1.SystemServer.java

SystemServer作为Android核心组件,负责启动和管理几乎所有系统服务。从Zygote进程创建system_server,是Android系统运行的基础。SystemServer中初始化大部分服务,通过SystemServiceManager加入ServiceManager管理,确保系统稳定运行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

frameworks/base/services/java/com/android/server

System Server是android 基本服务的提供者,是android系统运行的最基本需求,所有service运行在一个叫system_server的进程中,system_server进程是android java虚拟机跑的第一个进程,从Zygote 创建而来,是andorid系统最重要的java虚拟机。可以说,整个android系统的业务都是围绕system server而展开,所以,当system_server死掉了,手机必须重启。

从Zygote创建system_server进程时,便实例化了该类

因此在android的启动过程中位于zygote之后。android的所有服务循环都是建立在 SystemServer之上的。在SystemServer中,将可以看到它建立了android中的大部分服务,并通过ServerManager的add_service方法把这些服务加入到了ServiceManager的svclist中。从而完成ServcieManager对服务的管理。

public static void main(String[] args){
    new SystemServer.run();
}
private void run(){
    try{
        //run方法将会对整个系统的Service做初始化,搭建完运行时环境和上下文
        //创建消息队列,家在native lib库
        Looper.prepareMainLooper();
        System.loadLibrary("android_servers");
        performPendingShutdown();

        //创建ActivityThread初始化系统context
        createSystemContext();

        //创建SystemServiceManager负责创建启动管理系统服务
        mSystemServiceManager = new SystemServiceManager(mSystemContext);
        //创建系统服务管理者并添加到本地服务
        mSystemServiceManager.setStartInfo(mRuntimeRestart);
        LocalServices.addService(SystemServiceManager.class, mSystemServiceManager);
        SystemServerInitThreadPool.get();
... ...

try{
    
}

}

android.os.trace:

android.os.SystemProperties:设置或取得系统属性

    android属性值是以键值对的形式存在的,一般放在system.prop,build.prop,default.prop等

    SystemProperties.get("ro.android.myprop")可返回属性对应的key

private void createSystemContext(){
    ActivityThread activityThread = ActivityThread.systemMain();//得到ActivityThread对象
    mSystemContext = activityThread.getSystemContext();

    mSystemContext.setTheme(DEFAULT_SYSTEM_THEME);
    final Context systemUiContext = activityThread.getSystemUiCOntext();
    systemUiContrext.setTheme(DEFAULT_SYSTEM_THEME);
}

android.app.ActivityThread

 

 

 

06-26 09:47:06.997 1251 1251 E AndroidRuntime: *** FATAL EXCEPTION IN SYSTEM PROCESS: main 06-26 09:47:06.997 1251 1251 E AndroidRuntime: java.lang.IllegalStateException: Signature|privileged permissions not in privileged permission allowlist: {com.telcelam.lockscreen (/system/priv-app/realme/MXSiprogo): android.permission.REAL_GET_TASKS, com.dti.amx (/system/priv-app/realme/TelcelDT): android.permission.SCHEDULE_EXACT_ALARM} 06-26 09:47:06.997 1251 1251 E AndroidRuntime: at com.android.server.permission.access.permission.AppIdPermissionPolicy.onSystemReady(AppIdPermissionPolicy.kt:1634) 06-26 09:47:06.997 1251 1251 E AndroidRuntime: at com.android.server.permission.access.AccessPolicy.onSystemReady(AccessPolicy.kt:275) 06-26 09:47:06.997 1251 1251 E AndroidRuntime: at com.android.server.permission.access.AccessCheckingService.onSystemReady$frameworks__base__services__permission__android_common__services_permission_pre_jarjar(AccessCheckingService.kt:239) 06-26 09:47:06.997 1251 1251 E AndroidRuntime: at com.android.server.permission.access.permission.PermissionService.onSystemReady(PermissionService.kt:2295) 06-26 09:47:06.997 1251 1251 E AndroidRuntime: at com.android.server.pm.permission.PermissionManagerService$PermissionManagerServiceInternalImpl.onSystemReady(PermissionManagerService.java:780) 06-26 09:47:06.997 1251 1251 E AndroidRuntime: at com.android.server.pm.PackageManagerService.systemReady(PackageManagerService.java:4702) 06-26 09:47:06.997 1251 1251 E AndroidRuntime: at com.android.server.SystemServer.startOtherServices(SystemServer.java:3157) 06-26 09:47:06.997 1251 1251 E AndroidRuntime: at com.android.server.SystemServer.run(SystemServer.java:1014) 06-26 09:47:06.997 1251 1251 E AndroidRuntime: at com.android.server.SystemServer.main(SystemServer.java:713) 06-26 09:47:06.997 1251 1251 E AndroidRuntime: at java.lang.reflect.Method.invoke(Native Method) 06-26 09:47:06.997 1251 1251 E AndroidRuntime: at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:681) 06-26 09:47:06.997 1251 1251 E AndroidRuntime: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:893)
06-28
anr问题trace如下: "main" prio=5 tid=1 Blocked | group="main" sCount=1 ucsCount=0 flags=1 obj=0x72df6468 self=0xb400007072878c00 | sysTid=3104 nice=-2 cgrp=ssfg sched=0/0 handle=0x71230e9d28 | state=S schedstat=( 273294290029 918944300434 897810 ) utm=18065 stm=9263 core=5 HZ=100 | stack=0x7fe106e000-0x7fe1070000 stackSize=8188KB | held mutexes= at com.android.server.alarm.AlarmManagerService$DeliveryTracker.onSendFinished(AlarmManagerService.java:5798) - waiting to lock <0x09677b19> (a java.lang.Object) held by thread 281 at android.app.PendingIntent$FinishedDispatcher.run(PendingIntent.java:382) at android.os.Handler.handleCallback(Handler.java:973) at android.os.Handler.dispatchMessage(Handler.java:100) at android.os.Looper.loopOnce(Looper.java:282) at android.os.Looper.loop(Looper.java:387) at com.android.server.SystemServer.run(SystemServer.java:1069) at com.android.server.SystemServer.main(SystemServer.java:677) at java.lang.reflect.Method.invoke(Native method) at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:600) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:983) DumpLatencyMs: 212.411 "binder:3104_E" prio=5 tid=281 Runnable | group="main" sCount=0 ucsCount=0 flags=0 obj=0x1770d568 self=0xb400006e2db00800 | sysTid=4606 nice=-2 cgrp=ssfg sched=1073741824/0 handle=0x6e0b1ab730 | state=R schedstat=( 113789554601 690500424244 405734 ) utm=6620 stm=4758 core=5 HZ=100 | stack=0x6e0b0b4000-0x6e0b0b6000 stackSize=989KB | held mutexes= "mutator lock"(shared held) at android.icu.util.Currency.getAvailableCurrencyCodes(Currency.java:200) at libcore.icu.ICU.getCurrencyCode(ICU.java:671) at java.util.Currency.getInstance(Currency.java:421) at java.text.DecimalFormatSymbols.initializeCurrency(DecimalFormatSymbols.java:933) at java.text.DecimalFormatSymbols.setCurrency(DecimalFormatSymbols.java:508) at java.text.DecimalFormatSymbols.fromIcuInstance(DecimalFormatSymbols.java:1085) at java.text.DecimalFormat.getDecimalFormatSymbols(DecimalFormat.java:2819) at java.text.SimpleDateFormat.zeroPaddingNumber(SimpleDateFormat.java:1678) at java.text.SimpleDateFormat.subFormat(SimpleDateFormat.java:1593) at java.text.SimpleDateFormat.format(SimpleDateFormat.java:1117) at java.text.SimpleDateFormat.format(SimpleDateFormat.java:1087) at java.text.DateFormat.format(DateFormat.java:333) at java.text.Format.format(Format.java:159) at com.android.server.alarm.AlarmManagerService.setImplLocked(AlarmManagerService.java:2473) at com.android.server.alarm.AlarmManagerService.setImpl(AlarmManagerService.java:2425) - locked <0x09677b19> (a java.lang.Object) at com.android.server.alarm.AlarmManagerService$4.set(AlarmManagerService.java:3103) at android.app.IAlarmManager$Stub.onTransact(IAlarmManager.java:198) at android.os.Binder.execTransactInternal(Binder.java:1523) at android.os.Binder.execTransact(Binder.java:1457) DumpLatencyMs: 84.4358这最后分析是什么结果呢
最新发布
08-20
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值