-
Notifications
You must be signed in to change notification settings - Fork 1.1k
/
Copy pathfors.scala
117 lines (88 loc) · 3.49 KB
/
fors.scala
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
//############################################################################
// for-comprehensions (old and new syntax)
//############################################################################
//############################################################################
object Test extends App {
val xs = List(1, 2, 3)
val ys = List(Symbol("a"), Symbol("b"), Symbol("c"))
def it = 0 until 10
val ar = "abc".toCharArray
/////////////////// old syntax ///////////////////
def testOld(): Unit = {
println("\ntestOld")
// lists
for (x <- xs) print(x + " "); println()
for (x <- xs;
if x % 2 == 0) print(x + " "); println()
for {x <- xs
if x % 2 == 0} print(x + " "); println()
var n = 0
for (_ <- xs) n += 1; println(n)
for ((x, y) <- xs zip ys) print(x + " "); println()
for (p @ (x, y) <- xs zip ys) print(p._1 + " "); println()
// iterators
for (x <- it) print(x + " "); println()
for (x <- it;
if x % 2 == 0) print(x + " "); println()
for {x <- it
if x % 2 == 0} print(x + " "); println()
// arrays
for (x <- ar) print(x + " "); println()
for (x <- ar;
if x.toInt > 97) print(x + " "); println()
for {x <- ar
if x.toInt > 97} print(x + " "); println()
}
/////////////////// new syntax ///////////////////
def testNew(): Unit = {
println("\ntestNew")
// lists
var n = 0
for (_ <- xs) n += 1; println(n)
for ((x, y) <- xs zip ys) print(x + " "); println()
for (p @ (x, y) <- xs zip ys) print(p._1 + " "); println()
// iterators
for (x <- it) print(x + " "); println()
for (x <- it if x % 2 == 0) print(x + " "); println()
for (x <- it; if x % 2 == 0) print(x + " "); println()
for (x <- it;
if x % 2 == 0) print(x + " "); println()
for (x <- it
if x % 2 == 0) print(x + " "); println()
for {x <- it
if x % 2 == 0} print(x + " "); println()
for (x <- it;
y = 2
if x % y == 0) print(x + " "); println()
for {x <- it
y = 2
if x % y == 0} print(x + " "); println()
// arrays
for (x <- ar) print(x + " "); println()
}
/////////////////// filtering with case ///////////////////
def testFiltering(): Unit = {
println("\ntestFiltering")
val xs: List[Any] = List((1, 2), "hello", (3, 4), "", "world")
for (case x: String <- xs) do print(s"$x "); println()
for (case (x: String) <- xs) do print(s"$x "); println()
for (case y@ (x: String) <- xs) do print(s"$y "); println()
for (case (x, y) <- xs) do print(s"$x~$y "); println()
for (case (x: String) <- xs if x.isEmpty) do print("(empty)"); println()
for (case (x: String) <- xs; y = x) do print(s"$y "); println()
for (case (x: String) <- xs; case (y, z) <- xs) do print(s"$x/$y~$z "); println()
for (case (x, y) <- xs) do print(s"${(y, x)} "); println()
for case x: String <- xs do print(s"$x "); println()
for case (x: String) <- xs do print(s"$x "); println()
for case y@ (x: String) <- xs do print(s"$y "); println()
for case (x, y) <- xs do print(s"$x~$y "); println()
for case (x: String) <- xs if x.isEmpty do print("(empty)"); println()
for case (x: String) <- xs; y = x do print(s"$y "); println()
for case (x: String) <- xs; case (y, z) <- xs do print(s"$x/$y~$z "); println()
for case (x, y) <- xs do print(s"${(y, x)} "); println()
}
////////////////////////////////////////////////////
testOld()
testNew()
testFiltering()
}