Dominaezzz
09/25/2018, 2:27 PMDominaezzz
09/25/2018, 8:53 PMolonho
09/26/2018, 7:01 AMimport kotlin.native.concurrent.*
import kotlin.random.Random
import platform.posix.usleep
import kotlinx.cinterop.convert
data class Job(val index: Int, var input: Int, var counter: Int)
fun initJobs(count: Int) = Array<Job?>(count) { i -> Job(i, i * 2, i)}
fun main() {
val COUNT = 100
val workers = Array(COUNT, { _ -> Worker.start() })
val jobs = initJobs(COUNT)
val futures = Array(workers.size, { workerIndex ->
workers[workerIndex].execute(TransferMode.SAFE, {
val job = jobs[workerIndex]
jobs[workerIndex] = null
job!!
}) { job ->
job.counter += job.input
job
}
})
val futureSet = futures.toSet()
var consumed = 0
while (consumed < futureSet.size) {
val ready = futureSet.waitForMultipleFutures(10000)
ready.forEach {
it.consume { job ->
jobs[job.index] = job
}
consumed++
}
}
workers.forEach {
it.requestTermination().result
}
}
, note that due to bug, fixed in https://github.com/JetBrains/kotlin-native/pull/2135 TransferMode.UNSAFE
shall be used for that code to work, if used with current K/N versionDominaezzz
09/26/2018, 7:41 AM