亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

Java 和 Scala 如何調用變參

瀏覽:2日期:2022-08-25 16:56:40

Java 和 Scala 都支持變參方法, 寫在最后的位置上,最基本的調用方式也都是一樣的,一個個羅列過去。也可以傳入數組參數,因為變參本質上就是一個數組,就是把 ... 開始位置到最后一個參數都收納到數組中去,所以變參之所以要放在最后的位置上,且一個方法中最多只能有一個變參類型。

這里主要是對比 Scala 對變參方法的調用,基本調用法當然是沒問題的,但是在傳入數組作為變參的參數列表與 Java 相對時就稍有變化了。

另外提一下,如果想傳入 List 作為變參列表,而不是整體作為變參的第一個元素就是調用集合的 toArray() 方法轉換成一個數組傳入。

下面看 Java 中對變參方法的調用,參數列表和數組

public class JavaVarArgs { public static void main(String[] args) { foo('a', 'b', 'c'); foo(new String[]{'d', 'e'}); } public static void foo(String...params) { System.out.println(params + ' : ' + params.length); for(String s: params) { System.out.println(s); } }}

從輸出結果能夠很明白的看出變參 params 實際上就是一個數組

[Ljava.lang.String;@3f91beef : 3abc[Ljava.lang.String;@1a6c5a9e : 2de

我們知道 Scala 和 Java 之間可以互相調用,現在寫一段 Scala 代碼來調用 foo() 方法

object ScalaVarArgs { def main(args: Array[String]) { JavaVarArgs.foo('a', 'b', 'c') // JavaVarArgs.foo(Array[String]('d', 'e')) }}

JavaVarArgs.foo('a', 'b', 'c') 調用沒問題

而 JavaVarArgs.foo(Array[String]('d', 'e')) 會有編譯問題

Type mismatch: expected String, actual Array[String]

Java 在調用變參方法時可以直接傳入相應類型的數組,而 Scala 確不允許這么做了,因它試圖把 Array[String] 整體作為一個元素傳遞給 foo() 方法,而 foo() 要求的元素類型是字符串,所以編譯不過。

而 Scala 這時該如何使得與 Java 調用變參方法時的行為一致呢,那就是在調用時再附加說明:是要把數組中的元素逐個傳遞級變參,寫法

JavaVarArgs.foo(Array[String]('d', 'e') :_*)

這樣的調用輸出就是

[Ljava.lang.String;@7a718e31 : 2de

如果從上面的例子說來,我們的運氣還不錯,因為編譯器告訴了你出現了什么問題。最麻煩的問題總是在能編譯,但運行時詭異的情況。

因為在我本人實際中遭遇到的情形是變參類型是 Object 的方法,形如

public static void foo(Object...params) { System.out.println(params + ' : ' + params.length); for(Object o: params) { System.out.println(o); } }

上面把參數改為 Object...params, 不會改變 Java 傳數組調用它的行為,但卻增加了 Scala 調用它時的排錯難度。

在 Scala 中使用 foo(Array[String]('d', 'e') 調用并沒有編譯錯誤,加入上面的調試代碼才發現,不管傳入多大的數組,總是輸出像

[Ljava.lang.Object;@7814d044 : 1[Ljava.lang.String;@ea25c1

說方法只接收到了一個元素,類型被識別為形參的類型,不過進一步遍歷變參,發現第一個元素是一個字符串數組,所以 Scala 把 Array[String]('d', 'e') 整體作為 params 的第一個元素傳給了 foo() 方法。寫成

foo(Array[String]('d', 'e') : _*)

是為了把數組拆散了傳給 foo() 方法。

起初以為是 Scala 調用 Java 的變參方法需要這么做,后來重新用 Scala 實現下變參方法

def foo(params: AnyRef*) { println(params + ' : ' + params.length) for (s <- params) { println(s) } }

用 Scala 代碼來調用它,傳入數組,如果不想整體作為一個元素時也必須加上 : _* 參數說明,同樣的:

foo(Array[String]('d', 'e') :_*)

在寫這篇之前,我所認定的這是 Scala 調用變參方法的一個缺陷,: _* 似乎是一種默認行為,現在認為這恰恰是 Scala 的一個靈活性所在。Scala 提供了兩種方式來傳遞數組給變參,而為何 Java 不讓數組整體作為變參的一個元素呢,不過 Scala 放開這一特性,當變參為 Object... params 確實放大了 Bug 的出現機率。

以上就是Java 和 Scala 如何調用變參的詳細內容,更多關于Java 和 Scala 調用變參的資料請關注好吧啦網其它相關文章!

標簽: Java
相關文章:
主站蜘蛛池模板: 亚洲毛片免费视频 | 亚洲第一页视频 | 黄色a视频| 尤物国产精品福利三区 | 黄色视屏免费 | 狠狠色丁香婷婷综合久久来 | 中文字幕在线观看一区 | 成年男女男精品免费视频网站 | 日韩不卡一二三区 | 日本不卡高清免费v日本 | 日本乱人伦片中文字幕三区 | 九九精品影院 | 第一次男生很猛的进去视频 | 欧美一区二区三区大片 | 国产精品成久久久久三级 | 一本一道久久综合狠狠老 | 国产成人综合久久综合 | 午夜色大片在线观看 | 特黄一级黄色片 | 92看片淫黄大片看国产片 | 在线观看欧美国产 | 水蜜桃爱爱yy视频在线观看 | 亚洲精品久久午夜香蕉 | 成人欧美一区二区三区的电影 | 久久综合亚洲一区二区三区 | 国产成人18黄网站麻豆 | 丁香婷婷激情综合 | 五月天婷婷在线视频国产在线 | 欧美三片 | 国产情趣酒店鸳鸯浴在线观看 | 国产精品一区高清在线观看 | 亚洲综合欧美日韩 | 欧美激情视频一区二区免费 | 欧美刺激午夜性久久久久久久 | 亚洲精品欧洲一区二区三区 | 青青草国产精品欧美成人 | 久久人人青草97香蕉 | 国产高清不卡视频在线播放 | 亚洲天天在线日亚洲洲精 | 伊人网综合在线视频 | 亚洲综合在线观看视频 |