欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

android啟動程序,android程序啟動流程

Android 啟動后臺運行程序(Service)

Android開發(fā)中,當需要創(chuàng)建在后臺運行的程序的時候,就要使用到Service。Service 可以分為有無限生命和有限生命兩種。特別需要注意的是Service跟Activities是不同的(簡單來說可以理解為后臺與前臺的區(qū)別),例如,如果需要使用Service的話,需要調(diào)用startService(),從而利用startService()去調(diào)用Service中的OnCreate()和onStart()方法來啟動一個后臺的Service。 啟動一個Service的過程如下:context.startService() -onCreate()- onStart()-Service running其中onCreate()可以進行一些服務的初始化工作,onStart()則啟動服務。 停止一個Service的過程如下:context.stopService() | -onDestroy() -Service stop 接下來的實例是一個利用后臺服務播放音樂的小例子,點擊start運行服務,點擊stop停止服務。ServicesDemo.java(是一個Activity)

創(chuàng)新互聯(lián)建站擁有網(wǎng)站維護技術和項目管理團隊,建立的售前、實施和售后服務體系,為客戶提供定制化的成都網(wǎng)站設計、網(wǎng)站制作、網(wǎng)站維護、西部信息中心解決方案。為客戶網(wǎng)站安全和日常運維提供整體管家式外包優(yōu)質(zhì)服務。我們的網(wǎng)站維護服務覆蓋集團企業(yè)、上市公司、外企網(wǎng)站、購物商城網(wǎng)站建設、政府網(wǎng)站等各類型客戶群體,為全球千余家企業(yè)提供全方位網(wǎng)站維護、服務器維護解決方案。

package com.android.myservice;

import android.app.Activity;

import android.content.Intent;

import android.os.Bundle;

import android.util.Log;

import android.view.View;

import android.view.View.OnClickListener;

import android.widget.Button;

public class ServiceDemo extends Activity implements OnClickListener {

private static final String TAG = "ServiceDemo";

Button buttonStart, buttonStop;

}

除此之外還要在Manifest里面聲明服務:

?xml version="1.0" encoding="utf-8"?

manifest xmlns:android=" "

package="com.android.myservice"

application android:label="@string/app_name"

activity android:name=".ServiceDemo" android:label="@string/app_name"

intent-filter

action android:name="android.intent.action.MAIN"/

category android:name="android.intent.category.LAUNCHER"/

/intent-filter

/activity

service android:enabled="true" android:name=".MyService"/

/application

/manifest

定義Service(MyService.java

package com.android.myservice;

import android.app.Service;

import android.content.Intent;

import android.media.MediaPlayer;

import android.os.IBinder;

import android.util.Log;

import android.widget.Toast;

public class MyService extends Service {

private static final String TAG = "MyService";

MediaPlayer player;

}

layout文件夾中是main.xml

?xml version="1.0" encoding="utf-8"?

LinearLayout xmlns:android=" "

android:orientation="vertical"

android:layout_width="fill_parent"

android:layout_height="fill_parent"

android:gravity="center"

TextView

android:layout_width="fill_parent"

android:layout_height="wrap_content" android:text="@string/services_demo" android:gravity="center" android:textSize="20sp" android:padding="20dp"/

Button android:layout_width="wrap_content" android:layout_height="wrap_content" android:id="@+id/buttonStart" android:text="@string/start"/Button

Button android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="@string/stop" android:id="@+id/buttonStop"/Button

/LinearLayout

values 文件夾中是strings.xml

?xml version="1.0" encoding="utf-8"?

resources

string name="start"Start/string

string name="stop"Stop/string

string name="services_demo"Service Demo/string

/resources

Android 啟動流程

makeApplication創(chuàng)建application中會執(zhí)行attachBaseContext(context);

installContentProviders第一個參數(shù)context,是從上面?zhèn)鬟f下來的app,也就是application。

遍歷providers列表,初始化每一個provider,都是用application的context。構造出ContentProvider然后執(zhí)行attachInfo() 方法,attachInfo()執(zhí)行完畢會執(zhí)行onCreate()。

最后再mInstrumentation.callApplicationOnCreate(app);執(zhí)行Application的OnCreate方法。

總結

從流程上來看,符合日志打印的流程Application#attachBaseContext() → ContentProvider#attachInfo() → ContentProvider#onCreate() → Application#onCreate()

ContentProvider持有的Context也是application,具備給SDK初始化使用。

這時候第一進程是zygote。zygote英文是受精卵的意思。android系統(tǒng)的所有進程都是由zygote進程fork而來。zygote最先啟動的第一個進程是鼎鼎大名的SystemServer進程。這個進程包含了我們常說的三個大神級系統(tǒng)服務,分別是ActivityManagerService,WindowManagerService以及PackegeManagerService。

