-
Notifications
You must be signed in to change notification settings - Fork 10.4k
/
Copy pathconcurrency-taskgroup.swift
61 lines (54 loc) · 1.46 KB
/
concurrency-taskgroup.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
57
58
59
60
61
// RUN: %empty-directory(%t)
// RUN: %target-swift-frontend -enable-experimental-feature Embedded -target %target-cpu-apple-macos14 -parse-as-library %s -c -o %t/a.o
// RUN: %target-clang %t/a.o -o %t/a.out -L%swift_obj_root/lib/swift/embedded/%target-cpu-apple-macos -lswift_Concurrency -lswift_ConcurrencyDefaultExecutor -dead_strip
// RUN: %target-run %t/a.out | %FileCheck %s
// REQUIRES: executable_test
// REQUIRES: swift_in_compiler
// REQUIRES: optimized_stdlib
// REQUIRES: OS=macosx
// REQUIRES: swift_feature_Embedded
import _Concurrency
protocol Go: Actor {
var name: String { get }
func go(times: Int) async -> Int
}
extension Go {
func go(times: Int) async -> Int {
for i in 0..<times {
print("\(name) @ \(i)")
await Task.yield()
}
return times
}
}
actor One: Go { var name = "One" }
actor Two: Go { var name = "Two" }
func yielding() async {
let one = One()
let two = Two()
await withTaskGroup(of: Int.self) { group in
group.addTask {
await one.go(times: 5)
}
group.addTask {
await two.go(times: 5)
}
}
}
@main struct Main {
static func main() async {
await yielding()
print("All done!")
// CHECK: One @ 0
// CHECK: Two @ 0
// CHECK: One @ 1
// CHECK: Two @ 1
// CHECK: One @ 2
// CHECK: Two @ 2
// CHECK: One @ 3
// CHECK: Two @ 3
// CHECK: One @ 4
// CHECK: Two @ 4
// CHECK: All done!
}
}