scala-函数定义时参数列表/可变参数、默认值

相比java,scala的函数定义时可以设置参数的默认值。但在scala调用java方法时不可用,要遵循java语法。

需要在参数列表的参数声明后面加个=默认值即可,如下图,tableName和etl_date的默认值分别为test和1225

//ss:SparkSession,sc:SparkContext,rdd:RDD[String],
  private def doGen(tableName: String = "test", resultDir: String, etl_date: String = "1225") = {

  }

在调用时,如果有默认值的参数只有一个且为最后一个,可以通过加或不加来区分。
如果在中间,需要通过形参名 = 实际变量或字面量的方式来表达某个参数没有赋值。如下:
没有指定tableName,则tableName会使用默认值

doGen(resultDir = rD, etl_date = ed)

注意使用命名参数时,顺序是可以重新排列的。 但是,如果某些参数被命名了,而其他参数没有,则未命名的参数要放在命名参数的前面 并且 按照其方法签名中的参数顺序。如下是错误示范

printName(last = "Smith", "john") // error: positional after named argument
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值