2012年1月25日水曜日

Scala Tips / null

null値の可能性がある値をnull値ではない普通の値に持ち上げるイディオムです。

(分類の基準)

Java風

if式で変数がnullかどうかを判定します。

  1. def f(a: String, b: String): String = {  
  2.   if (a == null) b  
  3.   else a  
  4. }  

実際に使う時は以下のような感じになります。

  1. val c = if (a == null) b else a  

Scala風

match式を使う時は以下のようになります。この場合は、Java風の方が簡潔ですね。

  1. def f(a: String, b: String): String = {  
  2.   a match {  
  3.     case null => b  
  4.     case _ => a  
  5.   }  
  6. }  

Scala

OptionとOption#getOrElseを使うと簡潔に記述できます。

  1. def f(a: String, b: String): String = {  
  2.   Option(a) getOrElse b  
  3. }  

Scalaz

Scalazを使うと、さらに簡潔に記述することができます。

  1. def f(a: String, b: String): String = {  
  2.   a ?? b  
  3. }  

以下のような形でメソッドの引数に書きたい場合は、"??"を使った簡潔な記述方法は重宝します。

  1. val a = SomeJavaObject.getStringValue()  
  2. println("Value is " + a ?? "unknown")  

ノート

プログラムの実行速度という観点では、「Java風」が一番速く、「Scala」はオブジェクト生成とメソッド呼出しが余分に発生するためかなり遅くなります。「Scalaz」は、さらに一段余分にオブジェクト生成とメソッド呼出しが発生するため、さらに低速です。

つまり、Javaの実行速度とScalaの記述力のトレードオフが発生するわけです。実行速度を採るのであればJavaで書けばよいので、Scalaで書く以上、簡潔に記述できることを重視するのがよいでしょう。

まずScalaで書いてみて、プロファイルでホットスポットと判明した処理については、Java風に書き直したり、Java(場合によってはC++)で書いて呼び出すというアプローチになります。

0 件のコメント:

コメントを投稿