Android 进阶之刁钻问题汇总

Android 进阶之刁钻问题汇总,第1张

概述问题一:Android中子线程真的不能更新UI吗?参考回答:在onCreate()方法中创建的子线程访问UI是一种极端的情况,程序不会崩溃。由于ViewRootImpl还没有创建,所以无法检测当前线程是否为UI线程。ViewRootImpl的创建是在onResume()方法回调之后。ViewRootImpl是 问题一:AndroID 中子线程真的不能更新 UI 吗?

参考回答:
在 onCreate() 方法中创建的子线程访问 UI 是一种极端的情况,程序不会崩溃。由于
VIEwRootImpl 还没有创建,所以无法检测当前线程是否为 UI 线程。

VIEwRootImpl 的创建是在 onResume() 方法回调之后。VIEwRootImpl 是在 WindowManagerGlobal 的 addVIEw() 方法中创建的。问题二:AndroID 中为什么主线程不会因为 Looper.loop() 里的死循环卡死?

参考回答:

进程:每个app运行时前首先创建一个进程,该进程是由 Zygote fork 出来的,用于承载 App 上运行的各种 Activity/Service 等组件。进程对于上层应用来说是完全透明的,这也是Google有意为之,让App程序都是运行在AndroID Runtime。大多数情况一个App就运行在一个进程中,除非在AndroIDManifest.xml中配置AndroID:process属性,或通过native代码fork进程。线程:线程对应用来说非常常见,比如每次new Thread().start都会创建一个新的线程。该线程与App所在进程之间资源共享,从linux角度来说进程与线程除了是否共享资源外,并没有本质的区别,都是一个task_struct结构体,在cpu看来进程或线程无非就是一段可执行的代码,cpu采用CFS调度算法,保证每个task都尽可能公平的享有cpu时间片。对于线程既然是一段可执行的代码,当可执行代码执行完成后,线程生命周期便该终止了,线程退出。而对于主线程,我们是绝不希望会被运行一段时间,自己就退出,那么如何保证能一直存活呢?简单做法就是可执行代码是能一直执行下去的,死循环便能保证不会被退出,例如,binder 线程也是采用死循环的方法,通过循环方式不同与 Binder 驱动进行读写 *** 作,当然并非简单地死循环,无消息时会休眠。但这里可能又引发了另一个问题,既然是死循环又如何去处理其他事务呢?通过创建新线程的方式。真正会卡死主线程的 *** 作是在回调方法onCreate/onStart/onResume 等 *** 作时间过长,会导致掉帧,甚至发生 ANR,looper.loop本身不会导致应用卡死。问题三:Binder、IBinder、IInterface 的关系

参考回答:

Binder:概念意义的 Binder,和一个 BinderProxy 对象相关联;IBinder:一个接口,Binder类实现了它,是 Binder 的抽象;IInterface:一个接口,AIDL 接口必须继承它;点赞收藏分享@H_502_49@文章举报

小朵八发布了225 篇原创文章 · 获赞 64 · 访问量 20万+私信 关注 总结

以上是内存溢出为你收集整理的Android 进阶之刁钻问题汇总全部内容,希望文章能够帮你解决Android 进阶之刁钻问题汇总所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/web/1067308.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-05-26
下一篇2022-05-26

发表评论

登录后才能评论

评论列表(0条)

    保存