forked from swiftlang/swift
- Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathasync_let_fibonacci.swift
56 lines (44 loc) · 1.27 KB
/
async_let_fibonacci.swift
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
// RUN: %target-run-simple-swift( -target %target-swift-5.1-abi-triple -parse-as-library)
// REQUIRES: executable_test
// REQUIRES: concurrency
// UNSUPPORTED: freestanding
// rdar://76038845
// REQUIRES: concurrency_runtime
// UNSUPPORTED: back_deployment_runtime
func fib(_ n:Int)->Int{
varfirst=0
varsecond=1
for_in0..<n {
lettemp= first
first = second
second = temp + first
}
return first
}
@available(SwiftStdlib 5.1,*)
func asyncFib(_ n:Int)async->Int{
if n ==0 || n ==1{
return n
}
asyncletfirst=awaitasyncFib(n-2)
asyncletsecond=awaitasyncFib(n-1)
// Sleep a random amount of time waiting on the result producing a result.
try!awaitTask.sleep(nanoseconds:UInt64.random(in:0..<100)*1_000_000)
letresult=await first + second
// Sleep a random amount of time before producing a result.
try!awaitTask.sleep(nanoseconds:UInt64.random(in:0..<100)*1_000_000)
return result
}
@available(SwiftStdlib 5.1,*)
func runFibonacci(_ n:Int)async{
letresult=awaitasyncFib(n)
print("")
print("Async fib = \(result), sequential fib = \(fib(n))")
assert(result ==fib(n))
}
@available(SwiftStdlib 5.1,*)
@mainstructMain{
staticfunc main()async{
awaitrunFibonacci(10)
}
}