當前位置:首頁 » 安卓系統 » android重啟代碼

android重啟代碼

發布時間: 2022-12-08 10:23:27

『壹』 Android如何通過代碼重啟應用程序

樓上的方法是重啟activity,不過也只能這樣,代碼是在應用程序內部執行的,應用程序都關了,還怎麼運行重啟的代碼,你還是慢慢自己微調,達到類似重啟的效果吧

『貳』 如何通過代碼重啟Android設備

1.用runtime來實現,即:

java">try
{
Runtime.getRuntime().exec("su");
Runtime.getRuntime().exec("reboot");
}
catch(IOExceptione)
{}

2.Powermanger

PowerManagerpm=(PowerManager)getApplicationContext().getSystemService(Context.POWER_SERVICE);
pm.reboot(null);

以上需要系統root許可權,adb push xxx.apk system/app安裝,一定要在這個目錄下才能成為系統應用,來獲取更大的操作許可權

『叄』 android 如何讓service被管理器殺死後自動重啟

在ondestory生命周期裡面 startService,這樣他就永遠干不掉該service了。一被銷毀就重啟

『肆』 android 關機重啟流程

https://developer.android.com/intl/zh-CN/reference/android/os/PowerManager.html

在PowerManager的API文檔中,給出了一個關機/重啟介面:
public void reboot (String reason)
對於這個介面的描述很簡單,就是幾句話。
介面的作用就是重啟設備,而且,就算重啟成功了也沒有返回值。
需要包含REBOOT許可權,也就是android.permission.REBOOT
唯一參數reason代表需要的特定重啟模式,比如recovery,當然也可以為null。

1.frameworks/base/core/java/android/os/PowerManager.java
2.frameworks/base/core/java/android/os/IPowerManager.aidl
3.frameworks/base/services/java/com/android/server/PowerManagerService.java
4.frameworks/base/services/java/com/android/server/pm/ShutdownThread.java
5.frameworks/base/services/jni/com_android_server_PowerManagerService.cpp
---------------------》
6.system/core/libcutils/android_reboot.c
7.bionic/libc/unistd/reboot.c

8.__reboot通過syscall來到內核
9.kernel/sys.c

frameworks/base/core/java/android/os/PowerManager.java

mService為IPowerManager Binder介面服務。

frameworks/base/core/java/android/os/IPowerManager.aidl

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

frameworks/base/services/java/com/android/server/pm/ShutdownThread.java

這里說明是需要重啟,且不是安全模式,重啟參數為傳遞下來的reason,shutdownInner的confirm參數是用來設置是否有確認提示框的,通過reboot介面調用重啟是沒有的,為false。

重啟的實現在run()中,因為ShutdownThread是Thread的擴展,所以run會自動運行。
frameworks/base/services/java/com/android/server/pm/ShutdownThread.java

在重啟前會將重啟原因寫入sys.shutdown.requested,如果沒有則為空,如果是安全模式還會將persist.sys.safemode置1,之後會進行一些關機前的預處理,關閉ActivityManager以及MountService,最終調用rebootOrShutdown進行關機操作。

如果確認重啟,則調用PowerManagerService的lowLevelReboot函數,參數就是傳遞下來的reason,稍後分析。如果不是重啟,即mReboot=false,那就是需要關機了,在shutdown函數中就能夠知道。

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

frameworks/base/services/jni/com_android_server_PowerManagerService.cpp

可以看到無論是關機還是重啟,都是調用android_reboot來實現的,只是參數不一樣而已。

system/core/libcutils/android_reboot.c

以reboot recovery為例,arg即為recovery,所在在第五步的時候會傳入ANDROID_RB_RESTART2。到了android_reboot函數中,會看到這樣的定義#ifdef RECOVERY_PRE_COMMAND,即屬於重啟前會執行的命令,如果定義了就會執行。

下面也是做了一些關機重啟前的預處理工作,sync()作用是將緩存中的信息寫入磁碟,以免程序異常結束導致文件被損壞,linux系統關機前會做幾次這樣的動作;而remount_ro()作用是通過調用emergency_remount()強制將文件系統掛載為只讀,不再允許任何寫入操作,同時會通過檢查/proc/mounts的設備狀態來確認是否當前的所有寫入工作已經完成,這個檢查過程是阻塞操作。

接下來才是對參數的解析處理:

1)普通重啟 ANDROID_RB_RESTART, reason = RB_AUTOBOOT;

2)關機 ANDROID_RB_POWEROFF, 無需reason,直接調用reboot進行關機;

3)帶參數的特殊重啟 ANDROID_RB_RESTART2, reason 將為默認值 -1

這里又出現一個#ifdef RECOVERY_PRE_COMMAND_CLEAR_REASON,如果定義了它,則無論上層傳下來的參數是什麼樣的,最終都只是普通重啟而已。定義它的方式是在BoardConfig.mk中加入TARGET_RECOVERY_PRE_COMMAND_CLEAR_REASON := true,應該有廠商會喜歡這么做的,畢竟除了普通重啟,都可能帶給用戶一定的風險。