進程入口在ActivityThread這個類的main()方法,這個main方法類似C語言的mian方法,是一個程序入口。

這個方法會接著調(diào)用ActivityManagerNatvie(一個單例類,可以獲取ActivityManagerService的實例)的getDeafault()返回ActivityManagerService實例。

ApplicationThread是ActivityThread的內(nèi)部類,他是App和系統(tǒng)跨進程交互的入口,它的實現(xiàn)類在客戶端進程。

獲得了正在Binder通信的客戶端的當前線程的id,然后和ApplicationThread對象作為參數(shù)傳入到AMS的attachApplicationLocked。

thread是ApplicationThreadProxy的對象引用,它是代理對象,先調(diào)用ApplicationThreadProxy的bindApplication方法,接著在這個方法中又調(diào)用ApplicationThreadNative的函數(shù)onTransact,然后函數(shù)onTransact中根據(jù)code找到對應的case,最終會調(diào)用ApplicationThread的bindApplication方法。

在這里,bindApplication方法通過向ActivityThread的消息隊列發(fā)送BIND_APPLICATION消息

消息的處理調(diào)用handleBindApplication方法,handleBindApplication方法比較重要的是會調(diào)用如下方法

在執(zhí)行完bindApplication()之后進入ActivityStackSupervisor.attachApplicationLocked(),這樣我們整個應用進程已經(jīng)啟動起來了。開始activity的啟動邏輯了。

這個類是一個AMS的一個棧管理類,里面存儲著ActivityStack的集合。在這個方法,會遍歷各個ActivityStack,找到前臺棧,找到里面的TopActivity。然后比較 傳進來的ProcessRecord.processName和UID是否個和opActivity對用的ActivityRecord里面的一致。如果一致,就調(diào)用ActivityStackSupervisor.realStartAcvitiyLocked(ProcessRecord,ActivityRecord)方法。

這個方法會調(diào)用傳過來的ApplicationThread實例的ScheduelLaunchActivity(包括ActivityRecord)方法,所以真正執(zhí)行的是ActivityThread中的scheduleLaunchActivity

這個方法是跨進程的,會把ActivityRecord同步到App進程的ActivityRecordClient數(shù)據(jù)結構,用來后面構造Application和Activity等。

ActivityThread接收到SystemServer進程的消息之后會通過其內(nèi)部的Handler對象分發(fā)消息,經(jīng)過一系列的分發(fā)之后調(diào)用了ActivityThread的handleLaunchActivity方法:

接著調(diào)用PerformLaunchActivity方法和HandleLaunchActivtiy()方法。performLauncherActivity,看名字應該就是執(zhí)行Activity的啟動操作了

1.這個方法主要是構造Application和通過mInstrumention.newActivity()構造Activity。

這個方法會初始化一個Window,以后詳細講,人格視圖都是附在一個window的docorView上,然后由WMS.addView顯示。

這個方法會調(diào)用Actiity的resume()方法,并且在makrVisible()里面調(diào)用WMS.addView(window),這個windows里面的docorView的contentView就是onCreate()里面setContentView(int layout)設置的contentView。

注意關于WMS.addView(window),這個系統(tǒng)服務,我們下次再講,里面有一個類RootViewImpl,這個類負責管理我們contentView視圖樹的逐級繪制。

原文鏈接

Android啟動過程深入解析

當按下Android設備電源鍵時究竟發(fā)生了什么?

Android的啟動過程是怎么樣的?

什么是Linux內(nèi)核?

桌面系統(tǒng)linux內(nèi)核與Android系統(tǒng)linux內(nèi)核有什么區(qū)別?

什么是引導裝載程序?

什么是Zygote?

什么是X86以及ARM linux?

什么是init.rc?

什么是系統(tǒng)服務?

當我們想到Android啟動過程時,腦海中總是冒出很多疑問。本文將介紹Android的啟動過程,希望能幫助你找到上面這些問題的答案。

Android是一個基于Linux的開源操作系統(tǒng)。x86(x86是一系列的基于intel 8086 CPU的計算機微處理器指令集架構)是linux內(nèi)核部署最常見的系統(tǒng)。然而,所有的Android設備都是運行在ARM處理器(ARM 源自進階精簡指令集機器,源自ARM架構)上,除了英特爾的Xolo設備()。Xolo來源自凌動1.6GHz x86處理器。Android設備或者嵌入設備或者基于linux的ARM設備的啟動過程與桌面版本相比稍微有些差別。這篇文章中,我將解釋Android設備的啟動過程。深入linux啟動過程是一篇講桌面linux啟動過程的好文。

當你按下電源開關后Android設備執(zhí)行了以下步驟。

