8000 Merge pull request #439 from KenjiOhtsuka/feature/add_japanese_cheats… · Renkai/scala.github.com@6169a7b · GitHub
[go: up one dir, main page]

Skip to content

Commit 6169a7b

Browse files
committed
Merge pull request scala#439 from KenjiOhtsuka/feature/add_japanese_cheatsheet
modify japanese expression
2 parents 18d1be3 + e323cb6 commit 6169a7b

File tree

1 file changed

+24
-24
lines changed

1 file changed

+24
-24
lines changed

ja/cheatsheets/index.md

Lines changed: 24 additions & 24 deletions
Original file line numberDiff line numberDiff line change
@@ -16,71 +16,71 @@ language: ja
1616
| <span class="label success">Good</span> `val x = 5`<br> <span class="label important">Bad</span> `x=6` | 定数 |
1717
| `var x: Double = 5` | 明示的な型 |
1818
| <span id="functions" class="h2">関数</span> | |
19-
| <span class="label success">Good</span> `def f(x: Int) = { x*x }`<br> <span class="label important">Bad</span> `def f(x: Int) { x*x }` | 関数定義<br> 隠れたエラー: = を書かないと Unit を返す処理になります。; 大惨事の原因になります。 |
19+
| <span class="label success">Good</span> `def f(x: Int) = { x*x }`<br> <span class="label important">Bad</span> `def f(x: Int) { x*x }` | 関数定義<br> 落とし穴: = を書かないと Unit を返す手続きになり、大惨事の原因になります。 |
2020
| <span class="label success">Good</span> `def f(x: Any) = println(x)`<br> <span class="label important">Bad</span> `def f(x) = println(x)` | 関数定義 <br> シンタックスエラー: すべての引数に型指定が必要です。 |
2121
| `type R = Double` | 型エイリアス |
22-
| `def f(x: R)` vs.<br> `def f(x: => R)` | 値による呼び出し <br> 名前による呼び出し(遅延評価パラメータ) |
22+
| `def f(x: R)` vs.<br> `def f(x: => R)` | 値渡し <br> 名前渡し (遅延評価パラメータ) |
2323
| `(x:R) => x*x` | 無名関数 |
2424
| `(1 to 5).map(_*2)` vs.<br> `(1 to 5).reduceLeft( _+_ )` | 無名関数: アンダースコアは位置に応じて引数が代入されます。 |
2525
| `(1 to 5).map( x => x*x )` | 無名関数: 引数を2回使用する場合は名前をつけます。 |
26-
| <span class="label success">Good</span> `(1 to 5).map(2*)`<br> <span class="label important">Bad</span> `(1 to 5).map(*2)` | 無名関数: 演算子の右側を省略する方法。 わかりやすく書きたいなら `2*_` と書くのがよいでしょう|
26+
| <span class="label success">Good</span> `(1 to 5).map(2*)`<br> <span class="label important">Bad</span> `(1 to 5).map(*2)` | 無名関数: 片側が束縛された中置演算。 わかりづらいので `2*_` と書くことを推奨します|
2727
| `(1 to 5).map { val x=_*2; println(x); x }` | 無名関数: ブロックスタイルでは最後の式の結果が戻り値になります。 |
2828
| `(1 to 5) filter {_%2 == 0} map {_*2}` | 無名関数: パイプラインスタイル (括弧でも同様) 。 |
2929
| `def compose(g:R=>R, h:R=>R) = (x:R) => g(h(x))` <br> `val f = compose({_*2}, {_-1})` | 無名関数: 複数のブロックを渡す場合は外側の括弧が必要です。 |
3030
| `val zscore = (mean:R, sd:R) => (x:R) => (x-mean)/sd` | カリー化の明示的記法 |
3131
| `def zscore(mean:R, sd:R) = (x:R) => (x-mean)/sd` | カリー化の明示的記法 |
32-
| `def zscore(mean:R, sd:R)(x:R) = (x-mean)/sd` | カリー化の簡易記法、ただし |
33-
| `val normer = zscore(7, 0.4)_` | 簡易記法を使用する場合、部分関数を取得するには末尾にアンダースコアが必要です。 |
32+
| `def zscore(mean:R, sd:R)(x:R) = (x-mean)/sd` | カリー化の糖衣構文、ただしこの場合、 |
33+
| `val normer = zscore(7, 0.4)_` | 部分関数を取得するには末尾にアンダースコアが必要です。 |
3434
| `def mapmake[T](g:T=>T)(seq: List[T]) = seq.map(g)` | ジェネリック型 |
3535
| `5.+(3); 5 + 3` <br> `(1 to 5) map (_*2)` | 中置記法 |
3636
| `def sum(args: Int*) = args.reduceLeft(_+_)` | 可変長引数 |
3737
| <span id="packages" class="h2">パッケージ</span> | |
3838
| `import scala.collection._` | ワイルドカードでインポートします。 |
39-
| `import scala.collection.Vector` <br> `import scala.collection.{Vector, Sequence}` | 選択してインポートします|
39+
| `import scala.collection.Vector` <br> `import scala.collection.{Vector, Sequence}` | 個別にインポートします|
4040
| `import scala.collection.{Vector => Vec28}` | 別名でインポートします。 |
4141
| `import java.util.{Date => _, _}` | Date を除いて java.util のすべてをインポートします。 |
42-
| `package pkg` _at start of file_ <br> `package pkg { ... }` | パッケージ宣言 |
42+
| _(ファイル先頭の)_ `package pkg` <br> `package pkg { ... }` | パッケージ宣言 |
4343
| <span id="data_structures" class="h2">データ構造</span> | |
4444
| `(1,2,3)` | タプルリテラル (`Tuple3`) |
45-
| `var (x,y,z) = (1,2,3)` | 構造化代入: タプルはパターンマッチにより展開して代入されます。 |
46-
| <span class="label important">Bad</span>`var x,y,z = (1,2,3)` | 隠れたエラー: 各変数にタプル全体が代入されます。 |
45+
| `var (x,y,z) = (1,2,3)` | 構造化代入: パターンマッチによるタプルの展開。 |
46+
| <span class="label important">Bad</span>`var x,y,z = (1,2,3)` | 隠れたエラー: 各変数にタプル全体が代入されます。 |
4747
| `var xs = List(1,2,3)` | リスト (イミュータブル) |
4848
| `xs(2)` | 括弧を使って添字を書きます。 ([slides](http://www.slideshare.net/Odersky/fosdem-2009-1013261/27)) |
4949
| `1 :: List(2,3)` | 先頭に要素を追加 |
50-
| `1 to 5` _次と同じ_ `1 until 6` <br> `1 to 10 by 2` | Range の簡易記法 |
51-
| `()` _(中身のない括弧)_ | Unit 型 の唯一のメンバ (C/Java でいう void) 。 |
52-
| <span id="control_constructs" class="h2">制御構造</span> | |
50+
| `1 to 5` _(_ `1 until 6` <br> `1 to 10 by 2` _と同じ)_ | Range の糖衣構文 |
51+
| `()` _(中身のない括弧)_ | Unit 型 の唯一の値(C/Java でいう void) 。 |
52+
| <span id="control_constructs" class="h2">制御構文</span> | |
5353
| `if (check) happy else sad` | 条件分岐 |
54-
| `if (check) happy` _次と同じ_ <br> `if (check) happy else ()` | 条件分岐の省略形 |
54+
| `if (check) happy` <br> _(_ `if (check) happy else ()` _と同じ)_ | 条件分岐の省略形 |
5555
| `while (x < 5) { println(x); x += 1}` | while ループ |
5656
| `do { println(x); x += 1} while (x < 5)` | do while ループ |
5757
| `import scala.util.control.Breaks._`<br>`breakable {`<br>` for (x <- xs) {`<br>` if (Math.random < 0.1) break`<br>` }`<br>`}`| break ([slides](http://www.slideshare.net/Odersky/fosdem-2009-1013261/21)) |
58-
| `for (x <- xs if x%2 == 0) yield x*10` _次と同じ_ <br>`xs.filter(_%2 == 0).map(_*10)` | for 内包表記: filter/map |
59-
| `for ((x,y) <- xs zip ys) yield x*y` _次と同じ_ <br>`(xs zip ys) map { case (x,y) => x*y }` | for 内包表記: 構造化代入 |
60-
| `for (x <- xs; y <- ys) yield x*y` _次と同じ_ <br>`xs flatMap {x => ys map {y => x*y}}` | for 内包表記: 直積 |
58+
| `for (x <- xs if x%2 == 0) yield x*10` <br>_(_ `xs.filter(_%2 == 0).map(_*10)` _と同じ)_ | for 内包表記: filter/map |
59+
| `for ((x,y) <- xs zip ys) yield x*y` <br>_(_ `(xs zip ys) map { case (x,y) => x*y }` _と同じ)_ | for 内包表記: 構造化代入 |
60+
| `for (x <- xs; y <- ys) yield x*y` <br>_(_ `xs flatMap {x => ys map {y => x*y}}` _と同じ)_ | for 内包表記: 直積 |
6161
| `for (x <- xs; y <- ys) {`<br> `println("%d/%d = %.1f".format(x,y, x*y))`<br>`}` | for 内包表記: 命令型の記述<br>[sprintf-style](http://java.sun.com/javase/6/docs/api/java/util/Formatter.html#syntax) |
62-
| `for (i <- 1 to 5) {`<br> `println(i)`<br>`}` | for 内包表記: 上限を含んだイテレート |
63-
| `for (i <- 1 until 5) {`<br> `println(i)`<br>`}` | for 内包表記: 上限を除いたイテレート |
62+
| `for (i <- 1 to 5) {`<br> `println(i)`<br>`}` | for 内包表記: 上限を含んだ走査 |
63+
| `for (i <- 1 until 5) {`<br> `println(i)`<br>`}` | for 内包表記: 上限を除いた走査 |
6464
| <span id="pattern_matching" class="h2">パターンマッチング</span> | |
6565
| <span class="label success">Good</span> `(xs zip ys) map { case (x,y) => x*y }`<br> <span class="label important">Bad</span> `(xs zip ys) map( (x,y) => x*y )` | case をパターンマッチのために関数の引数で使っています。 |
6666
| <span class="label important">Bad</span><br>`val v42 = 42`<br>`Some(3) match {`<br>` case Some(v42) => println("42")`<br>` case _ => println("Not 42")`<br>`}` | "v42" は任意の Int の値とマッチする変数名として解釈され、 "42" が表示されます。 |
6767
| <span class="label success">Good</span><br>`val v42 = 42`<br>`Some(3) match {`<br>`` case Some(`v42`) => println("42")``<br>`case _ => println("Not 42")`<br>`}` | バッククオートで囲んだ "\`v42\`" は既に存在する `v42` として解釈され、 "Not 42" が表示されます。 |
6868
| <span class="label success">Good</span><br>`val UppercaseVal = 42`<br>`Some(3) match {`<br>` case Some(UppercaseVal) => println("42")`<br>` case _ => println("Not 42")`<br>`}` | 大文字から始まる `UppercaseVal` は既に存在する定数として解釈され、新しい変数としては扱われません。 これにより `UppercaseVal``3` とは異なる値と判断され、 "Not 42" が表示されます。 |
6969
| <span id="object_orientation" class="h2">オブジェクト指向</span> | |
70-
| `class C(x: R)` _次と同じ_ <br>`class C(private val x: R)`<br>`var c = new C(4)` | コンストラクタの引数 - private |
70+
| `class C(x: R)` <br>_(_ `class C(private val x: R)`<br>`var c = new C(4)` _と同じ)_ | コンストラクタの引数 - private |
7171
| `class C(val x: R)`<br>`var c = new C(4)`<br>`c.x` | コンストラクタの引数 - public |
7272
| `class C(var x: R) {`<br>`assert(x > 0, "positive please")`<br>`var y = x`<br>`val readonly = 5`<br>`private var secret = 1`<br>`def this = this(42)`<br>`}`|<br>コンストラクタはクラスの body 部分 です。<br>public メンバ の宣言<br>読取可能・書込不可なメンバの宣言<br>private メンバ の宣言<br>代替コンストラクタ |
7373
| `new{ ... }` | 無名クラス |
7474
| `abstract class D { ... }` | 抽象クラスの定義 (生成不可) |
7575
| `class C extends D { ... }` | 継承クラスの定義 |
7676
| `class D(var x: R)`<br>`class C(x: R) extends D(x)` | 継承とコンストラクタのパラメータ (要望: 自動的にパラメータを引き継げるようになってほしい)
77-
| `object O extends D { ... }` | シングルトンオブジェクトの定義 (モジュールライク) |
77+
| `object O extends D { ... }` | シングルトンオブジェクトの定義 (モジュールに似ている) |
7878
| `trait T { ... }`<br>`class C extends T { ... }`<br>`class C extends D with T { ... }` | トレイト<br>実装を持ったインターフェースで、コンストラクタのパラメータを持つことができません。 [mixin-able]({{ site.baseurl }}/tutorials/tour/mixin-class-composition.html).
7979
| `trait T1; trait T2`<br>`class C extends T1 with T2`<br>`class C extends D with T1 with T2` | 複数のトレイトを組み合わせられます。 |
80-
| `class C extends D { override def f = ...}` | override をつけてオーバライドします。 |
81-
| `new java.io.File("f")` | オブジェクトの作成 |
82-
| <span class="label important">Bad</span> `new List[Int]`<br> <span class="label success">Good</span> `List(1,2,3)` | 型のエラー: 抽象型のオブジェクトは生成できません。<br>習慣的に型を書かない方法をとります|
80+
| `class C extends D { override def f = ...}` | メソッドの override は明示する必要があります。 |
81+
| `new java.io.File("f")` | オブジェクトの生成 |
82+
| <span class="label important">Bad</span> `new List[Int]`<br> <span class="label success">Good</span> `List(1,2,3)` | 型のエラー: 抽象型のオブジェクトは生成できません。<br>代わりに、習慣として、型を隠蔽するファクトリを使います|
8383
| `classOf[String]` | クラスの情報取得 |
8484
| `x.isInstanceOf[String]` | 型のチェック (実行時) |
8585
| `x.asInstanceOf[String]` | 型のキャスト (実行時) |
86-
| `x: String` | 型帰属 (コンパイル時) |
86+
| `x: String` | 型帰属 (コンパイル時) |

0 commit comments

Comments
 (0)
0