搜索
搜 索
本版
文章
帖子
用户
图文精华
hadoop-2.6.0+zookeeper-3.4.6+hbase-1.0.0+hive-1.1.0完全分布 ...
首页
Portal
专题
BBS
面试
更多
登录
注册
用户组:游客
主题
帖子
云币
我的帖子
我的收藏
我的好友
我的勋章
设置
退出
导读
淘贴
博客
群组
社区VIP
APP下载
今日排行
本周排行
本周热帖
本月排行
本月热帖
会员排行
About云-梭伦科技
»
专题
›
交流区
›
移动云计算
›
浅谈zygote服务中的设计思路
0
0
0
分享
浅谈zygote服务中的设计思路
wscl1213
发表于 2013-12-15 23:53:05
[显示全部楼层]
只看大图
阅读模式
关闭右栏
0
4850
zygote服务是Android启动和服务APK的核心服务,每个APK都是通过zygote启动,今日阅读它的源码学习到一个不错的设计思路。
首先看看一个APK通过zygote的启动流程:
按照一般的设计思路,既然每个APK都是由单独的dalvik启动和运行,那么直接通过dalvikvm启动main不就完了吗吗?为啥还要搞得这么长一串流程。其实关键就在于这个Fork。我们看看对于linux启动一个进程的一般流程:
内核创建一个进程数据结构 内核从指定的程序文件读取程序代码并装载到设定的内存地址 内核从指定的目标程序入口执行代码[/ol]而对于一个普通的APK来说,它需要能访问到整个framework,所以第二步就需要装载整个framework,这对于启动apk这么频繁的操作来说是不小的性能损耗。而Fork是在本进程的基础上直接复制出一个新的进程,并且具有相同的进程数据结构,因此只要在Fork之前zygote预先载入共享的底层资源,就省去了后面所有apk载入framework的过程。具体代码非常清晰简单,可见源码列表:
/framework/base/cmds/app_process/app_main.cpp:zygote服务启动入口 /frameworks/base/core/java/com/android/internal/os/ZygoteInit.java:初始化Socket服务端,并负责fork dalvik进程
/libcore/dalvik/src/main/java/dalvik/system/Zygote.java:包装native fork方法
代码比较简单直接,就不多解释。这里可以吸取的是当需要设计一个频繁启动进程的系统时,如果进程间有很多可以同享的程序和数据时,可以考虑通过fork来实现。
回复
使用道具
举报
提升卡
置顶卡
沉默卡
喧嚣卡
变色卡
千斤顶
显身卡
没找到任何评论,期待你打破沉寂
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
本版积分规则
发表回复
回帖后跳转到最后一页
发表新帖
wscl1213
中级会员
关注
49
主题
226
帖子
4
粉丝
TA的主题
hadoop2 运行报错 Unable to close file because the last block does not have en...
2016-2-25
CDH集群部署手册
2016-1-24
让cloudera manager装的spark支持hql【分享】
2016-1-12
基于粗糙集理论的数据挖掘模型
2016-1-10
数据挖掘模型-Models_of_DM
2016-1-10
24小时热文
矩阵分析引论罗家洪(第四版)
互联网大厂年终福利曝光:看看别人家老板怎
像高手一样发言:七种常见工作场景的说话之
携程允许员工春节回乡办公2个月
数据治理实施方案
关闭
推荐
/2
中文版ChatGPT
1.无需魔法 2.提高编程效率 3.提高文档能力
查看 »
新手帮助
新手帮助:注册遇到问题,领取资源,加入铁粉群,不会使用搜索,如何获取积分等
查看 »
意见
反馈