此處圖片中step2中的一個單詞拼寫錯了,Boot Loaeder應該為Boot Loader(多謝@jameslast 提醒)

第一步:啟動電源以及系統(tǒng)啟動

當電源按下,引導芯片代碼開始從預定義的地方(固化在ROM)開始執(zhí)行。加載引導程序到RAM,然后執(zhí)行。

第二步:引導程序

引導程序是在Android操作系統(tǒng)開始運行前的一個小程序。引導程序是運行的第一個程序,因此它是針對特定的主板與芯片的。設備制造商要么使用很受歡迎的引導程序比如redboot、uboot、qi bootloader或者開發(fā)自己的引導程序,它不是Android操作系統(tǒng)的一部分。引導程序是OEM廠商或者運營商加鎖和限制的地方。

引導程序分兩個階段執(zhí)行。第一個階段,檢測外部的RAM以及加載對第二階段有用的程序;第二階段,引導程序設置網(wǎng)絡、內(nèi)存等等。這些對于運行內(nèi)核是必要的,為了達到特殊的目標,引導程序可以根據(jù)配置參數(shù)或者輸入數(shù)據(jù)設置內(nèi)核。

Android引導程序可以在bootablebootloaderlegacyusbloader找到。

傳統(tǒng)的加載器包含的個文件,需要在這里說明:

init.s初始化堆棧,清零BBS段,調(diào)用main.c的_main()函數(shù);

main.c初始化硬件(鬧鐘、主板、鍵盤、控制臺),創(chuàng)建linux標簽。

更多關于Android引導程序的可以在這里了解。

第三步:內(nèi)核

Android內(nèi)核與桌面linux內(nèi)核啟動的方式差不多。內(nèi)核啟動時,設置緩存、被保護存儲器、計劃列表,加載驅(qū)動。當內(nèi)核完成系統(tǒng)設置,它首先在系統(tǒng)文件中尋找”init”文件,然后啟動root進程或者系統(tǒng)的第一個進程。

第四步:init進程

init是第一個進程,我們可以說它是root進程或者說有進程的父進程。init進程有兩個責任,一是掛載目錄,比如/sys、/dev、/proc,二是運行init.rc腳本。

init進程可以在/system/core/init找到。

init.rc文件可以在/system/core/rootdir/init.rc找到。

readme.txt可以在/system/core/init/readme.txt找到。

對于init.rc文件,Android中有特定的格式以及規(guī)則。在Android中,我們叫做Android初始化語言。

Action(動作):動作是以命令流程命名的,有一個觸發(fā)器決定動作是否發(fā)生。

語法

1

2

3

4

5

; html-script: false ]

on trigger

command

command

command

Service(服務):服務是init進程啟動的程序、當服務退出時init進程會視情況重啟服務。

語法

1

2

3

4

5

; html-script: false ]

service name pathname [argument]*

option

option

...

Options(選項)

選項是對服務的描述。它們影響init進程如何以及何時啟動服務。

咱們來看看默認的init.rc文件。這里我只列出了主要的事件以及服務。

Table

Action/Service

描述

on early-init

設置init進程以及它創(chuàng)建的子進程的優(yōu)先級,設置init進程的安全環(huán)境

on init

設置全局環(huán)境,為cpu accounting創(chuàng)建cgroup(資源控制)掛載點

on fs

掛載mtd分區(qū)

on post-fs

改變系統(tǒng)目錄的訪問權限

on post-fs-data

改變/data目錄以及它的子目錄的訪問權限

on boot

基本網(wǎng)絡的初始化,內(nèi)存管理等等

service servicemanager

啟動系統(tǒng)管理器管理所有的本地服務,比如位置、音頻、Shared preference等等…

service zygote

啟動zygote作為應用進程

在這個階段你可以在設備的屏幕上看到“Android”logo了。

第五步

在Java中,我們知道不同的虛擬機實例會為不同的應用分配不同的內(nèi)存。假如Android應用應該盡可能快地啟動,但如果Android系統(tǒng)為每一個應用啟動不同的Dalvik虛擬機實例,就會消耗大量的內(nèi)存以及時間。因此,為了克服這個問題,Android系統(tǒng)創(chuàng)造了”Zygote”。Zygote讓Dalvik虛擬機共享代碼、低內(nèi)存占用以及最小的啟動時間成為可能。Zygote是一個虛擬器進程,正如我們在前一個步驟所說的在系統(tǒng)引導的時候啟動。Zygote預加載以及初始化核心庫類。通常,這些核心類一般是只讀的,也是Android SDK或者核心框架的一部分。在Java虛擬機中,每一個實例都有它自己的核心庫類文件和堆對象的拷貝。

Zygote加載進程

加載ZygoteInit類,源代碼:/frameworks/base/core/java/com/android/internal/os/ZygoteInit.java

