国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - Java教程 - Java和Scala集合間的相互轉(zhuǎn)換方式

Java和Scala集合間的相互轉(zhuǎn)換方式

2022-02-15 15:52COLLECTIONS Java教程

這篇文章主要介紹了Java和Scala集合間的相互轉(zhuǎn)換方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

Java和Scala集合間的相互轉(zhuǎn)換

在scala中,調(diào)用一個java的方法,通常需要傳遞相應(yīng)的參數(shù)。下面是scala與java互轉(zhuǎn)換對應(yīng)表

?
1
2
3
4
5
6
7
8
Iterator <=> java.util.Iterator
Iterator <=> java.util.Enumeration
Iterable <=> java.lang.Iterable
Iterable <=> java.util.Collection
mutable.Buffer <=> java.util.List
mutable.Set <=> java.util.Set
mutable.Map <=> java.util.Map
mutable.ConcurrentMap <=> java.util.concurrent.ConcurrentMap

scala與java互轉(zhuǎn)

?
1
2
3
4
5
6
7
import collection.JavaConverters._
import collection.mutable._
val map = Map("k" -> "v")
//轉(zhuǎn)換成java
val javaMap = map.asJava
//轉(zhuǎn)換成 scala
javaMap.asScala

注:在Scala內(nèi)部,這些轉(zhuǎn)換是通過一系列“包裝”對象完成的,這些對象會將相應(yīng)的方法調(diào)用轉(zhuǎn)發(fā)至底層的容器對象。所以容器不會在Java和Scala之間拷貝來拷貝去。

一個值得注意的特性是,如果你將一個Java容器轉(zhuǎn)換成其對應(yīng)的Scala容器,然后再將其轉(zhuǎn)換回同樣的Java容器,最終得到的是一個和一開始完全相同的容器對象(譯注:這里的相同意味著這兩個對象實際上是指向同一片內(nèi)存區(qū)域的引用,容器轉(zhuǎn)換過程中沒有任何的拷貝發(fā)生)

有一些Scala容器類型可以轉(zhuǎn)換成對應(yīng)的Java類型,但是并沒有將相應(yīng)的Java類型轉(zhuǎn)換成Scala類型的能力

?
1
2
3
4
Seq => java.util.List
mutable.Seq => java.util.List
Set => java.util.Set
Map => java.util.Map

因為Java并未區(qū)分可變?nèi)萜鞑豢勺內(nèi)萜黝愋停裕m然能將scala.immutable.List轉(zhuǎn)換成java.util.List,但所有的修改操作都會拋出“UnsupportedOperationException”

?
1
2
3
4
5
scala> jul = List(1, 2, 3).asJava
jul: java.util.List[Int] = [1, 2, 3]
scala> jul.add(7)
java.lang.UnsupportedOperationException
        at java.util.AbstractList.add(AbstractList.java:131)

Java與Scala的集合對比

一、Java集合

面向?qū)ο笳Z言對事物的體現(xiàn)是以對象的形式,為了對多個對象進行存儲。單單靠數(shù)組不足以解決問題,同時對對象的操作極為的不方便。數(shù)組不可以存儲不同的多個對象。

集合就像是一個容器,可以動態(tài)的把多個對象的引用放入到容器中。

Collection集合:不按照添加的順序存放對象的集合,集合內(nèi)元素的內(nèi)容是可以重復(fù)的。

保存一個一個的對象

1、Collection=>Set接口

元素不按照添加的順序(無序)、不可重復(fù)添加相同元素(內(nèi)容而不是地址)的集合

>HashSet

使用哈希算法實現(xiàn)的Set集合

去重規(guī)則:兩個對象的equals為true,并且兩個對象的哈希碼相等

如果想讓自定義對象重復(fù),需要重寫equals和hashCode

>LinkedSet

>TreeSet

?添加的順序是無序的,且不可重復(fù)

?注意添加元素的時候不能添加不同的類型,因為會進行比較,不同類型的元素?zé)o法進行比較

?1、自定義類要實現(xiàn)Comparable接口,實現(xiàn)并重寫方法。

?去重規(guī)則:compareTo返回0

?2、寫一個具體類,讓這個類實現(xiàn)Comparator接口,重寫compare方法,讓比較器關(guān)聯(lián)到TreeSet中

?使用樹實現(xiàn)的Set集合,底層是通過二叉樹實現(xiàn)的(=> 所以添加的數(shù)據(jù),遍歷出來后是看起來有順序的)

2、Collection=>List接口

元素按照添加的順序(有序)、可重復(fù)添加相同元素的集合

>ArrayList

?使用數(shù)組實現(xiàn)的List集合

>LinkedList ?

使用鏈表實現(xiàn)的List集合

>Vector ?

  • Vector:是線程安全的動態(tài)數(shù)組,底層是數(shù)組結(jié)構(gòu),初始化為長度為10的數(shù)組,如果容量滿了,按照2.0倍擴容。除了支持foreach和Iterator遍歷,還支持Enumeration迭代。

ArrayList和LinkedList

1.ArrayList是實現(xiàn)了基于動態(tài)數(shù)組的數(shù)據(jù)結(jié)構(gòu),LinkedList基于鏈表的數(shù)據(jù)結(jié)構(gòu)。

2.對于隨機訪問get和set,ArrayList覺得優(yōu)于LinkedList,因為LinkedList要移動指針。

