2024年Android Framework system_server进程启动,面试复盘总结怎么写

最后为了帮助大家深刻理解Android相关知识点的原理以及面试相关知识,这里放上相关的我搜集整理的24套腾讯、字节跳动、阿里、百度2020-2021面试真题解析,我把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包知识脉络 + 诸多细节

还有 高级架构技术进阶脑图、Android开发面试专题资料 帮助大家学习提升进阶,也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习。

一线互联网面试专题

379页的Android进阶知识大全

379页的Android进阶知识大全

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

:/apex/com.android.adservices/javalib/service- sdksandbox.jar
:/apex/com.android.appsearch/javalib/service-appsearch.jar
:/apex/com.android.art/javalib/service-art.jar
:/apex/com.android.media/javalib/service-media-s.jar
:/apex/com.android.permission/javalib/service-permission.jar*/

if (systemServerClasspath != null) { //刚刚进行了搜索这里不会空
    // Capturing profiles is only supported for debug or eng builds since selinux normally
    // prevents it.
    if (shouldProfileSystemServer() && (Build.IS_USERDEBUG || Build.IS_ENG)) {//这里为false adb shell getprop SYSTEMSERVERCLASSPATH
        try {
            Log.d(TAG, "Preparing system server profile");
            prepareSystemServerProfile(systemServerClasspath);//这个方法根据 : 获取每一个jar包的路径然后进行加载
        } catch (Exception e) {
            Log.wtf(TAG, "Failed to set up system server profile", e);
        }
    }
}

if (parsedArgs.mInvokeWith != null) {//这里跟了一下代码就是看看有没有设置参数--invoke-with 发现没有就执行 else
    String[] args = parsedArgs.mRemainingArgs;
    // If we have a non-null system server class path, we'll have to duplicate the
    // existing arguments and append the classpath to it. ART will handle the classpath
    // correctly when we exec a new process.
    if (systemServerClasspath != null) {
        String[] amendedArgs = new String[args.length + 2];
        amendedArgs[0] = "-cp";
        amendedArgs[1] = systemServerClasspath;
        System.arraycopy(args, 0, amendedArgs, 2, args.length);
        args = amendedArgs;
    }

    WrapperInit.execApplication(parsedArgs.mInvokeWith,
            parsedArgs.mNiceName, parsedArgs.mTargetSdkVersion,
            VMRuntime.getCurrentInstructionSet(), null, args);

    throw new IllegalStateException("Unexpected return from WrapperInit.execApplication");
} else {

    ClassLoader cl = getOrCreateSystemServerClassLoader();//创建SYSTEMSERVERPATHCLASS的classloader 但这里为空就不走这个方法了
    if (cl != null) {
        Thread.currentThread().setContextClassLoader(cl);
    }

    /*
     * Pass the remaining arguments to SystemServer.
     */
    return ZygoteInit.zygoteInit(parsedArgs.mTargetSdkVersion,
            parsedArgs.mDisabledCompatChanges,
            parsedArgs.mRemainingArgs, cl);
}

/* should never reach here */

}


**接下来走到了ZygoteInit.zygoteInit。**


--javascripttypescriptbashsqljsonhtmlcssccppjavarubypythongorustmarkdown



public static Runnable zygoteInit(int targetSdkVersion, long[] disabledCompatChanges,
String[] argv, ClassLoader classLoader) {
if (RuntimeInit.DEBUG) {
Slog.d(RuntimeInit.TAG, “RuntimeInit: Starting application from zygote”);
}

Trace.traceBegin(Trace.TRACE_TAG_ACTIVITY_MANAGER, "ZygoteInit");
RuntimeInit.redirectLogStreams();

//配置一些公共的初始化比如log之类的
RuntimeInit.commonInit();
//这里调用了一个native 方法 其实就是启动了一个binder,AndroidRuntime.cpp#com_android_internal_os_ZygoteInit_nativeZygoteInit–》app_main#onZygoteInit
ZygoteInit.nativeZygoteInit();
return RuntimeInit.applicationInit(targetSdkVersion, disabledCompatChanges, argv,
classLoader);
}


**然后查看applicationInit**


--javascripttypescriptbashsqljsonhtmlcssccppjavarubypythongorustmarkdown



protected static Runnable applicationInit(int targetSdkVersion, long[] disabledCompatChanges,
String[] argv, ClassLoader classLoader) {
// If the application calls System.exit(), terminate the process
// immediately without running any shutdown hooks. It is not possible to
// shutdown an Android application gracefully. Among other things, the
// Android runtime shutdown hooks close the Binder driver, which can cause
// leftover running threads to crash before the process actually exits.
nativeSetExitWithoutCleanup(true);

VMRuntime.getRuntime().setTargetSdkVersion(targetSdkVersion);
VMRuntime.getRuntime().setDisabledCompatChanges(disabledCompatChanges);

final Arguments args = new Arguments(argv);

// The end of of the RuntimeInit event (see #zygoteInit).
Trace.traceEnd(Trace.TRACE_TAG_ACTIVITY_MANAGER);

// Remaining arguments are passed to the start class's static main
//主要是这个方法 找到类的main方法 进行调用使用的反射调用
return findStaticMain(args.startClass, args.startArgs, classLoader);

}


