scala中的length和size

scala中获取长度一般有 length, length(),size 。
【注 size()问题可见结尾备注】

测试这三种时发现

  • 1 当为字符串时,三种方法都可以:
val m = "qq,ww,ee,rr"
println(m.length)
println(m.length())
println(m.size)
结果:

m: String = qq,ww,ee,rr
11
11
11

  • 2 当为Array或者List等其他类型时,length()方法均会报错:
val m = "qq,ww,ee,rr"
var a = m.split(",")
println(a.length)
println(a.size)
println(a.length())

结果:
m: String = qq,ww,ee,rr
a: Array[String] = Array(qq, ww, ee, rr)
4
4
:67: error: Int does not take parameters
       println(a.length())


var b = List[String]("1", "2")
println(b.length)
println(b.size)
println(b.length())
结果:
b: List[String] = List(1, 2)
2
2
:65: error: Int does not take parameters
       println(b.length())

参考 java中的length和size

1 java中的length属性是针对数组说的,比如说你声明了一个数组,想知道这个数组的长度则用到了length这个属性.

2 java中的length()方法是针对字符串String说的,如果想看这个字符串的长度则用到length()这个方法.

3.java中的size()方法是针对泛型集合说的,如果想看这个泛型有多少个元素,就调用此方法来查看

结论是string用length(),其他用size或者length。

注:查阅资料发现还有size() 但是测试时发现一直报错:

val n = "qq,ww,ee,rr"
var nn = m.split(",")
println(nn.size())
报错:
:221: error: Int does not take parameters
       println(nn.size())

查阅资料并没有发现解决办法,希望有人可以解答

你可能感兴趣的:(Scala,Spark)