本發(fā)明涉及移動終端技術(shù)領(lǐng)域,尤其涉及一種自管理的Android進(jìn)程凍結(jié)和解凍的裝置及方法。
背景技術(shù):
Android手機(jī)可以運(yùn)行任何基于其API(Application Programming Interface,應(yīng)用程序編程接口)開發(fā)的應(yīng)用(APK),這種開放性的自由度很大:一個應(yīng)用可以在后臺根據(jù)它的設(shè)計(jì)者的意愿運(yùn)行—進(jìn)行廣告推送、收集用戶狀態(tài)等,但是這些行為不一定是用戶想要的,反而還會占用CPU、增加功耗、影響用戶體驗(yàn)。進(jìn)程凍結(jié)是一種較好的后臺應(yīng)用管理方式。它識別出對用戶而言沒有必要運(yùn)行的進(jìn)程,將它掛起,禁止其運(yùn)行,等到用戶真正需要這個進(jìn)程的時候再解凍,恢復(fù)運(yùn)行。
進(jìn)程凍結(jié)中控制某一個進(jìn)程什么時候凍結(jié),什么時候解凍的控制邏輯,通常會放到系統(tǒng)框架的主進(jìn)程中,這樣做可以收集較全面的信息為判斷提供依據(jù),但缺點(diǎn)也很明顯,一方面,系統(tǒng)框架邏輯復(fù)雜,進(jìn)程凍結(jié)這種較大規(guī)模的變化有影響系統(tǒng)穩(wěn)定性的風(fēng)險,另一方面,Android系統(tǒng)安全性的等級的提升,導(dǎo)致系統(tǒng)要訪問應(yīng)用進(jìn)程的某些信息會遇到越來越多的權(quán)限問題,而開啟后門去解決權(quán)限問題,有留下安全漏洞的風(fēng)險。
技術(shù)實(shí)現(xiàn)要素:
本發(fā)明的主要目的在于提出一種自管理的Android進(jìn)程凍結(jié)和解凍的裝置及方法,通過將凍結(jié)控制線程放在應(yīng)用進(jìn)程中,使應(yīng)用進(jìn)程獨(dú)立管理凍結(jié)和解凍操作,不會影響整個設(shè)備系統(tǒng)的穩(wěn)定性,提升了用戶體驗(yàn)。
為實(shí)現(xiàn)上述目的,本發(fā)明提供的一種自管理的Android進(jìn)程凍結(jié)和解凍的裝置,包括:
凍結(jié)控制模塊,用于在應(yīng)用進(jìn)程中設(shè)置凍結(jié)控制線程;
凍結(jié)判斷模塊,用于所述凍結(jié)控制線程根據(jù)系統(tǒng)的運(yùn)行狀態(tài)判斷所述應(yīng)用進(jìn)程是否滿足預(yù)設(shè)的凍結(jié)條件,若是,則凍結(jié)所述應(yīng)用進(jìn)程,保持所述凍結(jié)控制線程和通訊線程的活動狀態(tài);
解凍模塊,用于當(dāng)所述通訊線程接收到外部通訊請求時,通過所述凍結(jié)控制線程解凍所述應(yīng)用進(jìn)程。
可選地,所述應(yīng)用進(jìn)程包括應(yīng)用程序包和應(yīng)用進(jìn)程框架,所述凍結(jié)控制線程和通訊線程皆設(shè)置于所述應(yīng)用進(jìn)程框架內(nèi)。
可選地,所述應(yīng)用進(jìn)程框架內(nèi)還設(shè)置有對外接口和對外接口代理,所述對外接口用于調(diào)用外部應(yīng)用程序,所述對外接口代理用于采集應(yīng)用程序包的調(diào)用信息,并將所述調(diào)用信息中導(dǎo)致所述應(yīng)用進(jìn)程狀態(tài)改變的調(diào)用信息通知到所述凍結(jié)控制線程。
可選地,所述應(yīng)用進(jìn)程還與系統(tǒng)框架進(jìn)程連接,所述系統(tǒng)框架進(jìn)程用于提供系統(tǒng)當(dāng)前環(huán)境信息,相應(yīng)地,所述凍結(jié)控制線程根據(jù)系統(tǒng)的運(yùn)行狀態(tài)判斷所述應(yīng)用進(jìn)程是否滿足預(yù)設(shè)的凍結(jié)條件具體為:
凍結(jié)控制線程根據(jù)所述對外接口代理提供的調(diào)用信息和所述系統(tǒng)當(dāng)前環(huán)境信息判斷所述應(yīng)用進(jìn)程是否滿足預(yù)設(shè)的凍結(jié)條件。
可選地,所述解凍模塊包括:
請求單元,用于通訊線程接收外部通訊請求;
判斷單元,用于判斷所述外部通訊請求是否需要及時解決,若是,則通過所述凍結(jié)控制線程解凍所述應(yīng)用進(jìn)程,否則,攔截所述外部通訊請求。
作為本發(fā)明的另一方面,提供的一種自管理的Android進(jìn)程凍結(jié)和解凍的方法,包括:
在應(yīng)用進(jìn)程中設(shè)置凍結(jié)控制線程;
所述凍結(jié)控制線程根據(jù)系統(tǒng)的運(yùn)行狀態(tài)判斷所述應(yīng)用進(jìn)程是否滿足預(yù)設(shè)的凍結(jié)條件,若是,則凍結(jié)所述應(yīng)用進(jìn)程,保持所述凍結(jié)控制線程和通訊線程的活動狀態(tài);
所述通訊線程接收到外部通訊請求時,通過所述凍結(jié)控制線程解凍所述應(yīng)用進(jìn)程。
可選地,所述應(yīng)用進(jìn)程包括應(yīng)用程序包和應(yīng)用進(jìn)程框架,所述凍結(jié)控制線程和通訊線程皆設(shè)置于所述應(yīng)用進(jìn)程框架內(nèi)。
可選地,所述應(yīng)用進(jìn)程框架內(nèi)還設(shè)置有對外接口和對外接口代理,所述對外接口用于調(diào)用外部應(yīng)用程序,所述對外接口代理用于采集應(yīng)用程序包的調(diào)用信息,并將所述調(diào)用信息中導(dǎo)致所述應(yīng)用進(jìn)程狀態(tài)改變的調(diào)用信息通知到所述凍結(jié)控制線程。
可選地,所述應(yīng)用進(jìn)程還與系統(tǒng)框架進(jìn)程連接,所述系統(tǒng)框架進(jìn)程,用于提供系統(tǒng)當(dāng)前環(huán)境信息,相應(yīng)地,所述凍結(jié)控制線程根據(jù)系統(tǒng)的運(yùn)行狀態(tài)判斷所述應(yīng)用進(jìn)程是否滿足預(yù)設(shè)的凍結(jié)條件具體為:
凍結(jié)控制線程根據(jù)所述對外接口代理提供的調(diào)用信息和所述系統(tǒng)當(dāng)前環(huán)境信息判斷所述應(yīng)用進(jìn)程是否滿足預(yù)設(shè)的凍結(jié)條件。
可選地,所述通訊線程接收到外部通訊請求時,通過所述凍結(jié)控制線程解凍所述應(yīng)用進(jìn)程包括:
通訊線程接收到外部通訊請求;
判斷所述外部通訊請求是否需要及時解決,若是,則通過所述凍結(jié)控制線程解凍所述應(yīng)用進(jìn)程,否則,攔截所述外部通訊請求。
本發(fā)明提出的一種自管理的Android進(jìn)程凍結(jié)和解凍的裝置及方法,該裝置包括:凍結(jié)控制模塊,用于在應(yīng)用進(jìn)程中設(shè)置凍結(jié)控制線程;凍結(jié)判斷模塊,用于所述凍結(jié)控制線程根據(jù)系統(tǒng)的運(yùn)行狀態(tài)判斷所述應(yīng)用進(jìn)程是否滿足預(yù)設(shè)的凍結(jié)條件,若是,則凍結(jié)所述應(yīng)用進(jìn)程,保持所述凍結(jié)控制線程和通訊線程的活動狀態(tài);解凍模塊,用于當(dāng)所述通訊線程接收到外部通訊請求時,通過所述凍結(jié)控制線程解凍所述應(yīng)用進(jìn)程,通過將凍結(jié)控制線程放在應(yīng)用進(jìn)程中,使應(yīng)用進(jìn)程獨(dú)立管理凍結(jié)和解凍操作,不會影響整個設(shè)備系統(tǒng)的穩(wěn)定性,提升了用戶體驗(yàn)。
附圖說明
圖1為實(shí)現(xiàn)本發(fā)明各個實(shí)施例的移動終端的硬件結(jié)構(gòu)示意圖;
圖2為如圖1所示的移動終端的無線通信系統(tǒng)示意圖;
圖3為本發(fā)明實(shí)施例一提供的一種自管理的Android進(jìn)程凍結(jié)和解凍的裝置示范性結(jié)構(gòu)框圖;
圖4為現(xiàn)有技術(shù)中應(yīng)用進(jìn)程功能結(jié)構(gòu)示意圖;
圖5為本發(fā)明實(shí)施例一、二提供的應(yīng)用進(jìn)程功能結(jié)構(gòu)示意圖;
圖6為本發(fā)明實(shí)施例三提供的一種自管理的Android進(jìn)程凍結(jié)和解凍的裝置示范性結(jié)構(gòu)框圖;
圖7為本發(fā)明實(shí)施例四提供的一種自管理的Android進(jìn)程凍結(jié)和解凍的方法流程圖;
圖8為本發(fā)明實(shí)施例五提供的一種自管理的Android進(jìn)程凍結(jié)和解凍的方法流程圖。
本發(fā)明目的的實(shí)現(xiàn)、功能特點(diǎn)及優(yōu)點(diǎn)將結(jié)合實(shí)施例,參照附圖做進(jìn)一步說明。
具體實(shí)施方式
應(yīng)當(dāng)理解,此處所描述的具體實(shí)施例僅僅用以解釋本發(fā)明,并不用于限定本發(fā)明。
現(xiàn)在將參考附圖描述實(shí)現(xiàn)本發(fā)明各個實(shí)施例的移動終端。在后續(xù)的描述中,使用用于表示元件的諸如“模塊”、“部件”或“單元”的后綴僅為了有利于本發(fā)明的說明,其本身并沒有特定的意義。因此,"模塊"與"部件"可以混合地使用。
移動終端可以以各種形式來實(shí)施。例如,本發(fā)明中描述的終端可以包括諸如移動電話、智能電話、筆記本電腦、數(shù)字廣播接收器、PDA(個人數(shù)字助理)、PAD(平板電腦)、PMP(便攜式多媒體播放器)、導(dǎo)航裝置等等的移動終端以及諸如數(shù)字TV、臺式計(jì)算機(jī)等等的固定終端。下面,假設(shè)終端是移動終端。然而,本領(lǐng)域技術(shù)人員將理解的是,除了特別用于移動目的的元件之外,根據(jù)本發(fā)明的實(shí)施方式的構(gòu)造也能夠應(yīng)用于固定類型的終端。
圖1為實(shí)現(xiàn)本發(fā)明各個實(shí)施例的移動終端的硬件結(jié)構(gòu)示意。
移動終端100可以包括無線通信單元110、A/V(音頻/視頻)輸入單元120、用戶輸入單元130、感測單元140、輸出單元150、存儲器160、接口單元170、控制器180和電源單元190等等。圖1示出了具有各種組件的移動終端,但是應(yīng)理解的是,并不要求實(shí)施所有示出的組件??梢蕴娲貙?shí)施更多或更少的組件。將在下面詳細(xì)描述移動終端的元件。
無線通信單元110通常包括一個或多個組件,其允許移動終端100與無線通信系統(tǒng)或網(wǎng)絡(luò)之間的無線電通信。例如,無線通信單元可以包括廣播接收模塊111、移動通信模塊112、無線互聯(lián)網(wǎng)模塊113、短程通信模塊114和位置信息模塊115中的至少一個。
廣播接收模塊111經(jīng)由廣播信道從外部廣播管理服務(wù)器接收廣播信號和/或廣播相關(guān)信息。廣播信道可以包括衛(wèi)星信道和/或地面信道。廣播管理服務(wù)器可以是生成并發(fā)送廣播信號和/或廣播相關(guān)信息的服務(wù)器或者接收之前生成的廣播信號和/或廣播相關(guān)信息并且將其發(fā)送給終端的服務(wù)器。廣播信號可以包括TV廣播信號、無線電廣播信號、數(shù)據(jù)廣播信號等等。而且,廣播信號可以進(jìn)一步包括與TV或無線電廣播信號組合的廣播信號。廣播相關(guān)信息也可以經(jīng)由移動通信網(wǎng)絡(luò)提供,并且在該情況下,廣播相關(guān)信息可以由移動通信模塊112來接收。廣播信號可以以各種形式存在,例如,其可以以數(shù)字多媒體廣播(DMB)的電子節(jié)目指南(EPG)、數(shù)字視頻廣播手持(DVB-H)的電子服務(wù)指南(ESG)等等的形式而存在。廣播接收模塊111可以通過使用各種類型的廣播系統(tǒng)接收信號廣播。特別地,廣播接收模塊111可以通過使用諸如多媒體廣播-地面(DMB-T)、數(shù)字多媒體廣播-衛(wèi)星(DMB-S)、數(shù)字視頻廣播-手持(DVB-H),前向鏈路媒體(MediaFLO@)的數(shù)據(jù)廣播系統(tǒng)、地面數(shù)字廣播綜合服務(wù)(ISDB-T)等等的數(shù)字廣播系統(tǒng)接收數(shù)字廣播。廣播接收模塊111可以被構(gòu)造為適合提供廣播信號的各種廣播系統(tǒng)以及上述數(shù)字廣播系統(tǒng)。經(jīng)由廣播接收模塊111接收的廣播信號和/或廣播相關(guān)信息可以存儲在存儲器160(或者其它類型的存儲介質(zhì))中。
移動通信模塊112將無線電信號發(fā)送到基站(例如,接入點(diǎn)、節(jié)點(diǎn)B等等)、外部終端以及服務(wù)器中的至少一個和/或從其接收無線電信號。這樣的無線電信號可以包括語音通話信號、視頻通話信號、或者根據(jù)文本和/或多媒體消息發(fā)送和/或接收的各種類型的數(shù)據(jù)。
無線互聯(lián)網(wǎng)模塊113支持移動終端的無線互聯(lián)網(wǎng)接入。該模塊可以內(nèi)部或外部地耦接到終端。該模塊所涉及的無線互聯(lián)網(wǎng)接入技術(shù)可以包括WLAN(無線LAN)(Wi-Fi)、Wibro(無線寬帶)、Wimax(全球微波互聯(lián)接入)、HSDPA(高速下行鏈路分組接入)等等。
短程通信模塊114是用于支持短程通信的模塊。短程通信技術(shù)的一些示例包括藍(lán)牙TM、射頻識別(RFID)、紅外數(shù)據(jù)協(xié)會(IrDA)、超寬帶(UWB)、紫蜂TM等等。
位置信息模塊115是用于檢查或獲取移動終端的位置信息的模塊。位置信息模塊的典型示例是GPS(全球定位系統(tǒng))。根據(jù)當(dāng)前的技術(shù),GPS模塊115計(jì)算來自三個或更多衛(wèi)星的距離信息和準(zhǔn)確的時間信息并且對于計(jì)算的信息應(yīng)用三角測量法,從而根據(jù)經(jīng)度、緯度和高度準(zhǔn)確地計(jì)算三維當(dāng)前位置信息。當(dāng)前,用于計(jì)算位置和時間信息的方法使用三顆衛(wèi)星并且通過使用另外的一顆衛(wèi)星校正計(jì)算出的位置和時間信息的誤差。此外,GPS模塊115能夠通過實(shí)時地連續(xù)計(jì)算當(dāng)前位置信息來計(jì)算速度信息。
A/V輸入單元120用于接收音頻或視頻信號。A/V輸入單元120可以包括相機(jī)121和麥克風(fēng)1220,相機(jī)121對在視頻捕獲模式或圖像捕獲模式中由圖像捕獲裝置獲得的靜態(tài)圖片或視頻的圖像數(shù)據(jù)進(jìn)行處理。處理后的圖像幀可以顯示在顯示模塊151上。經(jīng)相機(jī)121處理后的圖像幀可以存儲在存儲器160(或其它存儲介質(zhì))中或者經(jīng)由無線通信單元110進(jìn)行發(fā)送,可以根據(jù)移動終端的構(gòu)造提供兩個或更多相機(jī)1210。麥克風(fēng)122可以在電話通話模式、記錄模式、語音識別模式等等運(yùn)行模式中經(jīng)由麥克風(fēng)接收聲音(音頻數(shù)據(jù)),并且能夠?qū)⑦@樣的聲音處理為音頻數(shù)據(jù)。處理后的音頻(語音)數(shù)據(jù)可以在電話通話模式的情況下轉(zhuǎn)換為可經(jīng)由移動通信模塊112發(fā)送到移動通信基站的格式輸出。麥克風(fēng)122可以實(shí)施各種類型的噪聲消除(或抑制)算法以消除(或抑制)在接收和發(fā)送音頻信號的過程中產(chǎn)生的噪聲或者干擾。
用戶輸入單元130可以根據(jù)用戶輸入的命令生成鍵輸入數(shù)據(jù)以控制移動終端的各種操作。用戶輸入單元130允許用戶輸入各種類型的信息,并且可以包括鍵盤、鍋?zhàn)衅?、觸摸板(例如,檢測由于被接觸而導(dǎo)致的電阻、壓力、電容等等的變化的觸敏組件)、滾輪、搖桿等等。特別地,當(dāng)觸摸板以層的形式疊加在顯示模塊151上時,可以形成觸摸屏。
感測單元140檢測移動終端100的當(dāng)前狀態(tài),(例如,移動終端100的打開或關(guān)閉狀態(tài))、移動終端100的位置、用戶對于移動終端100的接觸(即,觸摸輸入)的有無、移動終端100的取向、移動終端100的加速或減速移動和方向等等,并且生成用于控制移動終端100的操作的命令或信號。例如,當(dāng)移動終端100實(shí)施為滑動型移動電話時,感測單元140可以感測該滑動型電話是打開還是關(guān)閉。另外,感測單元140能夠檢測電源單元190是否提供電力或者接口單元170是否與外部裝置耦接。感測單元140可以包括接近傳感器1410將在下面結(jié)合觸摸屏來對此進(jìn)行描述。
接口單元170用作至少一個外部裝置與移動終端100連接可以通過的接口。例如,外部裝置可以包括有線或無線頭戴式耳機(jī)端口、外部電源(或電池充電器)端口、有線或無線數(shù)據(jù)端口、存儲卡端口、用于連接具有識別模塊的裝置的端口、音頻輸入/輸出(I/O)端口、視頻I/O端口、耳機(jī)端口等等。識別模塊可以是存儲用于驗(yàn)證用戶使用移動終端100的各種信息并且可以包括用戶識別模塊(UIM)、客戶識別模塊(SIM)、通用客戶識別模塊(USIM)等等。另外,具有識別模塊的裝置(下面稱為"識別裝置")可以采取智能卡的形式,因此,識別裝置可以經(jīng)由端口或其它連接裝置與移動終端100連接。接口單元170可以用于接收來自外部裝置的輸入(例如,數(shù)據(jù)信息、電力等等)并且將接收到的輸入傳輸?shù)揭苿咏K端100內(nèi)的一個或多個元件或者可以用于在移動終端和外部裝置之間傳輸數(shù)據(jù)。
另外,當(dāng)移動終端100與外部底座連接時,接口單元170可以用作允許通過其將電力從底座提供到移動終端100的路徑或者可以用作允許從底座輸入的各種命令信號通過其傳輸?shù)揭苿咏K端的路徑。從底座輸入的各種命令信號或電力可以用作用于識別移動終端是否準(zhǔn)確地安裝在底座上的信號。輸出單元150被構(gòu)造為以視覺、音頻和/或觸覺方式提供輸出信號(例如,音頻信號、視頻信號、警報(bào)信號、振動信號等等)。輸出單元150可以包括顯示模塊151、音頻輸出模塊152、警報(bào)模塊153等等。
顯示模塊151可以顯示在移動終端100中處理的信息。例如,當(dāng)移動終端100處于電話通話模式時,顯示模塊151可以顯示與通話或其它通信(例如,文本消息收發(fā)、多媒體文件下載等等)相關(guān)的用戶界面(UI)或圖形用戶界面(GUI)。當(dāng)移動終端100處于視頻通話模式或者圖像捕獲模式時,顯示模塊151可以顯示捕獲的圖像和/或接收的圖像、示出視頻或圖像以及相關(guān)功能的UI或GUI等等。
同時,當(dāng)顯示模塊151和觸摸板以層的形式彼此疊加以形成觸摸屏?xí)r,顯示模塊151可以用作輸入裝置和輸出裝置。顯示模塊151可以包括液晶顯示器(LCD)、薄膜晶體管LCD(TFT-LCD)、有機(jī)發(fā)光二極管(OLED)顯示器、柔性顯示器、三維(3D)顯示器等等中的至少一種。這些顯示器中的一些可以被構(gòu)造為透明狀以允許用戶從外部觀看,這可以稱為透明顯示器,典型的透明顯示器可以例如為TOLED(透明有機(jī)發(fā)光二極管)顯示器等等。根據(jù)特定想要的實(shí)施方式,移動終端100可以包括兩個或更多顯示模塊(或其它顯示裝置),例如,移動終端可以包括外部顯示模塊(未示出)和內(nèi)部顯示模塊(未示出)。觸摸屏可用于檢測觸摸輸入壓力以及觸摸輸入位置和觸摸輸入面積。
音頻輸出模塊152可以在移動終端處于呼叫信號接收模式、通話模式、記錄模式、語音識別模式、廣播接收模式等等模式下時,將無線通信單元110接收的或者在存儲器160中存儲的音頻數(shù)據(jù)轉(zhuǎn)換音頻信號并且輸出為聲音。而且,音頻輸出模塊152可以提供與移動終端100執(zhí)行的特定功能相關(guān)的音頻輸出(例如,呼叫信號接收聲音、消息接收聲音等等)。音頻輸出模塊152可以包括揚(yáng)聲器、蜂鳴器等等。
警報(bào)模塊153可以提供輸出以將事件的發(fā)生通知給移動終端100。典型的事件可以包括呼叫接收、消息接收、鍵信號輸入、觸摸輸入等等。除了音頻或視頻輸出之外,警報(bào)模塊153可以以不同的方式提供輸出以通知事件的發(fā)生。例如,警報(bào)模塊153可以以振動的形式提供輸出,當(dāng)接收到呼叫、消息或一些其它進(jìn)入通信(incomingcommunication)時,警報(bào)模塊153可以提供觸覺輸出(即,振動)以將其通知給用戶。通過提供這樣的觸覺輸出,即使在用戶的移動電話處于用戶的口袋中時,用戶也能夠識別出各種事件的發(fā)生。警報(bào)模塊153也可以經(jīng)由顯示模塊151或音頻輸出模塊152提供通知事件的發(fā)生的輸出。
存儲器160可以存儲由控制器180執(zhí)行的處理和控制操作的軟件程序等等,或者可以暫時地存儲己經(jīng)輸出或?qū)⒁敵龅臄?shù)據(jù)(例如,電話簿、消息、靜態(tài)圖像、視頻等等)。而且,存儲器160可以存儲關(guān)于當(dāng)觸摸施加到觸摸屏?xí)r輸出的各種方式的振動和音頻信號的數(shù)據(jù)。
存儲器160可以包括至少一種類型的存儲介質(zhì),所述存儲介質(zhì)包括閃存、硬盤、多媒體卡、卡型存儲器(例如,SD或DX存儲器等等)、隨機(jī)訪問存儲器(RAM)、靜態(tài)隨機(jī)訪問存儲器(SRAM)、只讀存儲器(ROM)、電可擦除可編程只讀存儲器(EEPROM)、可編程只讀存儲器(PROM)、磁性存儲器、磁盤、光盤等等。而且,移動終端100可以與通過網(wǎng)絡(luò)連接執(zhí)行存儲器160的存儲功能的網(wǎng)絡(luò)存儲裝置協(xié)作。
控制器180通??刂埔苿咏K端的總體操作。例如,控制器180執(zhí)行與語音通話、數(shù)據(jù)通信、視頻通話等等相關(guān)的控制和處理。另外,控制器180可以包括用于再現(xiàn)(或回放)多媒體數(shù)據(jù)的多媒體模塊1810,多媒體模塊1810可以構(gòu)造在控制器180內(nèi),或者可以構(gòu)造為與控制器180分離??刂破?80可以執(zhí)行模式識別處理,以將在觸摸屏上執(zhí)行的手寫輸入或者圖片繪制輸入識別為字符或圖像。
電源單元190在控制器180的控制下接收外部電力或內(nèi)部電力并且提供操作各元件和組件所需的適當(dāng)?shù)碾娏Α?/p>
這里描述的各種實(shí)施方式可以以使用例如計(jì)算機(jī)軟件、硬件或其任何組合的計(jì)算機(jī)可讀介質(zhì)來實(shí)施。對于硬件實(shí)施,這里描述的實(shí)施方式可以通過使用特定用途集成電路(ASIC)、數(shù)字信號處理器(DSP)、數(shù)字信號處理裝置(DSPD)、可編程邏輯裝置(PLD)、現(xiàn)場可編程門陣列(FPGA)、處理器、控制器、微控制器、微處理器、被設(shè)計(jì)為執(zhí)行這里描述的功能的電子單元中的至少一種來實(shí)施,在一些情況下,這樣的實(shí)施方式可以在控制器180中實(shí)施。對于軟件實(shí)施,諸如過程或功能的實(shí)施方式可以與允許執(zhí)行至少一種功能或操作的單獨(dú)的軟件模塊來實(shí)施。軟件代碼可以由以任何適當(dāng)?shù)木幊陶Z言編寫的軟件應(yīng)用程序(或程序)來實(shí)施,軟件代碼可以存儲在存儲器160中并且由控制器180執(zhí)行。
至此,己經(jīng)按照其功能描述了移動終端。下面,為了簡要起見,將描述諸如折疊型、直板型、擺動型、滑動型移動終端等等的各種類型的移動終端中的滑動型移動終端作為示例。因此,本發(fā)明能夠應(yīng)用于任何類型的移動終端,并且不限于滑動型移動終端。
如圖1中所示的移動終端100可以被構(gòu)造為利用經(jīng)由幀或分組發(fā)送數(shù)據(jù)的諸如有線和無線通信系統(tǒng)以及基于衛(wèi)星的通信系統(tǒng)來操作。
現(xiàn)在將參考圖2描述其中根據(jù)本發(fā)明的移動終端能夠操作的通信系統(tǒng)。
這樣的通信系統(tǒng)可以使用不同的空中接口和/或物理層。例如,由通信系統(tǒng)使用的空中接口包括例如頻分多址(FDMA)、時分多址(TDMA)、碼分多址(CDMA)和通用移動通信系統(tǒng)(UMTS)(特別地,長期演進(jìn)(LTE))、全球移動通信系統(tǒng)(GSM)等等。作為非限制性示例,下面的描述涉及CDMA通信系統(tǒng),但是這樣的教導(dǎo)同樣適用于其它類型的系統(tǒng)。
參考圖2,CDMA無線通信系統(tǒng)可以包括多個移動終端100、多個基站(BS)270、基站控制器(BSC)275和移動交換中心(MSC)280。MSC280被構(gòu)造為與公共電話交換網(wǎng)絡(luò)(PSTN)290形成接口。MSC280還被構(gòu)造為與可以經(jīng)由回程線路耦接到基站270的BSC275形成接口。回程線路可以根據(jù)若干己知的接口中的任一種來構(gòu)造,所述接口包括例如E1/T1、ATM,IP、PPP、幀中繼、HDSL、ADSL或xDSL。將理解的是,如圖2中所示的系統(tǒng)可以包括多個BSC2750。
每個BS270可以服務(wù)一個或多個分區(qū)(或區(qū)域),由多向天線或指向特定方向的天線覆蓋的每個分區(qū)放射狀地遠(yuǎn)離BS270?;蛘撸總€分區(qū)可以由用于分集接收的兩個或更多天線覆蓋。每個BS270可以被構(gòu)造為支持多個頻率分配,并且每個頻率分配具有特定頻譜(例如,1.25MHz,5MHz等等)。
分區(qū)與頻率分配的交叉可以被稱為CDMA信道。BS270也可以被稱為基站收發(fā)器子系統(tǒng)(BTS)或者其它等效術(shù)語。在這樣的情況下,術(shù)語"基站"可以用于籠統(tǒng)地表示單個BSC275和至少一個BS270。基站也可以被稱為"蜂窩站"?;蛘?,特定BS270的各分區(qū)可以被稱為多個蜂窩站。
如圖2中所示,廣播發(fā)射器(BT)295將廣播信號發(fā)送給在系統(tǒng)內(nèi)操作的移動終端100。如圖1中所示的廣播接收模塊111被設(shè)置在移動終端100處以接收由BT295發(fā)送的廣播信號。在圖2中,示出了幾個全球定位系統(tǒng)(GPS)衛(wèi)星300。衛(wèi)星300幫助定位多個移動終端100中的至少一個。
在圖2中,描繪了多個衛(wèi)星300,但是理解的是,可以利用任何數(shù)目的衛(wèi)星獲得有用的定位信息。如圖1中所示的GPS模塊115通常被構(gòu)造為與衛(wèi)星300配合以獲得想要的定位信息。替代GPS跟蹤技術(shù)或者在GPS跟蹤技術(shù)之外,可以使用可以跟蹤移動終端的位置的其它技術(shù)。另外,至少一個GPS衛(wèi)星300可以選擇性地或者額外地處理衛(wèi)星DMB傳輸。
作為無線通信系統(tǒng)的一個典型操作,BS270接收來自各種移動終端100的反向鏈路信號。移動終端100通常參與通話、消息收發(fā)和其它類型的通信。特定基站270接收的每個反向鏈路信號被在特定BS270內(nèi)進(jìn)行處理。獲得的數(shù)據(jù)被轉(zhuǎn)發(fā)給相關(guān)的BSC275。BSC提供通話資源分配和包括BS270之間的軟切換過程的協(xié)調(diào)的移動管理功能。BSC275還將接收到的數(shù)據(jù)路由到MSC280,其提供用于與PSTN290形成接口的額外的路由服務(wù)。類似地,PSTN290與MSC280形成接口,MSC與BSC275形成接口,并且BSC275相應(yīng)地控制BS270以將正向鏈路信號發(fā)送到移動終端100。
基于上述移動終端硬件結(jié)構(gòu)以及通信系統(tǒng),提出本發(fā)明方法各個實(shí)施例。
實(shí)施例一
如圖3所示,在本實(shí)施例中,一種自管理的Android進(jìn)程凍結(jié)和解凍的裝置,包括:
凍結(jié)控制模塊10,用于在應(yīng)用進(jìn)程中設(shè)置凍結(jié)控制線程;
凍結(jié)判斷模塊20,用于所述凍結(jié)控制線程根據(jù)系統(tǒng)的運(yùn)行狀態(tài)判斷所述應(yīng)用進(jìn)程是否滿足預(yù)設(shè)的凍結(jié)條件,若是,則凍結(jié)所述應(yīng)用進(jìn)程,保持所述凍結(jié)控制線程和通訊線程的活動狀態(tài);
解凍模塊30,用于當(dāng)所述通訊線程接收到外部通訊請求時,通過所述凍結(jié)控制線程解凍所述應(yīng)用進(jìn)程。
在本實(shí)施例中,通過將凍結(jié)控制線程放在應(yīng)用進(jìn)程中,使應(yīng)用進(jìn)程獨(dú)立管理凍結(jié)和解凍操作,不會影響整個設(shè)備系統(tǒng)的穩(wěn)定性,提升了用戶體驗(yàn)。
在現(xiàn)有的技術(shù)中,如圖4所示,應(yīng)用進(jìn)程包括應(yīng)用程序包(APK)和應(yīng)用進(jìn)程框架,其中,應(yīng)用程序包由各個應(yīng)用程序的開發(fā)者提供,Android設(shè)備用戶可以在市場上下載使用應(yīng)用程序包,對系統(tǒng)而言,這部分是如何運(yùn)行的不可見,也是不可更改的;而應(yīng)用進(jìn)程框架用于為應(yīng)用程序包提供運(yùn)行環(huán)境,現(xiàn)有的應(yīng)用進(jìn)程框架包括對外接口和通訊線程,所述對外接口用于調(diào)用外部應(yīng)用程序,所述通訊線程用于和其他應(yīng)用程序進(jìn)行通訊,發(fā)送通訊請求至其他應(yīng)用程序或接收其他應(yīng)用程序發(fā)來的通訊請求,這一部分是可以由Android設(shè)備生產(chǎn)廠商進(jìn)行修改;在現(xiàn)有技術(shù)中,應(yīng)用進(jìn)程框架中的對外接口和通訊線程通過系統(tǒng)框架進(jìn)程與系統(tǒng)進(jìn)行信息傳遞,將采集到的自身信息發(fā)送至系統(tǒng),以便系統(tǒng)全局掌握系統(tǒng)內(nèi)各個應(yīng)用程序的運(yùn)行狀態(tài),或者通過系統(tǒng)框架進(jìn)程調(diào)用其他應(yīng)用程序,以便于與其他應(yīng)用程序進(jìn)行交互,而應(yīng)用進(jìn)程的凍結(jié)與解凍也是通過系統(tǒng)框架進(jìn)程進(jìn)行的,一般來說,系統(tǒng)框架邏輯復(fù)雜,所有應(yīng)用進(jìn)程的凍結(jié)與解凍都依靠系統(tǒng)框架來進(jìn)行,會極大影響系統(tǒng)穩(wěn)定性,基于此,在本案中,通過對應(yīng)用進(jìn)程中可以修改的部分,也即對應(yīng)用進(jìn)程框架進(jìn)行改進(jìn),使得應(yīng)用進(jìn)程的凍結(jié)與解凍操作由應(yīng)用進(jìn)程自身來管理,降低了對系統(tǒng)框架的依賴性,即使某一個應(yīng)用進(jìn)程的凍結(jié)與解凍操作出現(xiàn)故障,如凍結(jié)操作過快或解凍操作不及時,也只影響這一個應(yīng)用進(jìn)程,不會對其他應(yīng)用程序甚至整個設(shè)備系統(tǒng)造成影響,這樣就提高了整個系統(tǒng)的穩(wěn)定性。
具體地,如圖5所示,在本實(shí)施例中,所述應(yīng)用進(jìn)程包括應(yīng)用程序包和應(yīng)用進(jìn)程框架,與圖4不同的是,所述應(yīng)用進(jìn)程框架中除了通訊線程和對外接口,還設(shè)置有凍結(jié)控制線程和對外接口代理。
由于在應(yīng)用進(jìn)程中,應(yīng)用程序包部分是不可更改的,所以本實(shí)施例中的凍結(jié)控制線程和對外接口代理借設(shè)置于應(yīng)用進(jìn)程框架中,這部分可以由設(shè)備生產(chǎn)廠商來完成。
在本實(shí)施例中,當(dāng)應(yīng)用進(jìn)程啟動后,所述凍結(jié)控制線程隨之啟動,并從系統(tǒng)加載一些配置相關(guān)的基礎(chǔ)信息,也會通過對外接口代理獲取本應(yīng)用進(jìn)程更具體地來說是應(yīng)用程序包的調(diào)用信息,并結(jié)合系統(tǒng)框架進(jìn)程提供的系統(tǒng)當(dāng)前環(huán)境信息,來獲知系統(tǒng)的運(yùn)行狀態(tài),根據(jù)系統(tǒng)的運(yùn)行狀態(tài)判斷所述應(yīng)用進(jìn)程是否滿足預(yù)設(shè)的凍結(jié)條件,比如,某一應(yīng)用進(jìn)程試圖獲取用戶的隱私信息,如相冊、地理位置等,這一調(diào)用信息會被對外接口代理采集到,并判斷該調(diào)用信息會導(dǎo)致應(yīng)用進(jìn)程的狀態(tài)發(fā)生改變,滿足預(yù)設(shè)的凍結(jié)條件,則凍結(jié)該應(yīng)用進(jìn)程,在凍結(jié)應(yīng)用進(jìn)程時,通訊線程以及凍結(jié)控制線程不會被凍結(jié),以便于應(yīng)用進(jìn)程的自主解凍。
在本實(shí)施例中,當(dāng)凍結(jié)控制線程根據(jù)以上各種信息判斷到當(dāng)前應(yīng)用進(jìn)程不滿足預(yù)設(shè)的凍結(jié)條件時,則不進(jìn)行凍結(jié)操作,比如某一應(yīng)用進(jìn)行一直處于靜默狀態(tài),其對外接口的調(diào)用信息也屬于該應(yīng)用程序本身必須的基本調(diào)用,不會引起該應(yīng)用進(jìn)程的狀態(tài)發(fā)生變化,也不會對系統(tǒng)造成影響,則不必進(jìn)行凍結(jié)操作。
作為另一種實(shí)施例,所述凍結(jié)控制線程在對自身的凍結(jié)與解凍操作的同時,也不影響系統(tǒng)對應(yīng)用程序的直接控制,這是擁有最高權(quán)限的,當(dāng)用戶或系統(tǒng)發(fā)送關(guān)閉某一應(yīng)用的操作指令時,凍結(jié)控制線程會及時將該應(yīng)用的進(jìn)程進(jìn)行凍結(jié)。
在本實(shí)施例中,所述對外接口用于調(diào)用外部應(yīng)用程序,所述對外接口代理用于采集應(yīng)用程序包的調(diào)用信息,并將所述調(diào)用信息中導(dǎo)致所述應(yīng)用進(jìn)程狀態(tài)改變的調(diào)用信息通知到所述凍結(jié)控制線程。
在本實(shí)施例中,通過對外接口代理采集應(yīng)用進(jìn)程的自身信息,一定層度上提高信息收集的效率。在應(yīng)用進(jìn)程內(nèi)收集本應(yīng)用相關(guān)的各種信息,會減少在所有進(jìn)程中檢索信息的情況;而且,凍結(jié)控制線程通過對外接口代理查詢自身的信息,不需要額外的權(quán)限,也就不需要因權(quán)限問題而開后門,不會留下安全漏洞,提高了系統(tǒng)的安全性。
實(shí)施例二
如圖5所示,在本實(shí)施例中,所述應(yīng)用進(jìn)程還與系統(tǒng)框架進(jìn)程連接,所述系統(tǒng)框架進(jìn)程用于提供系統(tǒng)當(dāng)前環(huán)境信息,相應(yīng)地,所述凍結(jié)控制線程根據(jù)系統(tǒng)的運(yùn)行狀態(tài)判斷所述應(yīng)用進(jìn)程是否滿足預(yù)設(shè)的凍結(jié)條件具體為:
凍結(jié)控制線程根據(jù)所述對外接口代理提供的調(diào)用信息和所述系統(tǒng)當(dāng)前環(huán)境信息判斷所述應(yīng)用進(jìn)程是否滿足預(yù)設(shè)的凍結(jié)條件。
在本實(shí)施例中,當(dāng)應(yīng)用進(jìn)程啟動后,所述凍結(jié)控制線程隨之啟動,并從系統(tǒng)加載一些配置相關(guān)的基礎(chǔ)信息,也會通過對外接口代理獲取本應(yīng)用進(jìn)程更具體地來說是應(yīng)用程序包的調(diào)用信息,并結(jié)合系統(tǒng)框架進(jìn)程提供的系統(tǒng)當(dāng)前環(huán)境信息,來獲知系統(tǒng)的運(yùn)行狀態(tài),根據(jù)系統(tǒng)的運(yùn)行狀態(tài)判斷所述應(yīng)用進(jìn)程是否滿足預(yù)設(shè)的凍結(jié)條件,比如,某一應(yīng)用進(jìn)程試圖獲取用戶的隱私信息,如相冊、地理位置等,這一調(diào)用信息會被對外接口代理采集到,并判斷該調(diào)用信息會導(dǎo)致應(yīng)用進(jìn)程的狀態(tài)發(fā)生改變,滿足預(yù)設(shè)的凍結(jié)條件,則凍結(jié)該應(yīng)用進(jìn)程,在凍結(jié)應(yīng)用進(jìn)程時,通訊線程以及凍結(jié)控制線程不會被凍結(jié),以便于應(yīng)用進(jìn)程的自主解凍。
在本實(shí)施例中,當(dāng)凍結(jié)控制線程根據(jù)以上各種信息判斷到當(dāng)前應(yīng)用進(jìn)程不滿足預(yù)設(shè)的凍結(jié)條件時,則不進(jìn)行凍結(jié)操作,比如某一應(yīng)用進(jìn)行一直處于靜默狀態(tài),其對外接口的調(diào)用信息也屬于該應(yīng)用程序本身必須的基本調(diào)用,不會引起該應(yīng)用進(jìn)程的狀態(tài)發(fā)生變化,也不會對系統(tǒng)造成影響,則不必進(jìn)行凍結(jié)操作。
作為另一種實(shí)施例,所述凍結(jié)控制線程在對自身的凍結(jié)與解凍操作的同時,也不影響系統(tǒng)對應(yīng)用程序的直接控制,這是擁有最高權(quán)限的,當(dāng)用戶或系統(tǒng)發(fā)送關(guān)閉某一應(yīng)用的操作指令時,凍結(jié)控制線程會及時將該應(yīng)用的進(jìn)程進(jìn)行凍結(jié)。
實(shí)施例三
如圖6所示,在本實(shí)施例中,所述解凍模塊30包括:
請求單元31,用于通訊線程接收外部通訊請求;
判斷單元32,用于判斷所述外部通訊請求是否需要及時解決,若是,則通過所述凍結(jié)控制線程解凍所述應(yīng)用進(jìn)程,否則,攔截所述外部通訊請求。
在本實(shí)施例中,所述外部通訊請求是否需要及時解決可以通過查看該外部通訊請求是否有及時性的要求來判斷,如果外部通訊請求有及時性的要求,比如該外部通訊請求涉及通話、攝像等實(shí)時應(yīng)用程序,則需通過所述凍結(jié)控制線程解凍所述應(yīng)用進(jìn)程,如果外部通訊請求不需要及時處理,比如該外部通訊請求涉及到接收了某一論壇消息,或收到了一個廣告推送,則不需要對該應(yīng)用進(jìn)程進(jìn)行解凍,忽略該外部通訊請求,甚至是攔截該外部通訊請求。
實(shí)施例四
如圖7所示,在本實(shí)施例中,一種自管理的Android進(jìn)程凍結(jié)和解凍的方法,包括:
S10、在應(yīng)用進(jìn)程中設(shè)置凍結(jié)控制線程;
S20、所述凍結(jié)控制線程根據(jù)系統(tǒng)的運(yùn)行狀態(tài)判斷所述應(yīng)用進(jìn)程是否滿足預(yù)設(shè)的凍結(jié)條件,若是,則進(jìn)入步驟S30、凍結(jié)所述應(yīng)用進(jìn)程,保持所述凍結(jié)控制線程和通訊線程的活動狀態(tài);否則,進(jìn)入步驟S21、不凍結(jié)應(yīng)用進(jìn)程;
S40、所述通訊線程接收到外部通訊請求時,通過所述凍結(jié)控制線程解凍所述應(yīng)用進(jìn)程。
在本實(shí)施例中,通過將凍結(jié)控制線程放在應(yīng)用進(jìn)程中,使應(yīng)用進(jìn)程獨(dú)立管理凍結(jié)和解凍操作,不會影響整個設(shè)備系統(tǒng)的穩(wěn)定性,提升了用戶體驗(yàn)。
在現(xiàn)有的技術(shù)中,如圖4所示,應(yīng)用進(jìn)程包括應(yīng)用程序包(APK)和應(yīng)用進(jìn)程框架,其中,應(yīng)用程序包由各個應(yīng)用程序的開發(fā)者提供,Android設(shè)備用戶可以在市場上下載使用應(yīng)用程序包,對系統(tǒng)而言,這部分是如何運(yùn)行的不可見,也是不可更改的;而應(yīng)用進(jìn)程框架用于為應(yīng)用程序包提供運(yùn)行環(huán)境,現(xiàn)有的應(yīng)用進(jìn)程框架包括對外接口和通訊線程,所述對外接口用于調(diào)用外部應(yīng)用程序,所述通訊線程用于和其他應(yīng)用程序進(jìn)行通訊,發(fā)送通訊請求至其他應(yīng)用程序或接收其他應(yīng)用程序發(fā)來的通訊請求,這一部分是可以由Android設(shè)備生產(chǎn)廠商進(jìn)行修改;在現(xiàn)有技術(shù)中,應(yīng)用進(jìn)程框架中的對外接口和通訊線程通過系統(tǒng)框架進(jìn)程與系統(tǒng)進(jìn)行信息傳遞,將采集到的自身信息發(fā)送至系統(tǒng),以便系統(tǒng)全局掌握系統(tǒng)內(nèi)各個應(yīng)用程序的運(yùn)行狀態(tài),或者通過系統(tǒng)框架進(jìn)程調(diào)用其他應(yīng)用程序,以便于與其他應(yīng)用程序進(jìn)行交互,而應(yīng)用進(jìn)程的凍結(jié)與解凍也是通過系統(tǒng)框架進(jìn)程進(jìn)行的,一般來說,系統(tǒng)框架邏輯復(fù)雜,所有應(yīng)用進(jìn)程的凍結(jié)與解凍都依靠系統(tǒng)框架來進(jìn)行,會極大影響系統(tǒng)穩(wěn)定性,基于此,在本案中,通過對應(yīng)用進(jìn)程中可以修改的部分,也即對應(yīng)用進(jìn)程框架進(jìn)行改進(jìn),使得應(yīng)用進(jìn)程的凍結(jié)與解凍操作由應(yīng)用進(jìn)程自身來管理,降低了對系統(tǒng)框架的依賴性,即使某一個應(yīng)用進(jìn)程的凍結(jié)與解凍操作出現(xiàn)故障,如凍結(jié)操作過快或解凍操作不及時,也只影響這一個應(yīng)用進(jìn)程,不會對其他應(yīng)用程序甚至整個設(shè)備系統(tǒng)造成影響,這樣就提高了整個系統(tǒng)的穩(wěn)定性。
具體地,如圖5所示,在本實(shí)施例中,所述應(yīng)用進(jìn)程包括應(yīng)用程序包和應(yīng)用進(jìn)程框架,與圖4不同的是,所述應(yīng)用進(jìn)程框架中除了通訊線程和對外接口,還設(shè)置有凍結(jié)控制線程和對外接口代理。
由于在應(yīng)用進(jìn)程中,應(yīng)用程序包部分是不可更改的,所以本實(shí)施例中的凍結(jié)控制線程和對外接口代理借設(shè)置于應(yīng)用進(jìn)程框架中,這部分可以由設(shè)備生產(chǎn)廠商來完成。
在本實(shí)施例中,當(dāng)應(yīng)用進(jìn)程啟動后,所述凍結(jié)控制線程隨之啟動,并從系統(tǒng)加載一些配置相關(guān)的基礎(chǔ)信息,也會通過對外接口代理獲取本應(yīng)用進(jìn)程更具體地來說是應(yīng)用程序包的調(diào)用信息,并結(jié)合系統(tǒng)框架進(jìn)程提供的系統(tǒng)當(dāng)前環(huán)境信息,來獲知系統(tǒng)的運(yùn)行狀態(tài),根據(jù)系統(tǒng)的運(yùn)行狀態(tài)判斷所述應(yīng)用進(jìn)程是否滿足預(yù)設(shè)的凍結(jié)條件,比如,某一應(yīng)用進(jìn)程試圖獲取用戶的隱私信息,如相冊、地理位置等,這一調(diào)用信息會被對外接口代理采集到,并判斷該調(diào)用信息會導(dǎo)致應(yīng)用進(jìn)程的狀態(tài)發(fā)生改變,滿足預(yù)設(shè)的凍結(jié)條件,則凍結(jié)該應(yīng)用進(jìn)程,在凍結(jié)應(yīng)用進(jìn)程時,通訊線程以及凍結(jié)控制線程不會被凍結(jié),以便于應(yīng)用進(jìn)程的自主解凍。
在本實(shí)施例中,當(dāng)凍結(jié)控制線程根據(jù)以上各種信息判斷到當(dāng)前應(yīng)用進(jìn)程不滿足預(yù)設(shè)的凍結(jié)條件時,則不進(jìn)行凍結(jié)操作,比如某一應(yīng)用進(jìn)行一直處于靜默狀態(tài),其對外接口的調(diào)用信息也屬于該應(yīng)用程序本身必須的基本調(diào)用,不會引起該應(yīng)用進(jìn)程的狀態(tài)發(fā)生變化,也不會對系統(tǒng)造成影響,則不必進(jìn)行凍結(jié)操作。
作為另一種實(shí)施例,所述凍結(jié)控制線程在對自身的凍結(jié)與解凍操作的同時,也不影響系統(tǒng)對應(yīng)用程序的直接控制,這是擁有最高權(quán)限的,當(dāng)用戶或系統(tǒng)發(fā)送關(guān)閉某一應(yīng)用的操作指令時,凍結(jié)控制線程會及時將該應(yīng)用的進(jìn)程進(jìn)行凍結(jié)。
在本實(shí)施例中,所述對外接口用于調(diào)用外部應(yīng)用程序,所述對外接口代理用于采集應(yīng)用程序包的調(diào)用信息,并將所述調(diào)用信息中導(dǎo)致所述應(yīng)用進(jìn)程狀態(tài)改變的調(diào)用信息通知到所述凍結(jié)控制線程。
在本實(shí)施例中,通過對外接口代理采集應(yīng)用進(jìn)程的自身信息,一定層度上提高信息收集的效率。在應(yīng)用進(jìn)程內(nèi)收集本應(yīng)用相關(guān)的各種信息,會減少在所有進(jìn)程中檢索信息的情況;而且,凍結(jié)控制線程通過對外接口代理查詢自身的信息,不需要額外的權(quán)限,也就不需要因權(quán)限問題而開后門,不會留下安全漏洞,提高了系統(tǒng)的安全性。
在本實(shí)施例中,所述應(yīng)用進(jìn)程還與系統(tǒng)框架進(jìn)程連接,所述系統(tǒng)框架進(jìn)程,用于提供系統(tǒng)當(dāng)前環(huán)境信息,相應(yīng)地,所述步驟S20具體為:
凍結(jié)控制線程根據(jù)所述對外接口代理提供的調(diào)用信息和所述系統(tǒng)當(dāng)前環(huán)境信息判斷所述應(yīng)用進(jìn)程是否滿足預(yù)設(shè)的凍結(jié)條件。
實(shí)施例五
如圖8所示,在本實(shí)施例中,所述步驟S30包括:
S31、通訊線程接收到外部通訊請求;
S32、判斷所述外部通訊請求是否需要及時解決,若是,則進(jìn)入步驟S33、通過所述凍結(jié)控制線程解凍所述應(yīng)用進(jìn)程,否則,進(jìn)入步驟S34、攔截所述外部通訊請求。
在本實(shí)施例中,所述外部通訊請求是否需要及時解決可以通過查看該外部通訊請求是否有及時性的要求來判斷,如果外部通訊請求有及時性的要求,比如該外部通訊請求涉及通話、攝像等實(shí)時應(yīng)用程序,則需通過所述凍結(jié)控制線程解凍所述應(yīng)用進(jìn)程,如果外部通訊請求不需要及時處理,比如該外部通訊請求涉及到接收了某一論壇消息,或收到了一個廣告推送,則不需要對該應(yīng)用進(jìn)程進(jìn)行解凍,忽略該外部通訊請求,甚至是攔截該外部通訊請求。
需要說明的是,在本文中,術(shù)語“包括”、“包含”或者其任何其他變體意在涵蓋非排他性的包含,從而使得包括一系列要素的過程、方法、物品或者裝置不僅包括那些要素,而且還包括沒有明確列出的其他要素,或者是還包括為這種過程、方法、物品或者裝置所固有的要素。在沒有更多限制的情況下,由語句“包括一個……”限定的要素,并不排除在包括該要素的過程、方法、物品或者裝置中還存在另外的相同要素。
上述本發(fā)明實(shí)施例序號僅僅為了描述,不代表實(shí)施例的優(yōu)劣。
通過以上的實(shí)施方式的描述,本領(lǐng)域的技術(shù)人員可以清楚地了解到上述實(shí)施例方法可借助軟件加必需的通用硬件平臺的方式來實(shí)現(xiàn),當(dāng)然也可以通過硬件,但很多情況下前者是更佳的實(shí)施方式?;谶@樣的理解,本發(fā)明的技術(shù)方案本質(zhì)上或者說對現(xiàn)有技術(shù)做出貢獻(xiàn)的部分可以以軟件產(chǎn)品的形式體現(xiàn)出來,該計(jì)算機(jī)軟件產(chǎn)品存儲在一個存儲介質(zhì)(如ROM/RAM、磁碟、光盤)中,包括若干指令用以使得一臺終端設(shè)備(可以是手機(jī),計(jì)算機(jī),服務(wù)器,空調(diào)器,或者網(wǎng)絡(luò)設(shè)備等)執(zhí)行本發(fā)明各個實(shí)施例所述的方法。
以上僅為本發(fā)明的優(yōu)選實(shí)施例,并非因此限制本發(fā)明的專利范圍,凡是利用本發(fā)明說明書及附圖內(nèi)容所作的等效結(jié)構(gòu)或等效流程變換,或直接或間接運(yùn)用在其他相關(guān)的技術(shù)領(lǐng)域,均同理包括在本發(fā)明的專利保護(hù)范圍內(nèi)。