Skip to content

Commit 07e420a

Browse files
authored
Merge pull request #630 from starsep/master
Polish translation of cheatsheets page
2 parents 7469348 + 44cbd32 commit 07e420a

File tree

2 files changed

+87
-1
lines changed

2 files changed

+87
-1
lines changed

cheatsheets/index.md

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -3,7 +3,7 @@ layout: cheatsheet
33
title: Scalacheat
44
by: Brendan O'Connor
55
about: Thanks to <a href="http://brenocon.com/">Brendan O'Connor</a>, this cheatsheet aims to be a quick reference of Scala syntactic constructions. Licensed by Brendan O'Connor under a CC-BY-SA 3.0 license.
6-
languages: [ba, fr, ja, pt-br]
6+
languages: [ba, fr, ja, pl, pt-br]
77
---
88

99
###### Contributed by {{ page.by }}

pl/cheatsheets/index.md

Lines changed: 86 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,86 @@
1+
---
2+
layout: cheatsheet
3+
istranslation: true
4+
title: Scalacheat
5+
by: Filip Czaplicki
6+
about: Podziękowania dla <a href="http://brenocon.com/">Brendan O'Connor</a>. Ten cheatsheet ma być szybkim podsumowaniem konstrukcji składniowych Scali. Licencjonowany przez Brendan O'Connor pod licencją CC-BY-SA 3.0.
7+
language: pl
8+
---
9+
10+
###### Contributed by {{ page.by }}
11+
12+
| | |
13+
| ------ | ------ |
14+
| <span id="variables" class="h2">zmienne</span> | |
15+
| `var x = 5` | zmienna |
16+
| <span class="label success">Dobrze</span> `val x = 5`<br> <span class="label important">Źle</span> `x=6` | stała |
17+
| `var x: Double = 5` | zmienna z podanym typem |
18+
| <span id="functions" class="h2">funkcje</span> | |
19+
| <span class="label success">Dobrze</span> `def f(x: Int) = { x*x }`<br> <span class="label important">Źle</span> `def f(x: Int) { x*x }` | definicja funkcji <br> ukryty błąd: bez znaku = jest to procedura zwracająca Unit; powoduje to chaos |
20+
| <span class="label success">Dobrze</span> `def f(x: Any) = println(x)`<br> <span class="label important">Źle</span> `def f(x) = println(x)` | definicja funkcji <br> błąd składni: potrzebne są typy dla każdego argumentu. |
21+
| `type R = Double` | alias typu |
22+
| `def f(x: R)` vs.<br> `def f(x: => R)` | wywołanie przez wartość <br> wywołanie przez nazwę (parametry leniwe) |
23+
| `(x:R) => x*x` | funkcja anonimowa |
24+
| `(1 to 5).map(_*2)` vs.<br> `(1 to 5).reduceLeft( _+_ )` | funkcja anonimowa: podkreślenie to argument pozycjonalny |
25+
| `(1 to 5).map( x => x*x )` | funkcja anonimowa: aby użyć argumentu dwa razy, musisz go nazwać. |
26+
| <span class="label success">Dobrze</span> `(1 to 5).map(2*)`<br> <span class="label important">Źle</span> `(1 to 5).map(*2)` | funkcja anonimowa: związana metoda infiksowa. Możesz użyć także `2*_`. |
27+
| `(1 to 5).map { x => val y=x*2; println(y); y }` | funkcja anonimowa: z bloku zwracane jest ostatnie wyrażenie. |
28+
| `(1 to 5) filter {_%2 == 0} map {_*2}` | funkcja anonimowa: styl potokowy. (lub ponawiasowane). |
29+
| `def compose(g:R=>R, h:R=>R) = (x:R) => g(h(x))` <br> `val f = compose({_*2}, {_-1})` | funkcja anonimowa: aby przekazać kilka bloków musisz użyć nawiasów. |
30+
| `val zscore = (mean:R, sd:R) => (x:R) => (x-mean)/sd` | rozwijanie funkcji, oczywista składnia. |
31+
| `def zscore(mean:R, sd:R) = (x:R) => (x-mean)/sd` | rozwijanie funkcji, oczywista składnia. |
32+
| `def zscore(mean:R, sd:R)(x:R) = (x-mean)/sd` | rozwijanie funkcji, lukier składniowy. ale wtedy: |
33+
| `val normer = zscore(7, 0.4) _` | potrzeba wiodącego podkreślenia, aby wydobyć funkcję częściowo zaaplikowaną, tylko dla wersji z lukrem składniowym. |
34+
| `def mapmake[T](g:T=>T)(seq: List[T]) = seq.map(g)` | typ generyczny. |
35+
| `5.+(3); 5 + 3` <br> `(1 to 5) map (_*2)` | lukier składniowy dla operatorów infiksowych. |
36+
| `def sum(args: Int*) = args.reduceLeft(_+_)` | zmienna liczba argumentów funkcji. |
37+
| <span id="packages" class="h2">pakiety</span> | |
38+
| `import scala.collection._` | import wszystkiego z danego pakietu. |
39+
| `import scala.collection.Vector` <br> `import scala.collection.{Vector, Sequence}` | import selektywny. |
40+
| `import scala.collection.{Vector => Vec28}` | import ze zmianą nazwy. |
41+
| `import java.util.{Date => _, _}` | importowanie wszystkiego z java.util poza Date. |
42+
| `package pkg` _na początku pliku_ <br> `package pkg { ... }` | deklaracja pakietu. |
43+
| <span id="data_structures" class="h2">struktury danych</span> | |
44+
| `(1,2,3)` | literał krotki. (`Tuple3`) |
45+
| `var (x,y,z) = (1,2,3)` | przypisanie z podziałem: rozpakowywanie krotki przy pomocy dopasowywania wzorca. |
46+
| <span class="label important">Źle</span>`var x,y,z = (1,2,3)` | ukryty błąd: do każdego przypisana cała krotka. |
47+
| `var xs = List(1,2,3)` | lista (niezmienna). |
48+
| `xs(2)` | indeksowanie za pomocą nawiasów. ([slajdy](http://www.slideshare.net/Odersky/fosdem-2009-1013261/27)) |
49+
| `1 :: List(2,3)` | operator dołożenia elementu na początek listy. |
50+
| `1 to 5` _to samo co_ `1 until 6` <br> `1 to 10 by 2` | składnia dla przedziałów. |
51+
| `()` _(puste nawiasy)_ | jedyny obiekt typu Unit (podobnie jak void w C/Java). |
52+
| <span id="control_constructs" class="h2">konstrukcje kontrolne</span> | |
53+
| `if (check) happy else sad` | warunek. |
54+
| `if (check) happy` _to samo co_ <br> `if (check) happy else ()` | lukier składniowy dla warunku. |
55+
| `while (x < 5) { println(x); x += 1}` | pętla while. |
56+
| `do { println(x); x += 1} while (x < 5)` | pętla do while. |
57+
| `import scala.util.control.Breaks._`<br>`breakable {`<br>` for (x <- xs) {`<br>` if (Math.random < 0.1) break`<br>` }`<br>`}`| instrukcja przerwania pętli (break). ([slides](http://www.slideshare.net/Odersky/fosdem-2009-1013261/21)) |
58+
| `for (x <- xs if x%2 == 0) yield x*10` _to samo co_ <br>`xs.filter(_%2 == 0).map(_*10)` | instrukcja for: filtrowanie / mapowanie |
59+
| `for ((x,y) <- xs zip ys) yield x*y` _to samo co_ <br>`(xs zip ys) map { case (x,y) => x*y }` | instrukcja for: przypisanie z podziałem |
60+
| `for (x <- xs; y <- ys) yield x*y` _to samo co_ <br>`xs flatMap {x => ys map {y => x*y}}` | instrukcja for: iloczyn kartezjański |
61+
| `for (x <- xs; y <- ys) {`<br> `println("%d/%d = %.1f".format(x,y, x*y))`<br>`}` | instrukcja for: imperatywnie<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>`}` | instrukcja for: iterowanie aż do górnej granicy |
63+
| `for (i <- 1 until 5) {`<br> `println(i)`<br>`}` | instrukcja for: iterowanie poniżej górnej granicy |
64+
| <span id="pattern_matching" class="h2">pattern matching (dopasowywanie wzorca)</span> | |
65+
| <span class="label success">Dobrze</span> `(xs zip ys) map { case (x,y) => x*y }`<br> <span class="label important">Źle</span> `(xs zip ys) map( (x,y) => x*y )` | używaj słowa kluczowego case w funkcjach w celu dopasowywania wzorca (pattern matching). |
66+
| <span class="label important">Źle</span><br>`val v42 = 42`<br>`Some(3) match {`<br>` case Some(v42) => println("42")`<br>` case _ => println("Not 42")`<br>`}` | "v42" jest interpretowane jako nazwa pasująca do każdej wartości typu Int, więc "42" zostaje wypisywane. |
67+
| <span class="label success">Dobrze</span><br>`val v42 = 42`<br>`Some(3) match {`<br>`` case Some(`v42`) => println("42")``<br>`case _ => println("Not 42")`<br>`}` | "\`v42\`" z grawisami jest interpretowane jako istniejąca wartość `v42`, więc "Not 42" zostaje wypisywane. |
68+
| <span class="label success">Dobrze</span><br>`val UppercaseVal = 42`<br>`Some(3) match {`<br>` case Some(UppercaseVal) => println("42")`<br>` case _ => println("Not 42")`<br>`}` | `UppercaseVal` jest traktowane jako istniejąca wartość, nie jako zmienna wzorca, bo zaczyna się z wielkiej litery. W takim razie wartość przechowywana w `UppercaseVal` jest porównywana z `3`, więc "Not 42" zostaje wypisywane. |
69+
| <span id="object_orientation" class="h2">obiektowość</span> | |
70+
| `class C(x: R)` _to samo co_ <br>`class C(private val x: R)`<br>`var c = new C(4)` | parametry konstruktora - prywatne |
71+
| `class C(val x: R)`<br>`var c = new C(4)`<br>`c.x` | parametry konstruktora - publiczne |
72+
| `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><br>konstruktor jest ciałem klasy<br>deklaracja publicznego pola<br>deklaracja publicznej stałej<br>deklaracja pola prywatnego<br>alternatywny konstruktor|
73+
| `new{ ... }` | klasa anonimowa |
74+
| `abstract class D { ... }` | definicja klasy abstrakcyjnej. (nie da się stworzyć obiektu tej klasy) |
75+
| `class C extends D { ... }` | definicja klasy pochodnej. |
76+
| `class D(var x: R)`<br>`class C(x: R) extends D(x)` | dziedziczenie i parametry konstruktora. (wishlist: domyślne, automatyczne przekazywanie parametrów)
77+
| `object O extends D { ... }` | definicja singletona. (w stylu modułu) |
78+
| `trait T { ... }`<br>`class C extends T { ... }`<br>`class C extends D with T { ... }` | cechy.<br>interface'y z implementacją. bez parametrów konstruktora. [możliwość mixin'ów]({{ site.baseurl }}/tutorials/tour/mixin-class-composition.html).
79+
| `trait T1; trait T2`<br>`class C extends T1 with T2`<br>`class C extends D with T1 with T2` | wiele cech. |
80+
| `class C extends D { override def f = ...}` | w przeciążeniach funkcji wymagane jest słowo kluczowe override. |
81+
| `new java.io.File("f")` | tworzenie obiektu. |
82+
| <span class="label important">Źle</span> `new List[Int]`<br> <span class="label success">Dobrze</span> `List(1,2,3)` | błąd typu: typ abstrakcyjny<br>zamiast tego konwencja: wywoływalna fabryka przysłaniająca typ |
83+
| `classOf[String]` | literał klasy. |
84+
| `x.isInstanceOf[String]` | sprawdzenie typu (w czasie wykonania) |
85+
| `x.asInstanceOf[String]` | rzutowanie typu (w czasie wykonania) |
86+
| `x: String` | oznaczenie typu (w czasie kompilacji) |

0 commit comments

Comments
 (0)