3.對于新增和刪除操作add和remove,LinedList比較占優(yōu)勢,因為ArrayList要移動數(shù)據(jù)。 這一點要看實際情況的。若只對單條數(shù)據(jù)插入或刪除,ArrayList的速度反而優(yōu)于LinkedList。但若是批量隨機的插入刪除數(shù)據(jù),LinkedList的速度大大優(yōu)于ArrayList. 因為ArrayList每插入一條數(shù)據(jù),要移動插入點及之后的所有數(shù)據(jù)。

Arraylist,LinkedList,Vector的區(qū)別

  • ArrayList:是線程不安全的動態(tài)數(shù)組,底層是數(shù)組結(jié)構(gòu),JDK1.7后初始化為空數(shù)組,在添加第一個元素時初始化為長度為10的數(shù)組,如果容量滿了,按照1.5倍擴容。支持foreach和Iterator遍歷。
  • Vector:是線程安全的動態(tài)數(shù)組,底層是數(shù)組結(jié)構(gòu),初始化為長度為10的數(shù)組,如果容量滿了,按照2.0倍擴容。除了支持foreach和Iterator遍歷,還支持Enumeration迭代。
  • LinkedList:是雙向鏈表,底層是鏈表結(jié)構(gòu)。當(dāng)頻繁在集合中插入、刪除元素時,效率較高,但是查找遍歷的效率較低。

3、Map接口

Map集合:保存一對一對的對象

具有映射關(guān)系“Key-Value”形式的集合

1、Map中的key和value都可以是任何引用類型的數(shù)據(jù)

2、Map中的key是用set來進行存放的,不允許重復(fù),也就是說同一個Map對象所對應(yīng)的類,需要重寫hashCode和equals方法

3、Map中的key和value存在單向一一對應(yīng)關(guān)系,通過指定的key,可以唯一確定value的值

Map是如何維護k-v的呢?

  • Entry:橫向來看,條目對象里面是一個一個的鍵值對,若干個Entry構(gòu)成一個Map(無序不可重復(fù))EntrySet

縱向來看KeySet專門放鍵,Collection放值

>HashMap ?

HashMap是線程不安全的哈希表,底層結(jié)構(gòu)是JDK1.7時數(shù)組+鏈表,JDK1.8時數(shù)組+鏈表/紅黑樹。

HashMap的線程安全問題可以使用Collections的synchronizedMap(Map<K,V> m) 方法解決。

>TreeMap

> Hashtable ?

Hashtable是線程安全的哈希表,底層結(jié)構(gòu)是數(shù)組+鏈表。

二、Scala集合

>1、Scala集合有三個大類:序列Seq、集Set、映射Map。并且所有的集合都有自己擴展的特質(zhì)

>2、對于幾乎所有的集合類,Scala都同時提供了可變與不可變兩個版本,位于兩個包下

? 不可變集合:scala.collection.immutable

? 不可變集合指的是,該集合的對象不能修改,每次修改過后,就會產(chǎn)生新的對象。這里修改指的是長度的改變,增加或減少。當(dāng)只是修改對象里面的屬性時,是可以的。

? 可變集合:scala.collection.immutable

? 可變集合指的是,可以對原對象修改,并且不會產(chǎn)生新的對象。

常用 ==>

1、Seq

不可變:~

–>IndexedSeq

Array,String ->底層隱式轉(zhuǎn)化

–>LinearSeq

List,Queue,Stack

可變:~

  • ArrayBuffer
  • StringBuffer

2、Set

默認情況下,Set使用的是不可變集合,如果想要使用可變的集合,需要導(dǎo)包–scala.collection.mutable.Set

無序,且數(shù)據(jù)不可重復(fù)

3、Map

創(chuàng)建Map,默認是不可改變的。

使用可變的時候,和Java的一樣。

值得注意的是:

根據(jù)key,獲取value值有兩種情況~

1.獲取到value

2.沒有獲取到,返回空

與java不同的是,Scala沒有類似于Java直接獲取(get())方法,Scala為了避免取到null值,添加了新的類型Option

Option下有兩個子類 None | Some – None相當(dāng)于沒獲取到值,Some會對獲取到的value進行包裝處理

如果返回None,可以進行二次處理,給一個默認值

如果真的想通過key來獲取Value可以使用getOrElse(elem,default) 函數(shù)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持服務(wù)器之家。

原文鏈接:https://docs.scala-lang.org/zh-cn/overviews/collections/conversions-between-java-and-scala-collections.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 欧美日韩不卡视频 | a视频在线| 欧美日韩中 | 免费人成黄页网站在线一区二区 | 午夜精品影院 | 91精品国产乱码久久久久久 | 国产黄免费在线观看 | 亚洲成人精品在线观看 | 国产精品com | 国产精品永久免费视频 | www.黄在线看 | 亚洲视频中文字幕 | 国产亚洲精品久久久久动 | 99色综合| 国产成人精品一区二区在线 | 欧美日韩第一区 | 91性高湖久久久久久久久网站 | 欧美日韩久久精品 | 久久综合久色欧美综合狠狠 | 久久精品一区二区三区四区 | 久久女人网 | 成人高清视频在线 | 黄色免费av | 亚洲美女在线视频 | 精久久| 99伊人 | 亚洲视频欧美视频 | 国产中文字幕亚洲 | 精品二区 | 中文字幕高清在线 | 黄色片在线免费观看 | 国外成人在线视频网站 | 国产一区二区三区成人 | 欧美日韩精品一区二区三区蜜桃 | 欧美精产国品一二三区 | 黄毛片视频 | 欧美一区永久视频免费观看 | 国产中文在线 | 精品欧美一区二区三区久久久 | 午夜精品一区二区三区在线视频 | 午夜精品一区二区三区免费视频 |