最後會對reason進行一個檢測,那麼通過上邊的分析,其實只有帶參數的特殊重啟才會為-1,而不等於-1的情況中有普通重啟和關機,而關機已經自行解決了……所以,不等於-1的情況到了這里也只有普通重啟了。最終這里就是區分普通重啟與特殊重啟的地方了。這里再插入一個問題,其他的幾個cmd都是什麼值呢?答案在bionic/libc/include/sys/reboot.h中:

reboot(reason) -> reboot(RB_AUTOBOOT) -> __reboot( LINUX_REBOOT_MAGIC1, LINUX_REBOOT_MAGIC2, LINUX_REBOOT_CMD_RESTART, NULL )
__reboot通過syscall來到內核bionic/libc/arch-arm/syscalls/__reboot.S

其被指定了一個固定的偏移量,在被調用的時候就是通過這個偏移量去內核中尋找對應的入口的,由此可見,內核中一定有著相同的定義,否則將不能成功調用。內核中對syscall偏移量的定義在內核源碼中的arch/arm/include/asm/unistd.h,相關信息完全一致。

已經找到了內核中的對應映射,那麼下一步就要去找尋真正的實現函數了,在include/asm-generic/unistd.h中可以找到內核對__NR_reboot的syscall函數映射,即

同時,能夠發現如此溫馨的一幕,內核已經指引我們下一步該去哪裡尋找sys_reboot,即kernel/sys.c。

include/linux/syscalls.h

與__reboot的調用參數一致。

進入sys.c文件後,並沒有找到名為sys_reboot的函數,而通過仔細查找,發現一個很有趣的函數,其定義為SYSCALL_DEFINE4(reboot, int, magic1, int, magic2, unsigned int, cmd, void __user *, arg),對比__reboot的參數,能夠符合。究竟是不是這個函數?

同樣在include/linux/syscalls.h文件中,能夠找到這樣幾個定義:

而pm_power_off為空的話,就把用戶的關機命令轉換為掛起:
arch/arm/kernel/process.c

pm_power_off = msm_pm_power_off;

SYSCALL_DEFINE4(reboot, int, magic1, int, magic2, unsigned int, cmd, void __user *, arg)
這個過程是用reboot_mutex互斥鎖來進行保護的,以保證同一時間只可能有一個解析過程,避免沖突。

bionic/libc/include/sys/reboot.h 中可以看到android定義的啟動方式
RESTART
POWER_OFF
RESTART2

對框架進行賦值,qcom 平台 845上已經不是這函數,自己查找
arm_pm_restart = msm_pm_restart;

下面是qcom 實現,每個平台不同

可以在跟蹤這個流程的過程中會發現,確實是有存在關機的相關介面的。那麼關機該怎麼用呢?
frameworks/base/services/java/com/android/serverBatteryService.java

重啟方式: 最後就是設定寄存器,Uboot 解析不同寄存器的值進入不同的啟動模式

recovery 如果傳下來的字元串是recovery那麼,就在RTC寄存器里設置某個特定值,當uboot里讀取RTC寄存器的時候如果獲取了這個特定值,那就可以起recovery這個動作了。

Ref: https://blog.csdn.net/leerobin83/article/details/7162751

上面主要講到流程,在實際開發中, 主動調用系統開機關機如何做
(Ref: https://blog.csdn.net/luzhenrong45/article/details/42092007 )
一. 發送系統廣播方式
二. 通過init.rc啟動系統服務來運行sh文件
三. Runtime調用Linux-shell
四 . PowerManager reboot以及反射調用PowerManagerService shutdown
五.使用ShutdownThread (嘗試不成功,但想法覺得可行)

Intent.java位於源碼/frameworks/base/core/java/android/content/Intent.java下面

腳本方式,實際都是基於指令的

使用PowerManager 或ShutdownThread 都是基於關機流程

熱點內容
用友軟體sql 發布:2024-04-20 20:10:01 瀏覽:932
python倒著循環 發布:2024-04-20 20:09:52 瀏覽:758
雲伺服器遠程電腦版 發布:2024-04-20 20:09:12 瀏覽:258
ps資料庫 發布:2024-04-20 19:52:43 瀏覽:521
dpi的演算法 發布:2024-04-20 19:41:16 瀏覽:933
成興ca鎖密碼初始密碼是什麼 發布:2024-04-20 19:24:43 瀏覽:667
如何更准確的看手機配置 發布:2024-04-20 19:15:12 瀏覽:332
匯優的演算法 發布:2024-04-20 19:10:51 瀏覽:414
和平精英暗夜危機模式密碼是什麼 發布:2024-04-20 19:10:03 瀏覽:686
韓國泡泡安卓怎麼充值 發布:2024-04-20 18:56:27 瀏覽:295