**目前为止zygote孵化进程后的流程已经走完了,等于是返回了某个类的main方法,那么传递的是哪个类的main呢?**


这里可以看到是args.startClass


--javascripttypescriptbashsqljsonhtmlcssccppjavarubypythongorustmarkdown



findStaticMain(args.startClass, args.startArgs, classLoader);


**在Runnable forkSystemServer(String abiList, String socketName,ZygoteServer zygoteServer) 就设置了 com.android.server.SystemServer**


**接下来根据代码我们进入com.android.server.SystemServer的main方法,我们看到这里是启动一个线程**


--javascripttypescriptbashsqljsonhtmlcssccppjavarubypythongorustmarkdown



public static void main(String[] args) {
new SystemServer().run();
}


--javascripttypescriptbashsqljsonhtmlcssccppjavarubypythongorustmarkdown



private void run() {
TimingsTraceAndSlog t = new TimingsTraceAndSlog();
try {

//加载一个android_servers.so
System.loadLibrary(“android_servers”);

//创建一个系统的上下文
createSystemContext();

    // Create the system service manager. 创建系统服务的管理者
    mSystemServiceManager = new SystemServiceManager(mSystemContext);
    mSystemServiceManager.setStartInfo(mRuntimeRestart,
            mRuntimeStartElapsedTime, mRuntimeStartUptime);
    mDumper.addDumpable(mSystemServiceManager);

    LocalServices.addService(SystemServiceManager.class, mSystemServiceManager);
    // Prepare the thread pool for init tasks that can be parallelized
    SystemServerInitThreadPool tp = SystemServerInitThreadPool.start();
    mDumper.addDumpable(tp);
	.....

// Start services.
//从这里就开始启动各种服务了
try {
    t.traceBegin("StartServices");
	//启动引导服务比如下面的核心服务其他服务有依赖关系的服务
    startBootstrapServices(t);
	//启动核心服务
    startCoreServices(t);
	//启动其他服务
    startOtherServices(t);
	//定义在apexes中的服务apexes,有兴趣的可以看下源码
	/*Apex服务是指Android操作系统中的一种应用程序启动方式,它允许应用程序在设备启动时以系统服务的形式自动运行。这些服务通常包括系统应用、框架服务和系统UI等。它们在设备启动时会自动运行,并为用户提供各种基础功能和界面。

startApexServices方法会遍历所有已安装的Apex服务,并调用它们的启动方法,使它们在系统启动时自动运行。该方法在系统启动过程中被调用,是Android操作系统启动过程中的一部分。/
startApexServices(t);
} catch (Throwable ex) {
Slog.e(“System”, "
*****************************");
Slog.e(“System”, "
Failure starting system services", ex);
throw ex;
} finally {
t.traceEnd(); // StartServices
}

StrictMode.initVmDefaults(null);

if (!mRuntimeRestart && !isFirstBootOrUpgrade()) {
    final long uptimeMillis = SystemClock.elapsedRealtime();
    FrameworkStatsLog.write(FrameworkStatsLog.BOOT_TIME_EVENT_ELAPSED_TIME_REPORTED,
            FrameworkStatsLog.BOOT_TIME_EVENT_ELAPSED_TIME__EVENT__SYSTEM_SERVER_READY,
            uptimeMillis);
    final long maxUptimeMillis = 60 * 1000;
    if (uptimeMillis > maxUptimeMillis) {
        Slog.wtf(SYSTEM_SERVER_TIMING_TAG,
                "SystemServer init took too long. uptimeMillis=" + uptimeMillis);
    }
}

// Loop forever.
Looper.loop();
throw new RuntimeException("Main thread loop unexpectedly exited");

}


最后在启动完各个service后,他还会调用Service的systemReady方法




### 最后

跳槽季整理面试题已经成了我多年的习惯!**在这里我和身边一些朋友特意整理了一份快速进阶为Android高级工程师的系统且全面的学习资料。涵盖了Android初级——Android高级架构师进阶必备的一些学习技能。**

附上:我们之前因为秋招收集的二十套一二线互联网公司Android面试真题(含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)

![](https://img-blog.csdnimg.cn/img_convert/ab95181ac2c76ac2e0f7780589d9071b.webp?x-oss-process=image/format,png)




**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化学习资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618156601)**

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

76772)]




**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化学习资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618156601)**

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值