久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

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

Java 和 Scala 如何調用變參

瀏覽:8日期: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
相關文章:
主站蜘蛛池模板: 精品影院 | 久久久久亚洲视频 | 日本二区在线观看 | 午夜影晥 | 国产羞羞视频在线观看 | 国产日韩欧美精品 | 9色porny自拍视频一区二区 | 天天干天天操天天爽 | 激情久久久久 | 在线永久免费观看日韩a | 成人欧美一区二区三区在线观看 | 国产精品毛片久久久久久 | 天天澡天天狠天天天做 | 国内成人精品2018免费看 | 亚洲精品久久久久久久久久久 | 国产精品久久久久久久午夜 | 欧美一区久久 | 第四色影音先锋 | 男人的天堂在线视频 | 中文字幕在线视频免费观看 | 欧美在线高清 | 亚洲免费精品 | 亚洲精品色 | 精品一区二区三区免费 | aa毛片 | 精品国产一区二区三区久久久蜜 | 久久6| 一区二区三区中文字幕 | 国产成人精品一区二 | 欧美一级在线观看 | 五月天婷婷激情视频 | 中文字幕一区在线观看视频 | 国产精品一区二区在线看 | 亚洲电影一区二区 | 午夜精品久久久久 | 欧美一级在线 | 国产免费自拍视频 | 国产一级黄色大片 | 欧美理论视频 | 激情综合色综合久久综合 | 美女久久久久 |