registerZygoteSocket()為zygote命令連接注冊一個服務器套接字。

preloadClassed “preloaded-classes”是一個簡單的包含一系列需要預加載類的文本文件,你可以在/frameworks/base找到“preloaded-classes”文件。

preloadResources() preloadResources也意味著本地主題、布局以及android.R文件中包含的所有東西都會用這個方法加載。

在這個階段,你可以看到啟動動畫。

第六步:系統(tǒng)服務或服務

完成了上面幾步之后,運行環(huán)境請求Zygote運行系統(tǒng)服務。系統(tǒng)服務同時使用native以及java編寫,系統(tǒng)服務可以認為是一個進程。同一個系統(tǒng)服務在Android SDK可以以System Services形式獲得。系統(tǒng)服務包含了所有的System Services。

Zygote創(chuàng)建新的進程去啟動系統(tǒng)服務。你可以在ZygoteInit類的”startSystemServer”方法中找到源代碼。

核心服務:

啟動電源管理器;

創(chuàng)建Activity管理器;

啟動電話注冊;

啟動包管理器;

設置Activity管理服務為系統(tǒng)進程;

啟動上下文管理器;

啟動系統(tǒng)Context Providers;

啟動電池服務;

啟動定時管理器;

啟動傳感服務;

啟動窗口管理器;

啟動藍牙服務;

啟動掛載服務。

其他服務:

啟動狀態(tài)欄服務;

啟動硬件服務;

啟動網(wǎng)絡狀態(tài)服務;

啟動網(wǎng)絡連接服務;

啟動通知管理器;

啟動設備存儲監(jiān)視服務;

啟動定位管理器;

啟動搜索服務;

啟動剪切板服務;

啟動登記服務;

啟動壁紙服務;

啟動音頻服務;

啟動耳機監(jiān)聽;

啟動AdbSettingsObserver(處理adb命令)。

第七步:引導完成

一旦系統(tǒng)服務在內(nèi)存中跑起來了,Android就完成了引導過程。在這個時候“ACTION_BOOT_COMPLETED”開機啟動廣播就會發(fā)出去。

Android應用程序啟動流程總結

AMS主要功能:

AMS是Android中最核心的服務,主要負責系統(tǒng)中四大組件的啟動、切換、調(diào)度及應用進程的管理和調(diào)度等工作。還負責啟動或殺死應用程序的進程。

WMS主要功能:

為所有窗口分配Surface。

管理Surface的顯示順序、尺寸、位置。

管理窗口動畫。

輸入系統(tǒng)相關:WMS是派發(fā)系統(tǒng)按鍵和觸摸消息的最佳人選,當接收到一個觸摸事件,它需要尋找一個最合適的窗口來處理消息。

PWS主要功能:

PMS 用來管理跟蹤所有應用APK,包括安裝,卸載,解析,控制權限等。

SystemServer也是一個進程,包括AMS、PMS、WMS等等。

zygote意為“受精卵“。Android是基于Linux系統(tǒng)的,而在Linux中,所有的進程都是由init進程直接或者是間接fork出來的,zygote進程也不例外。

App進程是用戶點擊桌面icon時,通過Launcher進程請求SystemServer,再調(diào)用Zygote孵化的。

①點擊啟動一個App,Launcher進程采用Binder IPC向ActivityManagerService發(fā)起startActivity請求;

②ActivityManagerService接收到請求后,向zygote進程發(fā)送創(chuàng)建進程的請求;

③Zygote進程fork出新的子進程,即App進程;

④App進程通過Binder IPC向sytem_server進程發(fā)起綁定Application請求;

⑤system_server進程在收到請求后,進行一系列準備工作后,再通過binder IPC向App進程發(fā)送scheduleLaunchActivity請求;

⑥App進程的binder線程(ApplicationThread)在收到請求后,通過handler向主線程發(fā)送LAUNCH_ACTIVITY消息;

⑦主線程在收到Message后,通過發(fā)射機制創(chuàng)建目標Activity,并回調(diào)Activity.onCreate()等方法。

⑧到此,App便正式啟動,開始進入Activity生命周期,執(zhí)行完onCreate/onStart/onResume方法,UI渲染結束后便可以看到App的主界面。

備注:

Launcher,PMS,Zygote,App進程是三個獨立的進程,相互通信就需要使用進程間通信機制。與Zygote通信是使用的socket通信,Launcher,PMS,App進程間使用的是Binder機制。

當前標題:android啟動程序,android程序啟動流程
分享路徑:http://chinadenli.net/article24/dsgcpce.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供自適應網(wǎng)站微信小程序網(wǎng)站設計網(wǎng)站維護網(wǎng)站收錄

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站建設網(wǎng)站維護公司