Android 协程 cpu密集型任务的取消

 /**
     * 密集型的任务取消
     */
    @Test
    fun `test cancel cpu task by isActive`() = runBlocking<Unit> {
        val startTime = System.currentTimeMillis()
        val job = launch(Dispatchers.Default) {
            var nexPrintTime = startTime
            var i = 0
            while (i < 5 && isActive) {
                if (System.currentTimeMillis() >= nexPrintTime) {
                    println("job:I'm sleeping ${i++}...")
                    nexPrintTime += 500
                }
            }


        }
        delay(1300)
        println("main:I'm tired of waiting")
        job.cancelAndJoin()
        println("main:Now i can quit.")


    }

如果不加 && isActive

会无法取消掉 把四次结果都打印出来。。

也可以是使用这个方法

    /**
     * 密集型的任务取消
     */
    @Test
    fun `test cancel cpu task by enSureActive`() = runBlocking<Unit> {
        val startTime = System.currentTimeMillis()
        val job = launch(Dispatchers.Default) {
            var nexPrintTime = startTime
            var i = 0
            while (i < 5) {
                ensureActive()
                if (System.currentTimeMillis() >= nexPrintTime) {
                    println("job:I'm sleeping ${i++}...")
                    nexPrintTime += 500
                }
            }


        }
        delay(1300)
        println("main:I'm tired of waiting")
        job.cancelAndJoin()
        println("main:Now i can quit.")

    }

    ensureActive() 抛出Cancel的那个异常来退出循环

还有一种方式通过yield

 /**
     * 密集型的任务取消
     */
    @Test
    fun `test cancel cpu task by yield`() = runBlocking<Unit> {
        val startTime = System.currentTimeMillis()
        val job = launch(Dispatchers.Default) {
            var nexPrintTime = startTime
            var i = 0
            while (i < 5) {
                yield()
                if (System.currentTimeMillis() >= nexPrintTime) {
                    println("job:I'm sleeping ${i++}...")
                    nexPrintTime += 500
                }
            }


        }
        delay(1300)
        println("main:I'm tired of waiting")
        job.cancelAndJoin()
        println("main:Now i can quit.")

    }

yield()也是抛出异常退出

会出让线程的执行权  

如果想退出的时候抛出来异常可以使用finally

    /**
     * 协程取消的副作用
     */
    @Test
    fun `test release resources`() = runBlocking<Unit> {
        val job = launch {
            try {
                repeat(1000) { i ->
                    println("job:I'm sleeping ${i}...")
                    delay(500L)
                }
            } finally {
                println("job : I'm running finally")
            }
        }

        delay(1300)
        println("main:I'm tired of waiting")
        job.cancelAndJoin()
        println("main:Now i can quit.")
    }
}

try finlly 虽然时尚。但是kotlin有更好的标准函数 use

可以用来处理被实现了Closeable的对象 

程序结束会自动调用close方法。适合文件对象。

    @Test
    fun `test use function`() = runBlocking<Unit> {
        val filePatg =
            "H:\\develop\\project\\android\\learn\\coroutine\\app\\src\\test\\java\\com\\example\\coroutine\\CoroutineTest02.kt"
        println("plan1:")
        val br = BufferedReader(FileReader(filePatg))
        with(br) {
            try {
                var line: String?
                while (true) {
                    line = readLine() ?: break
                    println(line)
                }
            } finally {
                close()
            }
        }
        //还可以使用use
        println("plan2:")
        val br2 = BufferedReader(FileReader(filePatg))
        br2.use {
            var line: String?
            while (true) {
                line = it.readLine() ?: break
                println(line)
            }
        }


    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

安果移不动

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值