前言
用過c#的可能對 yield 關鍵字愛不釋手,那么在像我這種被迫上java賊船的人,就想找到類似的功能。
關于c#中的yield關鍵字大家可以參考這篇文章:http://www.jfrwli.cn/article/222256.html
我使用的是kotlin,下面的方法演示了產(chǎn)生一個序列的功能。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
val fibonacciSeq = buildSequence { var a = 0 var b = 1 yield( 1 ) while ( true ) { yield(a + b) val tmp = a + b a = b b = tmp } } fun main(args: Array<String>){ fibonacciSeq.take( 50 ).forEach { println(it) } } |
程序?qū)?zhí)行50次然后退出。
實現(xiàn)枚舉器
上面的代碼使用的是序列功能,并非是常見的枚舉器,下面的代碼更像c#的枚舉器。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
class MyList : Iterable<Int>{ private val list = arrayOf( 1 , 2 , 3 , 4 , 5 , 6 ) override fun iterator(): Iterator<Int> { return buildIterator { val size = list.size for (i in 0 until size) { yield(list[i] + i) } } } } fun main(args: Array<String>){ val list = MyList() for (p in list) { println(p) } } |
實現(xiàn)類似Linq
我們在使用Linq時可以將序列不斷的變換,Kotlin也可以很方便的處理。
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
|
//將輸入的數(shù)據(jù) + 1 fun Do1(seq : Sequence<Int>) : Sequence<Int>{ return buildSequence { for (i in seq){ yield(i + 1 ) } } } //變換成字符串 fun Do2(seq : Sequence<Int>) : Sequence<String>{ return buildSequence { for (i in seq){ yield( "hello $i " ) } } } //將多個數(shù)據(jù)聚合到一個數(shù)據(jù) fun Do3(seq : Sequence<String>) : Sequence<String>{ return buildSequence{ var result = "" var count = 0 for (i in seq){ result += i count++ if (count == 3 ){ yield(result) result = "" count = 0 } } if (count > 0 ){ yield(result) } } } fun main(args: Array<String>){ val data = arrayOf( 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 ) val result = Do3(Do2(Do1(data.asSequence()))) for (p in result){ println(p) } } |
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對服務器之家的支持。
原文鏈接:http://www.cnblogs.com/tansm/p/9211244.html