我在Kotlin中为Android集成了一个简单的演示应用程序,该应用程序使用Jsoup检索了网页的标题.我正在使用dispatchers.Main作为上下文进行网络呼叫.
我对协程的理解是,如果我在dispatchers.Main上调用launch,它的确在主线程上运行,但是会暂停执行以免阻塞线程.
我对androID.os.networkonmainthreadException的理解是它存在,因为网络 *** 作很繁琐,并且在主线程上运行时会阻止它.
所以我的问题是,鉴于协程不会阻塞运行它的线程,所以networkonmainthreadException真的有效吗?以下是一些示例代码,它们在Jsoup.connect(url).get()处抛出给定的异常:
class MainActivity : AppCompatActivity() { val job = Job() val mainScope = Coroutinescope(dispatchers.Main + job) // called from onCreate() private fun printTitle() { mainScope.launch { val url ="https://kotlinlang.org" val document = Jsoup.connect(url).get() Log.d("MainActivity", document.Title()) // ... update UI with Title } }}
我知道我可以使用dispatchers.IO上下文简单地运行它,并将结果提供给main / UI线程,但这似乎避开了协程的某些实用程序.
作为参考,我正在使用Kotlin 1.3.
解决方法:
My understanding of coroutines is that if I call launch on the dispatchers.Main it does run on the main thread, but suspends the execution so as to not block the thread.
挂起执行以便不阻塞线程的唯一点是标记为暂停的方法,即挂起方法.
由于Jsoup.connect(url).get()不是挂起方法,因此它会阻塞当前线程.当您使用dispatchers.Main时,当前线程是主线程,并且您的网络 *** 作直接在主线程上运行,从而导致networkonmainthreadException.
可以通过将其包装在withContext()中来使类似于get()方法的阻塞工作挂起,这是一个挂起方法,可确保在该方法运行时不会阻塞dispatchers.Main.
mainScope.launch { val url ="https://kotlinlang.org" val document = withContext(dispatchers.IO) { Jsoup.connect(url).get() } Log.d("MainActivity", document.Title()) // ... update UI with Title}
总结 以上是内存溢出为你收集整理的android-NetworkOnMainThreadException对协程中的网络调用有效吗?全部内容,希望文章能够帮你解决android-NetworkOnMainThreadException对协程中的网络调用有效吗?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)