suspend fun sf1(){
Log.e(MainActivity.TAG,"testSuspendFun1_sf1_04,當(dāng)前線程:${Thread.currentThread().name}")
// delay(3000)
var x = 0;
for(i in 1..1000000000){
x += i
}
Log.e(MainActivity.TAG,"testSuspendFun1_sf1_05,當(dāng)前線程:${Thread.currentThread().name}")
}
launch
fun testSuspendFun1(){
val mScope = MainScope()
//執(zhí)行順序 1
Log.e(MainActivity.TAG,"testSuspendFun1_01,當(dāng)前線程:${Thread.currentThread().name}")
mScope.launch {
//創(chuàng)建并運(yùn)行一個(gè)異步 ,但不是切換線程
//執(zhí)行順序 3
Log.e(MainActivity.TAG,"testSuspendFun1_03,當(dāng)前線程:${Thread.currentThread().name}")
//執(zhí)行順序 4
sf1()
//執(zhí)行順序 5
Log.e(MainActivity.TAG,"testSuspendFun1_06,當(dāng)前線程:${Thread.currentThread().name}")
}
//執(zhí)行順序 2
Log.e(MainActivity.TAG,"testSuspendFun1_02,當(dāng)前線程:${Thread.currentThread().name}")
}
async
fun testSuspendFun2(){
val mScope = MainScope()
//執(zhí)行順序 1
Log.e(MainActivity.TAG,"testSuspendFun2,01,當(dāng)前線程:${Thread.currentThread().name}")
val job = mScope.launch {
//創(chuàng)建并運(yùn)行一個(gè)異步 ,但不是切換線程
//執(zhí)行順序 3
Log.e(MainActivity.TAG,"testSuspendFun2,03,當(dāng)前線程:${Thread.currentThread().name}")
val deferred = this.async {
//創(chuàng)建一個(gè)異步,暫時(shí)不運(yùn)行
//執(zhí)行順序 6
Log.e(MainActivity.TAG,"testSuspendFun2,06,當(dāng)前線程:${Thread.currentThread().name}")
sf1()
1
}
//執(zhí)行順序 4
Log.e(MainActivity.TAG,"testSuspendFun2,04,當(dāng)前線程:${Thread.currentThread().name}")
sf1()
//執(zhí)行順序 5
Log.e(MainActivity.TAG,"testSuspendFun2,05,當(dāng)前線程:${Thread.currentThread().name}")
val result = deferred.await()
//執(zhí)行順序 7
Log.e(MainActivity.TAG,"testSuspendFun2,07,當(dāng)前線程:${Thread.currentThread().name}")
}
//執(zhí)行順序 2
Log.e(MainActivity.TAG,"testSuspendFun2,02,當(dāng)前線程:${Thread.currentThread().name}")
}
最后編輯于 :2024.04.17 14:38:08
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者 【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。 平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。