TWI533205B - 應用程式存留期管理 - Google Patents
應用程式存留期管理 Download PDFInfo
- Publication number
- TWI533205B TWI533205B TW100134404A TW100134404A TWI533205B TW I533205 B TWI533205 B TW I533205B TW 100134404 A TW100134404 A TW 100134404A TW 100134404 A TW100134404 A TW 100134404A TW I533205 B TWI533205 B TW I533205B
- Authority
- TW
- Taiwan
- Prior art keywords
- applications
- application
- threshold
- computing device
- met
- Prior art date
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/50—Allocation of resources, e.g. of the central processing unit [CPU]
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q10/00—Administration; Management
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/48—Program initiating; Program switching, e.g. by interrupt
- G06F9/4806—Task transfer initiation or dispatching
- G06F9/4843—Task transfer initiation or dispatching by program, e.g. task dispatcher, supervisor, operating system
- G06F9/485—Task life-cycle, e.g. stopping, restarting, resuming execution
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5005—Allocation of resources, e.g. of the central processing unit [CPU] to service a request
- G06F9/5011—Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resources being hardware resources other than CPUs, Servers and Terminals
- G06F9/5022—Mechanisms to release resources
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2209/00—Indexing scheme relating to G06F9/00
- G06F2209/48—Indexing scheme relating to G06F9/48
- G06F2209/482—Application
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2209/00—Indexing scheme relating to G06F9/00
- G06F2209/50—Indexing scheme relating to G06F9/50
- G06F2209/504—Resource capping
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Software Systems (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- Business, Economics & Management (AREA)
- Quality & Reliability (AREA)
- Entrepreneurship & Innovation (AREA)
- Human Resources & Organizations (AREA)
- Marketing (AREA)
- Operations Research (AREA)
- Economics (AREA)
- Strategic Management (AREA)
- Tourism & Hospitality (AREA)
- General Business, Economics & Management (AREA)
- Stored Programmes (AREA)
- Power Sources (AREA)
- Telephone Function (AREA)
- Electric Propulsion And Braking For Vehicles (AREA)
- User Interface Of Digital Computer (AREA)
- Techniques For Improving Reliability Of Storages (AREA)
- Mobile Radio Communication Systems (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
Description
本發明係關於應用程式存留期管理。
計算裝置可同時地執行多個應用程式。當同時地執行的應用程式的數目增加時,各種計算裝置資源的使用(例如處理器、記憶體等等)亦增加。即使應用程式並不主動地由計算裝置的使用者來使用,此等應用程式可繼續地使用計算裝置資源。此者係有問題的,因為由多個同時地執行的應用程式使用計算裝置資源會降低計算裝置的效能,前述情況會導致令人挫折和不愉快的使用者經驗。
提供此發明內容以簡化的形式作選擇性概念的介紹,該等概念進一步描述於後文的實施方式中。此發明內容無意於識別所請求發明內容的關鍵特徵或必要特徵,及無意於被使用以限制所請求發明內容的範圍。
根據一或多個態樣,在執行多個應用程式的計算裝置中,作出關於多個臨界值中的臨界值是否已符合的檢查。多個臨界值的每一者與多個應用程式的一者的特性相關聯,或與計算裝置的資源的特性關聯。若該臨界值並未符合,則多個應用程式被允許繼續在該計算裝置上執行。然而,若該臨界值已符合,則至少部份地根據與已符合的該臨界值相關聯的特性,選擇欲被關閉的多個應用程式中的一或多個,及該選擇的應用程式被關閉。
根據一或多個態樣,產生在計算裝置上執行的背景應用程式的清單。該背景應用程式的清單進行優先排序,該優先排序係至少部份地根據由在該清單上背景應用程式對計算裝置的資源的使用。在該背景應用程式的清單上選擇應用程式,及該選擇的應用程式被關閉。
在此討論應用程式存留期管理。監控應用程式的各種特性及/或計算裝置資源,例如應用程式年齡、處理器使用、記憶體使用等等。此等監控的特性之每一者具有相關的臨界值,若該等臨界值的至少一者符合,則一或多個應用程式經選擇以自動地關閉。經選擇以自動地關閉的一或多個應用程式係至少地部份根據符合的臨界值和與此臨界值相關聯的特性。
第1圖根據一或多個具體實施例示例說明實例計算裝置100,該實例計算裝置實施應用程式存留期管理。計算裝置100可為各種不同類型的裝置。舉例而言,計算裝置100可為桌上型電腦、小筆電或膝上型電腦、筆記型電腦或平板電腦、行動台、娛樂裝置、通訊地耦接至顯示裝置的機頂盒、電視、細胞式或其它的無線電話、遊戲台、汽車用電腦等等。因此,計算裝置100的範圍從具有大量記憶體和處理器資源(例如個人電腦、遊戲台)的全資源裝置至具有有限的記憶體及/或處理資源的低資源裝置(例如傳統的機頂盒、手持遊戲台)。
計算裝置100係由一或多個電源供電。此等電源可為外部電源或插入電源,及當操作在從此電源提供的功率下,計算裝置100意指為:操作為插入系統或裝置。此等電源亦可為內部電源(例如電池),及當操作在從此電源提供的功率下,計算裝置100意指為:操作為使用電池(on-battery)的系統或裝置。取決於該裝置在任何特定的時間點操作下使用的電源,許多類型的裝置在不同的時間點可為插入系統或使用電池的系統。然而,其它類型的裝置可僅為插入系統(不具有任何的內部電源),或僅為使用電池的系統(不使用外部電源)。
計算裝置100包含:作業系統102和一或多個應用程式104。在操作期間,作業系統102和應用程式104在計算裝置100上執行,其中作業系統102對應用程式104進行管理。如同在後文中更為詳細地討論者,應用程式104的管理包含:自動地關閉一或多個應用程式104。應用程式104的存留期或壽命意指為:當應用程式執行的時間區段,該時間區段啟始於該應用程式開始執行及結束於該應用程式關閉時。
作業系統102包含:系統資訊收集模組106和應用程式存留期管理模組108。雖然系統資訊收集模組106和應用程式存留期管理模組108經示例說明作為作業系統102的部份,可替代性地,模組106和模組108的一或二者可分離於作業系統102來實施。
系統資訊收集模組106收集關於應用程式104的特性及/或計算裝置100的資源之各種資訊。關於應用程式104的特性的資訊包含(例如):每一應用程式104的年齡。應用程式104的年齡意指為:應用程式104於多久之前(例如就分鐘、小時、天數等等而言)持續在前景中。應用程式被呈現或另外地藉由計算裝置的使用者界面來呈現時係處於前景。已被最小化的應用程式(及可選地應用程式使得應用程式顯示視窗被其它的應用程式的顯示視窗來覆蓋)並不處於前景中,及意指為背景應用程式。關於應用程式104的特性的資訊亦可包含:應用程式104的其它特性,例如多少個應用程式104在計算裝置100上執行的計數。
計算裝置100的資源包含:計算裝置100的硬體及/或軟體資源,例如處理器及/或處理器核心、記憶體、網路連接等等。關於計算裝置100的資源的特性之資訊包含(例如):關於計算裝置100的資源之使用的資訊、描述計算裝置100的資源之特性的資訊等等。舉例而言,計算裝置100的資源的特性可包含:計算裝置100的處理器(或處理器核心)之多少資源被所有的應用程式104集總地使用、計算裝置100的每一處理器(或每一處理器核心)的多少資源被每一個別的應用程式104來使用、在待命清單上(standby list)的記憶體頁面的平均存留期、網路連接的類型(例如特定的網路連接是否為細胞式無線連接、無線區域網路(例如Wi-Fi)連接等等)等等。
應用程式存留期管理模組108包含:應用程式資訊追蹤模組112、觸發模組114、應用程式選擇模組116及關閉模組118。應用程式資訊追蹤模組112從系統資訊收集模組106接收關於應用程式104的特性及/或計算裝置100的資源之資訊。觸發模組114監控由應用程式資訊追蹤模組112接收的資訊,及決定:與應用程式104的特定特性及/或計算裝置100的資源相關聯的臨界值何時符合。當與應用程式104的特定特性及/或計算裝置100的資源相關聯的臨界值符合時,應用程式選擇模組116選擇要被關閉一或多個應用程式104。關閉模組118管理由應用程式選擇模組116選擇的一或多個應用程式的關閉。關閉模組108自動地關閉由應用程式選擇模組116選擇的一或多個應用程式-並不需要接收要被關閉的應用程式的使用者輸入或確認以供關閉模組108來關閉所選擇的一或多個應用程式。
應用程式資訊追蹤模組112維持關於來自系統資訊收集模組106的應用程式104的各種特性及/或計算裝置100的資源之資訊。應用程式資訊追蹤模組112可以規律或不規律的時間間隔(例如每5秒鐘)從系統資訊收集模組106請求此資訊,或替代性地以其它方式從模組106接收此資訊(例如模組112可向模組106註冊以接收訊息或其它資訊的更新)。
在一或多個具體實施例中,由應用程式資訊追蹤模組112維持的資訊包含:每一應用程式104的年齡、在計算裝置100中的每一處理器核心的處理器(中央處理單元或CPU)核心使用、記憶體使用、在計算裝置100中的每一儲存裝置的儲存裝置(例如硬碟)使用及由計算裝置100使用的每一網路連接的網路連接使用。處理器核心使用係(例如)由所有的應用程式104對處理器核心容量的集總使用(例如作為全部處理核心容量的百分比),及/或由每一應用程式104對處理器容量(例如作為全部處理器核心容量的百分比)的個別使用。此處理器核心使用(無論集總的應用程式或個別的應用程式)可被決定,例如藉由對特定數目的時間間隔(例如12個時間間隔)於特定的時間間隔(例如每5秒鐘)的使用作平均。
記憶體使用係(例如)由所有的應用程式104對記憶體的集總使用,及/或由每一應用程式104對記憶體的個別使用。此記憶體使用(無論集總的應用程式或個別的應用程式)可被決定,例如藉由決定:在由作業系統102的記憶體管理器維持的待命清單上記憶體頁面的平均存留期(例如在特定的時間區段(例如前面的數分鐘)、應用程式的壽命等等)。此記憶體使用亦可以不同的方式來決定,例如藉由決定:在用於應用程式的記憶體頁面之工作集的記憶體頁面的平均數目(例如在特定的時間區段(例如前面的數分鐘)、應用程式的壽命等等)。
儲存裝置使用係(例如)由所有的應用程式104對儲存裝置的集總使用,及/或由每一應用程式104對儲存裝置的個別使用。儲存裝置使用(無論集總的應用程式或個別的應用程式)可被決定,例如藉由將對儲存裝置的存取之頻率作平均(例如在特定的時間區段(例如前面的數分鐘)、應用程式的壽命等等)。此儲存裝置使用亦可以不同的方式被決定,例如藉由決定傳輸至儲存裝置及/或從儲存裝置傳輸的資料量(例如在特定的時間區段(例如前面的數分鐘)、應用程式的壽命等等)。
網路連接使用係(例如)由所有的應用程式104對網路連接的集總使用,及/或由每一應用程式104對網路連接的個別使用。網路連接使用(無論集總的應用程式或個別的應用程式)可被決定,例如藉由決定透過網路連接進行通訊(傳送或接收)的資料之平均頻率(例如在特定的時間區段(例如前面的數分鐘)、應用程式的壽命等等)。此網路連接使用亦可以不同的方式被決定,例如藉由決定透過網路連接進行通訊(傳送或接收)的平均資料量(例如在特定的時間區段(例如前面的數分鐘)、應用程式的壽命等等)。
觸發模組114使用由應用程式資訊追蹤模組112維持的資訊以決定:與應用程式104的特定特性及/或計算裝置100的資源相關聯的臨界值何時符合。在一或多個具體實施例中,由應用程式資訊追蹤模組112維持資訊的每一特性具有本身相關聯的臨界值(雖然應可注意到此多個臨界值可為相同的數值)。由觸發模組114使用的臨界值可在觸發模組114中預先組態的,或替代性地提供至觸發模組114,或由觸發模組114另外地從另一元件或模組(計算裝置100或另一裝置的元件或模組)獲得。
在一或多個具體實施例中,若相關的特性具有等於或超過臨界值的數值,則臨界值為符合。在其它具體實施例中,臨界值可以其它的方式來符合,例如相關的特性是否具有超過臨界值的數值。
臨界值可以各種不同的方式來設定,及在一或多個具體實施例中可被設定以維持高度的系統回應和長的電池壽命。當特定的特性符合特定的臨界值時,藉由關閉特定的應用程式,應用程式存留期管理模組108嘗試維持高度的系統回應和長的電池壽命。特定的臨界值可(例如)根據不同裝置的操作的經驗分析來設定。
表格I包含:臨界值的實例,該等臨界值可使用於應用程式104的特定特性,及/或計算裝置100的資源。可瞭解到包含在表格I中的實例為示例,及其它的臨界值及/或其它的特性可被替代性地使用。表格I示例說明:與插入系統的特定特性相關聯的臨界值的實例。
表格II包含:臨界值的另外的實例,該等臨界值可使用於應用程式104的特定特性,及/或計算裝置100的資源。可瞭解到包含在表格II中的實例為示例,及其它的臨界值及/或其它的特性可被替代性地使用。表格II示例說明:與使用電池的系統的特定特性相關聯的臨界值的實例。
回應於:觸發模組114決定臨界值已符合,應用程式選擇模組116選擇一或多個應用程式104被關閉。此選擇係至少部份地根據與超過的特定臨界值相關聯的特性,及因此亦至少部份地根據超過的特定臨界值。當至少一個臨界值符合時,應用程式選擇模組116選擇一或多個應用程式104被關閉。舉例而言,若一個資源(例如處理器使用、記憶體使用等等)的臨界值符合,應用程式選擇模組116選擇一或多個應用程式104被關閉。
在一或多個具體實施例中,應用程式選擇模組116選擇應用程式104被關閉,及提供所選擇的應用程式104的指示至關閉模組118。關閉模組118以各種不同的方式中的任何者來關閉所選擇的應用程式104,例如藉由通訊請求至所選擇的應用程式104以將本身關閉、藉由與作業系統102的其它元件或模組進行通訊以將所選擇的應用程式104之執行終止等等。在所選擇的應用程式104關閉之後,觸發模組114檢查先前符合的臨界值(及導致所選擇的應用程式104被關閉)是否依然符合。若臨界值依然符合,則應用程式選擇模組116選擇另一應用程式104被關閉。然而,若應用程式值依然不符合,則並無額外的應用程式需要被關閉。
可替代性地,並非逐一地選擇應用程式,應用程式選擇模組116可選擇欲被關閉的多個應用程式。舉例而言,應用程式選擇模組116可根據計算裝置100的特定資源,決定特定數目的要繼續執行的應用程式(例如在計算裝置100中的特定數量的隨機存取記憶體(RAM)、在計算裝置100中的特定數量的處理器核心等等)。選擇一或多個應用程式以使得僅有此特定數量的應用程式繼續執行。
應用程式選擇模組116可以各種不同的方式選擇何者應用程式104以被關閉。在一或多個具體實施例中,應用程式選擇模組116從包含在背景中執行的應用程式的一組應用程式中選擇應用程式以被關閉。在前景中執行的應用程式(及因此可能已顯示對使用者為可視見的使用者界面)並不在從其中選擇要被關閉的應用程式的集合中。應用程式是否在前景或背景中執行係該應用程式的特性,該特性係由應用程式存留期管理模組108來維持,及可由應用程式存留期管理模組108從系統資訊收集模組106中擷取。
此外,在一或多個具體實施例中,由應用程式資訊追蹤模組112所維持的應用程式104的特性和計算裝置100的資源係由應用程式選擇模組116獲得。對與已符合的臨界值相關聯的特性而言,該組在背景中執行的應用程式係根據該應用程式此特性的值來優先排序。應用程式模組116從該組在背景中執行的應用程式選擇最具冒犯性的應用程式104。最具冒犯性的應用程式104係針對此特性具有最大或最高值的應用程式。例如,應用程式104具有資源的最高度使用、應用程式104具有最大的年齡值(例如應用程式104具有最老的年齡)等等。最不具冒犯性的應用程式104則為具有資源的最低度使用的應用程式104、具有最年輕的年齡的應用程式等等。舉例而言,若處理器使用臨界值符合,則應用程式選擇模組116選擇具有最大處理器使用的應用程式作為最具冒犯性的應用程式,及選擇此應用程式作為要被關閉的應用程式。例如,若具有5個正在執行的應用程式104,該等應用程式個別地具有20%、5%、4%、4%及3%的處理器使用率,則具有20%的處理器使用率的應用程式為具有處理器的最高度使用的應用程式,及為經選擇要被關閉的應用程式。可替代性地,多個應用程式可經選擇而被關閉(例如具有20%的處理器使用率的應用程式,和具有5%的處理器使用率的應用程式)。
可替代性地,其它的技術可使用以從該組在背景中執行的應用程式裡選擇要被關閉的應用程式。舉例而言,該組在背景中執行的應用程式可根據每一應用程式被使用的頻繁程度(例如當應用程式執行時應用程式在前景執行的時間之多少百分比)、每一應用程式在前景中持續的新近程度等等來優先排序。經選擇作為要被關閉的應用程式之應用程式可為最不常使用的應用程式、最不新近地處於前景的應用程式等等。
再者,在一或多個具體實施例中,一或多個不同類型的應用程式被免除於:被應用程式選擇模組116選擇作為要被關閉的應用程式。應用程式選擇模組116可與另一模組或裝置組態,或替代性地從另一模組或裝置獲得此等一或多個類型的應用程式的指示,該等應用程式免除於由應用程式選擇模組116選擇作為要被關閉的應用程式。特定類型的應用程式可以不同的方式來決定,該等應用程式免除於由應用程式選擇模組116選擇作為要被關閉的應用程式,該決定之步驟係根據應用程式選擇模組116的設計者或計算裝置100的管理者或使用者之所欲者。
應可注意到:雖然在此討論應用程式104的特性及/或計算裝置100的資源和相關的臨界值的各種實例,此等實例僅為示例,及其它的特性可替代性地與在此討論的技術共同使用。舉例而言,可使用例如為在計算裝置100上執行的應用程式104的數目之特性,及觸發模組114在若具有至少一臨界值數目的應用程式104在計算裝置100上執行,則決定為:該臨界值已符合。藉由另一實例的方式,不同的臨界值可與不同類型的網路連接相關聯,例如用於細胞式無線網路連接使用的臨界值,和用於Wi-Fi網路連接使用的另一臨界值。
第2圖根據一或多個具體實施例示例說明實例系統200,該實例系統實施應用程式存留期管理。系統200可藉由(例如)第1圖的計算裝置100來實施。系統200包含:應用程式存留期管理模組202,該應用程式存留期管理模組可例如為第1圖的應用程式存留期管理模組108。
應用程式存留期管理模組202從系統資訊收集模組206接收應用程式及/或資源特性204。此等應用程式及/或資源特性可為(例如)關於應用程式104的各種特性及/或計算裝置100的資源且由第1圖的應用程式資訊追蹤模組112接收的資訊。此等應用程式及/或資源特性204可藉由另一元件或模組接收,例如第1圖的系統資訊收集模組106。
應用程式存留期管理模組202亦從使用者界面管理模組210接收應用程式識別器208。應用程式識別器208識別例如目前在前景中執行的應用程式。使用者界面管理模組210維持目前在前景中執行的應用程式之記錄,及提供在此記錄中的應用程式作為應用程式識別器208。此等應用程式識別器可藉由另一元件或模組來接收,例如第1圖的系統資訊收集模組106。
應用程式存留期管理模組202使用一或多個應用程式/資源特性204和應用程式識別器208以選擇要被關閉的一或多個應用程式212。如同前文所討論者,此等一或多個應用程式可以不同的方式來選擇。此等應用程式212可為(例如)第1圖的一或多個應用程式104。應用程式存留期管理模組202通訊關閉請求或命令214至一或多個應用程式212。
第3圖係根據一或多個具體實施例的流程圖,該流程圖示例說明用於實施應用程式存留期管理的裝置之實例程序300。程序300藉由計算裝置來進行,例如第1圖的計算裝置100,及可以軟體、韌體、硬體或所述者組合來實施。程序300經顯示作為一組步驟,及不限於經顯示用以執行各種步驟的操作之順序。程序300係用於實施應用程式存留期管理的裝置之實例程序;在此參照不同的圖式來包含實施應用程式存留期管理的額外的討論。
在程序300中,作出是否超過臨界值的檢查(步驟302)。如同前文所討論者,此臨界值係與在計算裝置上執行的應用程式之特性及/或計算裝置的資源相關聯的臨界值。
若未超過任何臨界值,則在計算裝置上執行的應用程式被允許繼續在計算裝置上執行(步驟304)。然後重複步驟302(例如在規律或不規律的時間間隔)。
然而,若超過臨界值,則選擇一或多個要被關閉的應用程式(步驟306)。如同前文所討論者,可以不同的方式選擇此等一或多個應用程式。
關閉在步驟306中選擇的一或多個應用程式(步驟308)。然後重複步驟302(例如在規律或不規律的時間間隔)。
第4圖係根據一或多個具體實施例的流程圖,該流程圖示例說明實例程序400,該實例程序用以選擇要被關閉的一或多個應用程式。程序400藉由計算裝置來進行,例如第1圖的計算裝置100,及可以軟體、韌體、硬體或所述者組合來實施。程序400經顯示作為一組步驟,及不限於經顯示用以執行各種步驟的操作之順序。程序400係用於選擇要被關閉的一或多個應用程式之實例程序;在此參照不同的圖式來包含選擇要被關閉的一或多個應用程式之額外的討論。
回應於與在計算裝置上執行的應用程式之特性及/或計算裝置的資源相關聯的臨界值已符合,而一般性地啟始程序400。在程序400中,產生背景應用程式的清單(步驟402)。背景應用程式為在計算裝置上於背景中執行的應用程式。
可選擇地,免除於關閉的一或多個應用程式可從所產生的清單中移除(步驟404)。如同前文所討論者,不同類型的應用程式可免除於關閉。
對在所產生的清單上維持的應用程式進行優先排序(步驟406)。應用程式可以不同的方式進行優先排序,例如根據特定資源的使用(例如與已符合的臨界值相關聯的資源)、年齡、使用的頻率等等。
在所產生的清單上選擇應用程式(步驟408)。在步驟408中選擇的應用程式係優先排序為最高的應用程式(例如具有資源的最高度使用、具有最老的年齡、具有最低頻率的使用等等)。
關閉所選擇的應用程式(步驟410)。如同前文所討論者,可以不同的方式關閉所選擇的應用程式。
然後作出關於臨界值是否依然符合的檢查(步驟412)。若臨界值依然符合,則程序400返回至步驟408以選擇另一應用程式。可替代性地,程序400可返回至步驟402以重新產生背景應用程式的清單。
若臨界值依然不符合,則程序400完成(步驟414)。此外,若所有可被關閉的應用程式(例如所有的背景應用程式、並未免除於關閉的所有應用程式等等)已被關閉,則完成程序400(步驟414)(即使臨界值依然符合)。
程序400參照產生清單和從免除於關閉的清單應用程式中移除來討論。可替代性地,可產生和優先排序清單的背景應用程式,在所產生的清單中選擇應用程式,則僅若在所選擇的應用程式並未免除於關閉時關閉該應用程式。
在此討論的技術支援各種使用情況。舉例而言,若特定的背景應用程式正使用處理器(或記憶體)的大量的容量,此特定的背景應用程式可被選擇為要被關閉的應用程式。因此,背景應用程式(該背景應用程式並未處於前景中及目前並不由裝置100的使用者來使用)被自動地關閉,及由此背景應用程式使用的資源經釋放以供其它的應用程式來使用。並非簡單地將最不新近地使用的應用程式關閉,具有高機率以將資源釋放以供其它應用程式使用的應用程式係被關閉的應用程式。
應可注意到:在此討論的應用程式存留期管理技術減輕使用者在他或她的計算裝置上管理多個應用程式的一些負擔。使用者可如同他或她所欲者來執行應用程式,而無需擔心當他或她不再使用彼等應用程式時關閉彼等應用程式。而是,在此討論的應用程式存留期管理技術為使用者自動地關閉應用程式,小心地關閉背景應用程式而非目前由使用者使用的應用程式。
第5圖根據一或多個具體實施例示例說明實例計算裝置500,該計算裝置經組態以實施應用程式存留期管理。計算裝置500可為(例如)第1圖的計算裝置100。
計算裝置500包含:一或多個處理器或處理單元502(其中每一者可包含:一或多個處理器核心)、一或多個電腦可讀取媒體504,該電腦可讀取儲存媒體可包含:一或多個記憶體及/或儲存元件506、一或多個輸入/輸出(I/O)裝置508、匯流排510,該匯流排允許各種元件和裝置與另一者進行通訊。電腦可讀取媒體504及/或一或多個I/O裝置508可被包含作為計算裝置500的部份,或替代性地耦合至計算裝置500。匯流排510代表數種類型的匯流排架構的一或多者,該等匯流排架構包含:記憶體匯流排或記憶體控制器、週邊匯流排、加速繪圖埠、處理器或本端匯流排及使用各種不同的匯流排架構者等等。匯流排510可包含:有線及/或無線匯流排。
記憶體/儲存元件506代表一或多個電腦儲存媒體。元件506可包含:揮發性媒體(例如隨機存取記憶體(RAM))及/或非揮發性媒體(例如唯讀記憶體(ROM)、快閃記憶體、光碟、磁碟等等)。元件506可包含:固定的媒體(例如RAM、ROM、固定的硬碟機等等)和可移除媒體(例如快閃記憶體碟、可移除硬碟、光碟等等)。
在此討論的技術可以軟體來實施,該軟體具有可由一或多個處理單元502執行的指令。可瞭解到不同的指令可儲存於計算裝置500的不同元件中,例如在處理單元502中、在處理單元502的各種快取記憶體中、在裝置500的其它快取記憶體中(未示出)、在其它電腦可讀取媒體上等等。此外,可瞭解到:指令在計算裝置500中儲存的位置可隨時間改變。
一或多個輸入/輸出裝置508允許使用者輸入命令或資訊至計算裝置500,及亦允許資訊被呈現至使用者及/或其它元件或裝置。輸入裝置的實例包含:鍵盤、游標控制裝置(例如滑鼠)、麥克風、掃描器等等。輸出裝置的實例包含:顯示裝置(例如螢幕或投影機)、揚聲器、印表機、網路卡等等。
在此描述的各種技術可以軟體或程式模組的一般性上下文來描述。一般而言,軟體包含:常式、程式、物件、元件、資料結構及執行特定任務或實施特定抽象資料型別者等等。此等模組和技術的實施可儲存在一些形式的電腦可讀取媒體上及透過一些形式的電腦可讀取媒體傳遞。電腦可讀取媒體可為任何可獲得使用的媒體或可由計算裝置存取的媒體。藉由實例方式(而非限制),電腦可讀取媒體可包含(但不限於):「電腦儲存媒體」和「通訊媒體」。
「電腦儲存媒體」包含:揮發性和非揮發性、可移除和不可移除媒體,該等媒體可以任何方法或技術來實施以用於儲存資訊,例如電腦可讀取指令、資料結構、程式模組或其它資料。電腦儲存媒體包含(但不限於)RAM、ROM、EEPROM、快閃記憶體或其它記憶體技術、CD-ROM、數位影音光碟(DVD)或其它光學儲存、磁匣、磁帶、磁碟儲存或其它磁性儲存裝置或其它可使用以儲存所欲資訊和可由電腦存取的任何其它媒體。
「通訊媒體」典型地體現電腦可讀取指令、資料結構、程式模組或其它在調變資料訊號中的資料,例如載波或其它傳輸機制。通訊媒體亦包含:任何資訊傳送媒體。詞彙「調變資料訊號」意指:訊號,該訊號具有一或多個特性集或以此方式以將資訊編碼在該訊號中而改變。藉由實例方式(而非限制),通訊媒體包含:有線媒體(諸如有線網路或直接線路連接)及無線媒體(諸如聲音、RF、紅外線及其它無線媒體)。任何前述的組合亦被包含於電腦可讀取媒體的範圍內。
一般而言,在此描述的任何功能或技術可使用軟體、韌體、硬體(諸如固定的邏輯電路)、手動處理或此等實施的組合來實施。在此使用的詞彙「模組」和「元件」一般性地代表軟體、韌體、硬體或所述者組合。在軟體實施的情況中,模組或元件代表當在處理器上(例如CPU或數個CPU)執行時進行特定任務的程式代碼。程式代碼可儲存在一或多個電腦可讀取記憶體裝置中,進一步的描述可參閱第5圖。在此描述的應用程式存留期管理技術的特徵係平台獨立的,意指為技術可在具有各種處理器的各種商業計算平台上實施。
雖然本發明係以特定於結構化特徵及/或方法步驟的語言來描述,可瞭解到界定在申請專利範圍中的發明並不必然地限制於前文所描述的特定特徵或步驟。而是,在前文描述的特定特徵和步驟經揭示作為實施申請專利範圍的實例形式。
100...計算裝置
102...作業系統
104...應用程式
106...系統資訊收集模組
108...應用程式存留期管理模組
112...應用程式資訊追蹤模組
114...觸發模組
116...應用程式選擇模組
118...關閉模組
200...系統
202...應用程式存留期管理模組
204...應用程式/資源特性
206...系統資訊收集模組
208...應用程式識別器
210...使用者界面管理模組
212...應用程式
214...關閉
500...計算裝置
502...處理器或處理單元
504...電腦可讀取儲存媒體
506...記憶體及/或儲存元件
508...輸入/輸出(I/O)裝置
510...匯流排
在全部圖式中使用相同的編號來參照類似的特徵。
第1圖根據一或多個具體實施例示例說明實例計算裝置,該實例計算裝置實施應用程式存留期管理。
第2圖根據一或多個具體實施例示例說明實例系統,該實例系統實施應用程式存留期管理。
第3圖係根據一或多個具體實施例的流程圖,該流程圖示例說明用於實施應用程式存留期管理的裝置之實例程序。
第4圖係根據一或多個具體實施例的流程圖,該流程圖示例說明實例程序,該實例程序用以選擇要被關閉的一或多個應用程式。
第5圖根據一或多個具體實施例示例說明實例計算裝置,該實例計算裝置可經組態以實施應用程式存留期管理。
100...計算裝置
102...作業系統
104...應用程式
106...系統資訊收集模組
108...應用程式存留期管理模組
112...應用程式資訊追蹤模組
114...觸發模組
116...應用程式選擇模組
118...關閉模組
Claims (19)
- 一種用於在執行多個應用程式的一計算裝置中之方法,該方法包含以下步驟:判定多個臨界值,該等多個臨界值中的每一者係與該等多個應用程式中的一者之一特性相關聯或(either)與該計算裝置的一資源的一特性相關聯;調整該等多個臨界值,該調整是至少部分地根據該計算裝置是否是運作為一插入系統(plugged-in system)或是一使用電池系統(on-battery system);檢查該等多個臨界值中的一臨界值是否已符合,該臨界值與該計算裝置的一週期性的網路使用量相關聯;若該臨界值並未符合,允許該等多個應用程式繼續在該計算裝置上執行;及若該臨界值已符合,則至少部份地根據該計算裝置的該周期性網路使用量,選擇要被關閉的該等多個應用程式中的一或更多者;及關閉該一或更多個應用程式。
- 如請求項1所述之方法,進一步包括以下步驟:檢查與由該等多個應用程式對該計算裝置的一處理器核心的一使用相關聯的一臨界值是否已符合;及若與由該等多個應用程式對該處理器核心的該使用相 關聯的該臨界值已符合,則至少部份地根據該處理器的該使用,選擇要被關閉的該等多個應用程式中的一或更多個額外的應用程式並關閉該一或更多個額外的應用程式。
- 如請求項1所述之方法,進一步包括以下步驟:檢查與由該等多個應用程式中的一單一應用程式對該計算裝置的一處理器核心的一使用相關聯的一臨界值是否已符合;及若與由該單一應用程式對該處理器核心的該使用相關聯的該臨界值已符合,則關閉該單一應用程式。
- 如請求項1所述之方法,進一步包括以下步驟:檢查與該計算裝置的記憶體的一使用相關聯的一臨界值是否已符合;及若與該記憶體的該使用相關聯的該臨界值已符合,則至少部分地根據該記憶體的該使用,選擇要被關閉的該等多個應用程式中的一或更多個額外的應用程式並關閉該一或更多個額外的應用程式。
- 如請求項1所述之方法,進一步包括以下步驟:檢查與該計算裝置的一儲存裝置的一使用相關聯的一臨界值是否已符合;及若與該儲存裝置的該使用相關聯的該臨界值已符合, 則至少部分地根據該儲存裝置的該使用,選擇要被關閉的該等多個應用程式中的一或更多個額外的應用程式並關閉該一或更多個額外的應用程式。
- 如請求項1所述之方法,進一步包括以下步驟:檢查與該等多個應用程式中的該一者之一年齡相關聯的一臨界值是否已符合,其中該等多個應用程式中的該一者之該年齡指示:該等多個應用程式中的該一者最後(last)在前景中是在多久之前;及若與該等多個應用程式中的該一者之該年齡相關聯的該臨界值是否已符合,則關閉該等多個應用程式中的該一者。
- 如請求項1所述之方法,其中該選擇要被關閉的該等多個應用程式中的一或更多個之步驟包含以下步驟:識別免除於被關閉的該等多個應用程式中的至少一者,其中該等多個應用程式中的該至少一者包含:在前景中執行的應用程式;及在該等多個應用程式中的該至少一者之外,選擇一或更多個應用程式作為要被關閉的該等多個應用程式中的該一或更多者。
- 如請求項1所述之方法,進一步包括以下步驟:檢查與該計算裝置的一資源相關聯,不同於週期性的 網路使用的一臨界值是否已符合;及選擇該等多個應用程式中具有對該資源的最大使用的一或更多個額外的應用程式並關閉該一或更多個額外的應用程式。
- 一種具有儲存於其上的多個指令的電腦儲存記憶體,當該等指令由一計算裝置的一或更多個處理器執行時,使得該一或更多個處理器進行以下操作包括:產生在該計算裝置上執行的背景應用程式的一清單;判定與該計算裝置的一週期性的網路使用相關聯的一臨界值,若該計算裝置是運作為一使用電池系統(on-battery system),則該臨界值具有一第一臨界值,且若該計算裝置是運作為一插入系統(plugged-in system),則該臨界值具有一第二臨界值,該第一臨界值與該第二臨界值具有不同的臨界值;優先排序(prioritizing)在該清單上的該等背景應用程式,使得超過一週期性的網路使用量的背景應用程式具有一較低的優先權;在背景應用程式的該清單上選擇具有一低優先權的一應用程式;自動地關閉所選擇的該應用程式;及重複該選擇一應用程式及該關閉所選擇的該應用程式直到該計算裝置的該週期性的網路使用不符合由上述判定所判定的該臨界值。
- 如請求項9所述之電腦儲存記憶體,其中在該清單上選擇該應用程式之操作包括:在該清單上選擇具有一最大週期性的網路使用量的該應用程式。
- 如請求項9所述之電腦儲存記憶體,其中選擇該應用程式之操作包括:在背景應用程式中的該清單上選擇多個應用程式,及其中關閉所選擇的該應用程式之操作包括關閉所選擇的該等多個應用程式。
- 如請求項9所述之電腦儲存記憶體,其中在該清單上的該等背景應用程式進一步地被至少部分的根據該計算裝置的一處理器核心的使用而優先排序(prioritized)。
- 如請求項9所述之電腦儲存記憶體,其中在該清單上的該等背景應用程式進一步地被至少部分的根據該計算裝置的一儲存裝置的使用而優先排序(prioritized)。
- 如請求項9所述之電腦儲存記憶體,其中若該週期性的網路使用是在一細胞式無線網路上,則該臨界值為一第三臨界值,且若該週期性的網路使用是在一Wi-Fi網路上,則該臨界值為一第四臨界值,其中該第三臨界值與該第四臨界值為不同的臨界值。
- 如請求項9所述之電腦儲存記憶體,其中在該清單上的該等背景應用程式進一步地被至少部分的根據該計算裝置的記憶體的使用而優先排序(prioritized)。
- 如請求項9所述之電腦儲存記憶體,其中在該清單上的該等背景應用程式進一步地被至少部分的根據該等背景應用程式的一年齡而優先排序(prioritized),其中該等背景應用程式的該年齡指示:該等應用程式最後(last)在前景中是在多久之前。
- 一種用於在執行多個應用程式的一計算裝置中之方法,該方法包含以下步驟:判定多個臨界值,包括:一第一臨界值,該第一臨界值與該等多個應用程式的一者的一年齡相關聯;一第二臨界值,該第二臨界值與該計算裝置的一處理器核心的使用相關聯;一第三臨界值,該第三臨界值與該計算裝置的一儲存裝置的使用相關聯;及一第四臨界值,該第四臨界值與該計算裝置的週期性的網路使用相關聯;調整該等多個臨界值,該調整是至少部分地根據該計算裝置是否是運作為一插入系統(plugged-in system)或是一使用電池系統(on-battery system); 檢查該等多個臨界值中的一臨界值是否已符合;若該等多個臨界值中的任何一者皆不符合,允許該等多個應用程式繼續在該計算裝置上執行;若該第一臨界值已符合,則從該等多個應用程式中選擇具有一最老年齡的一第一應用程式並關閉該第一應用程式;若該第二臨界值已符合,則從該等多個應用程式中選擇具有一最大處理器核心使用的一第二應用程式並關閉該第二應用程式;若該第三臨界值已符合,則從該等多個應用程式中選擇具有一最大儲存裝置使用的一第三應用程式並關閉該第三應用程式;及若該第四臨界值已符合,則從該等多個應用程式中選擇具有一最大週期性的網路使用量的一第四應用程式並關閉該第四應用程式。
- 如請求項17所述之方法,進一步包括以下步驟:在該計算裝置上運行一經驗分析(empirical analysis);及其中該等多個臨界值的該判定是至少部份地根據該經驗分析。
- 如請求項17所述之方法,進一步包括以下步驟:至少部分地根據該週期性的網路使用是在一細胞式無 線網路上或是該週期性的網路使用是在一Wi-Fi網路上,而調整該第四臨界值。
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/911,450 US8635630B2 (en) | 2010-10-25 | 2010-10-25 | Application lifetime management |
Publications (2)
Publication Number | Publication Date |
---|---|
TW201220180A TW201220180A (en) | 2012-05-16 |
TWI533205B true TWI533205B (zh) | 2016-05-11 |
Family
ID=45974105
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
TW100134404A TWI533205B (zh) | 2010-10-25 | 2011-09-23 | 應用程式存留期管理 |
Country Status (10)
Country | Link |
---|---|
US (1) | US8635630B2 (zh) |
EP (1) | EP2633406A4 (zh) |
JP (1) | JP5984824B2 (zh) |
KR (1) | KR101827030B1 (zh) |
CN (1) | CN102436605B (zh) |
AU (1) | AU2011323985B2 (zh) |
CA (1) | CA2814604C (zh) |
RU (1) | RU2599967C2 (zh) |
TW (1) | TWI533205B (zh) |
WO (1) | WO2012060955A2 (zh) |
Families Citing this family (57)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP2130190A1 (en) * | 2006-10-27 | 2009-12-09 | Cecure Gaming Limited | Online gaming system |
US20120209413A1 (en) | 2011-02-14 | 2012-08-16 | Microsoft Corporation | Background Audio on Mobile Devices |
US9176759B1 (en) * | 2011-03-16 | 2015-11-03 | Google Inc. | Monitoring and automatically managing applications |
JP5659066B2 (ja) * | 2011-03-31 | 2015-01-28 | Kddi株式会社 | サービス制御装置およびサービス制御プログラム |
US9465427B2 (en) * | 2011-06-30 | 2016-10-11 | International Business Machines Corporation | Software-centric power management by indirectly determining that user is not actively using computer program running on computing device |
US8997171B2 (en) | 2011-08-19 | 2015-03-31 | Microsoft Technology Licensing, Llc | Policy based application suspension and termination |
US9032413B2 (en) * | 2011-09-01 | 2015-05-12 | Microsoft Technology Licensing, Llc | Decoupling background work and foreground work |
US9049660B2 (en) * | 2011-09-09 | 2015-06-02 | Microsoft Technology Licensing, Llc | Wake pattern management |
US8892710B2 (en) | 2011-09-09 | 2014-11-18 | Microsoft Corporation | Keep alive management |
US8578394B2 (en) * | 2011-09-09 | 2013-11-05 | Microsoft Corporation | Exempting applications from suspension |
US8806250B2 (en) | 2011-09-09 | 2014-08-12 | Microsoft Corporation | Operating system management of network interface devices |
US8990534B2 (en) | 2012-05-31 | 2015-03-24 | Apple Inc. | Adaptive resource management of a data processing system |
US8994827B2 (en) | 2012-11-20 | 2015-03-31 | Samsung Electronics Co., Ltd | Wearable electronic device |
US10551928B2 (en) | 2012-11-20 | 2020-02-04 | Samsung Electronics Company, Ltd. | GUI transitions on wearable electronic device |
US10185416B2 (en) | 2012-11-20 | 2019-01-22 | Samsung Electronics Co., Ltd. | User gesture input to wearable electronic device involving movement of device |
CN102946486A (zh) * | 2012-11-20 | 2013-02-27 | 惠州Tcl移动通信有限公司 | 一种基于手机的后台应用自动清理方法及手机 |
US10423214B2 (en) | 2012-11-20 | 2019-09-24 | Samsung Electronics Company, Ltd | Delegating processing from wearable electronic device |
US11372536B2 (en) | 2012-11-20 | 2022-06-28 | Samsung Electronics Company, Ltd. | Transition and interaction model for wearable electronic device |
US11157436B2 (en) | 2012-11-20 | 2021-10-26 | Samsung Electronics Company, Ltd. | Services associated with wearable electronic device |
US9477313B2 (en) | 2012-11-20 | 2016-10-25 | Samsung Electronics Co., Ltd. | User gesture input to wearable electronic device involving outward-facing sensor of device |
US11237719B2 (en) * | 2012-11-20 | 2022-02-01 | Samsung Electronics Company, Ltd. | Controlling remote electronic device with wearable electronic device |
CN103902357A (zh) * | 2012-12-27 | 2014-07-02 | 富泰华工业(深圳)有限公司 | 应用程序管理系统及方法 |
KR102083316B1 (ko) | 2013-04-24 | 2020-04-14 | 삼성전자주식회사 | 사용자 디바이스의 메모리 관리 방법 및 장치 |
US9749209B2 (en) | 2013-11-01 | 2017-08-29 | The Nielsen Company (Us), Llc | Methods and apparatus to credit background applications |
JP2015106167A (ja) * | 2013-11-28 | 2015-06-08 | ソニー株式会社 | 情報処理装置、情報処理方法および記憶媒体 |
KR102148948B1 (ko) * | 2013-12-06 | 2020-08-27 | 삼성전자주식회사 | 전자 장치의 멀티 태스킹 방법 및 그 전자 장치 |
US10691332B2 (en) | 2014-02-28 | 2020-06-23 | Samsung Electronics Company, Ltd. | Text input on an interactive display |
US9871741B2 (en) | 2014-03-10 | 2018-01-16 | Microsoft Technology Licensing, Llc | Resource management based on device-specific or user-specific resource usage profiles |
US9760138B2 (en) | 2014-04-25 | 2017-09-12 | Microsoft Technology Licensing, Llc | Load scheduling in multi-battery devices |
US9690685B2 (en) * | 2014-05-30 | 2017-06-27 | Apple Inc. | Performance management based on resource consumption |
US10552179B2 (en) | 2014-05-30 | 2020-02-04 | Apple Inc. | Resource management with dynamic resource policies |
CN104239094B (zh) * | 2014-08-29 | 2017-12-08 | 小米科技有限责任公司 | 后台应用程序的控制方法、装置及终端设备 |
US9696782B2 (en) | 2015-02-09 | 2017-07-04 | Microsoft Technology Licensing, Llc | Battery parameter-based power management for suppressing power spikes |
US10158148B2 (en) | 2015-02-18 | 2018-12-18 | Microsoft Technology Licensing, Llc | Dynamically changing internal state of a battery |
US9748765B2 (en) | 2015-02-26 | 2017-08-29 | Microsoft Technology Licensing, Llc | Load allocation for multi-battery devices |
US9465734B1 (en) | 2015-04-08 | 2016-10-11 | Apple Inc. | Coalition based memory management |
US9983887B2 (en) | 2015-06-05 | 2018-05-29 | Apple Inc. | Memory management of data processing systems |
WO2017016590A1 (en) * | 2015-07-27 | 2017-02-02 | Hewlett-Packard Development Company, L P | Scheduling heterogenous processors |
US9971664B2 (en) * | 2015-08-27 | 2018-05-15 | Vmware, Inc. | Disaster recovery protection based on resource consumption patterns |
US9939862B2 (en) | 2015-11-13 | 2018-04-10 | Microsoft Technology Licensing, Llc | Latency-based energy storage device selection |
US10061366B2 (en) | 2015-11-17 | 2018-08-28 | Microsoft Technology Licensing, Llc | Schedule-based energy storage device selection |
US9793570B2 (en) | 2015-12-04 | 2017-10-17 | Microsoft Technology Licensing, Llc | Shared electrode battery |
CN107291549B (zh) * | 2016-03-31 | 2020-11-24 | 阿里巴巴集团控股有限公司 | 一种管理应用程序的方法及装置 |
CN107766128B (zh) * | 2016-08-17 | 2021-01-29 | 华为技术有限公司 | 一种启动应用的方法及装置 |
US10169576B2 (en) | 2016-11-15 | 2019-01-01 | International Business Machines Corporation | Malware collusion detection |
CN106791152B (zh) * | 2016-12-30 | 2019-08-27 | Oppo广东移动通信有限公司 | 一种通信方法及移动终端 |
KR102365227B1 (ko) * | 2017-03-21 | 2022-02-22 | 삼성전자 주식회사 | 전자장치 및 그 제어방법 |
US10397096B2 (en) | 2017-04-28 | 2019-08-27 | International Business Machines Corporation | Path resolution in InfiniBand and ROCE networks |
US10778767B2 (en) | 2017-04-28 | 2020-09-15 | International Business Machines Corporation | Persistent memory replication in RDMA-capable networks |
US11243899B2 (en) * | 2017-04-28 | 2022-02-08 | International Business Machines Corporation | Forced detaching of applications from DMA-capable PCI mapped devices |
WO2018214083A1 (zh) * | 2017-05-25 | 2018-11-29 | 深圳配天智能技术研究院有限公司 | 一种程序文件显示方法、终端及计算机存储介质 |
CN107222914B (zh) * | 2017-06-14 | 2020-09-29 | Oppo广东移动通信有限公司 | 应用控制方法及相关产品 |
EP3732570A4 (en) | 2017-11-10 | 2021-11-03 | R-Stor Inc. | SYSTEM AND PROCESS FOR REDUCING RESOURCES PROVIDED |
KR102492996B1 (ko) | 2018-06-08 | 2023-01-31 | 삼성전자주식회사 | 외부 입력을 이용하여 백그라운드 태스크를 처리하는 전자 장치 및 그 저장 매체 |
US11966588B2 (en) * | 2021-10-26 | 2024-04-23 | Google Llc | Flash memory usage management |
KR20230080535A (ko) * | 2021-11-30 | 2023-06-07 | 삼성전자주식회사 | 메모리 회수 방법 및 장치 |
WO2024154996A1 (ko) * | 2023-01-17 | 2024-07-25 | 삼성전자 주식회사 | 프로세서의 cpu들에 프로세스들을 할당하는 전자 장치 |
Family Cites Families (30)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4224664A (en) | 1976-05-07 | 1980-09-23 | Honeywell Information Systems Inc. | Apparatus for detecting when the activity of one process in relation to a common piece of information interferes with any other process in a multiprogramming/multiprocessing computer system |
US5944829A (en) | 1996-09-30 | 1999-08-31 | Intel Corporation | Adjusting software characteristics by user interface based upon battery level and the amount of time the user wants the battery to last |
US6910210B1 (en) * | 1998-11-24 | 2005-06-21 | Microsoft Corp. | System and method for terminating applications |
US6834386B1 (en) | 1999-07-16 | 2004-12-21 | Microsoft Corporation | Method and system for regulating background tasks using performance measurements |
US20030187857A1 (en) | 2002-03-29 | 2003-10-02 | Ford Daniel E. | Computer resource access system and method |
US6910106B2 (en) * | 2002-10-04 | 2005-06-21 | Microsoft Corporation | Methods and mechanisms for proactive memory management |
US7538762B2 (en) * | 2003-09-30 | 2009-05-26 | Intel Corporation | Switching display update properties upon detecting a power management event |
KR20060135621A (ko) * | 2003-10-10 | 2006-12-29 | 코닌클리케 필립스 일렉트로닉스 엔.브이. | 블루레이 디스크용 자바 생명주기 모델 |
US8275802B2 (en) | 2004-06-17 | 2012-09-25 | International Business Machines Corporation | Optimized least recently used lookup cache |
US20060136882A1 (en) | 2004-12-17 | 2006-06-22 | Nokia Corporation | System and method for background JAVA application resource control |
JP4060322B2 (ja) * | 2005-03-28 | 2008-03-12 | 三菱電機株式会社 | アプリケーション管理装置およびそのソフトウェアを格納した記憶媒体 |
JP2007013315A (ja) * | 2005-06-28 | 2007-01-18 | Toshiba Corp | 情報処理装置および動画像再生方法 |
JP4738412B2 (ja) | 2005-07-12 | 2011-08-03 | 富士通株式会社 | 共用管理プログラム、共用管理方法、端末装置、及び共用管理システム |
US20070245163A1 (en) | 2006-03-03 | 2007-10-18 | Yung-Hsiang Lu | Power management in computer operating systems |
US7584376B2 (en) | 2006-08-23 | 2009-09-01 | Palm, Inc. | Method and apparatus for power management |
US8954045B2 (en) * | 2006-09-29 | 2015-02-10 | Qualcomm Incorporated | Method and apparatus for managing resources at a wireless device |
EP2130190A1 (en) | 2006-10-27 | 2009-12-09 | Cecure Gaming Limited | Online gaming system |
US7827358B2 (en) | 2007-01-07 | 2010-11-02 | Apple Inc. | Memory management methods and systems |
US7853812B2 (en) | 2007-02-07 | 2010-12-14 | International Business Machines Corporation | Reducing power usage in a software application |
US7890959B2 (en) | 2007-03-30 | 2011-02-15 | Sap Ag | System and method for message lifetime management |
US9003394B2 (en) | 2007-07-10 | 2015-04-07 | Ricoh Company, Ltd. | Program determining apparatus and program determining method |
US8510743B2 (en) | 2007-10-31 | 2013-08-13 | Google Inc. | Terminating computer applications |
US9027027B2 (en) | 2008-06-09 | 2015-05-05 | Microsoft Technology Licensing, Llc | Thread management based on device power state |
US8566565B2 (en) | 2008-07-10 | 2013-10-22 | Via Technologies, Inc. | Microprocessor with multiple operating modes dynamically configurable by a device driver based on currently running applications |
US8706863B2 (en) * | 2008-07-18 | 2014-04-22 | Apple Inc. | Systems and methods for monitoring data and bandwidth usage |
US8510577B2 (en) | 2008-07-28 | 2013-08-13 | Microsoft Corporation | Reducing power consumption by offloading applications |
US8479202B2 (en) * | 2009-02-06 | 2013-07-02 | International Business Machines Corporation | Method and system for autonomic application program spawning in a computing environment |
US8769139B2 (en) | 2010-01-29 | 2014-07-01 | Clarendon Foundation, Inc. | Efficient streaming server |
US20120144331A1 (en) | 2010-12-03 | 2012-06-07 | Ari Tolonen | Method for Arranging Application Windows on a Display |
US8997171B2 (en) | 2011-08-19 | 2015-03-31 | Microsoft Technology Licensing, Llc | Policy based application suspension and termination |
-
2010
- 2010-10-25 US US12/911,450 patent/US8635630B2/en active Active
-
2011
- 2011-09-23 TW TW100134404A patent/TWI533205B/zh not_active IP Right Cessation
- 2011-10-02 CA CA2814604A patent/CA2814604C/en active Active
- 2011-10-02 AU AU2011323985A patent/AU2011323985B2/en active Active
- 2011-10-02 KR KR1020137010456A patent/KR101827030B1/ko active IP Right Grant
- 2011-10-02 WO PCT/US2011/054514 patent/WO2012060955A2/en active Application Filing
- 2011-10-02 JP JP2013536637A patent/JP5984824B2/ja active Active
- 2011-10-02 RU RU2013119123/08A patent/RU2599967C2/ru active
- 2011-10-02 EP EP11838413.0A patent/EP2633406A4/en not_active Ceased
- 2011-10-25 CN CN201110327254.0A patent/CN102436605B/zh active Active
Also Published As
Publication number | Publication date |
---|---|
KR20130127445A (ko) | 2013-11-22 |
WO2012060955A2 (en) | 2012-05-10 |
US8635630B2 (en) | 2014-01-21 |
AU2011323985A1 (en) | 2013-05-02 |
WO2012060955A3 (en) | 2012-07-19 |
AU2011323985B2 (en) | 2014-10-09 |
CA2814604A1 (en) | 2012-05-10 |
JP2013542530A (ja) | 2013-11-21 |
RU2599967C2 (ru) | 2016-10-20 |
CA2814604C (en) | 2018-10-23 |
CN102436605A (zh) | 2012-05-02 |
EP2633406A2 (en) | 2013-09-04 |
US20120102504A1 (en) | 2012-04-26 |
JP5984824B2 (ja) | 2016-09-06 |
TW201220180A (en) | 2012-05-16 |
EP2633406A4 (en) | 2016-05-04 |
CN102436605B (zh) | 2014-10-22 |
KR101827030B1 (ko) | 2018-02-07 |
RU2013119123A (ru) | 2014-10-27 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
TWI533205B (zh) | 應用程式存留期管理 | |
US11204806B2 (en) | Systems and methods for user adaptive resource management | |
US7596705B2 (en) | Automatically controlling processor mode of multi-core processor | |
CA2636908C (en) | System and method for portable power source management | |
US20130227571A1 (en) | Virtual machine and/or multi-level scheduling support on systems with asymmetric processor cores | |
US8429666B2 (en) | Computing platform with resource constraint negotiation | |
JP2013509658A (ja) | 将来の使用推量に基づく記憶メモリの割り当て | |
CN110895524B (zh) | redis满载时键的复合过期方法、装置、服务器及存储介质 | |
US9747111B2 (en) | Task execution on a managed node based on compliance with execution policy | |
WO2021093365A1 (zh) | 一种gpu显存管理控制方法及相关装置 | |
JP2006351004A (ja) | 携帯端末機のメモリ管理方法 | |
US20120260081A1 (en) | Adjusting Device Performance Based on Processing Profiles | |
US10114438B2 (en) | Dynamic power budgeting in a chassis | |
US20140149057A1 (en) | Estimating the battery life of a portable electronic device based on usage logs | |
CN117130454B (zh) | 功耗调整方法和电子设备 | |
US8281091B2 (en) | Automatic selection of storage volumes in a data storage system | |
CN111107429A (zh) | 提高电视系统性能的方法、装置及计算机可读存储介质 | |
JP2009205548A (ja) | バックアップシステム | |
CN111090627B (zh) | 基于池化的日志存储方法、装置、计算机设备及存储介质 | |
TWI731504B (zh) | 電子裝置與系統服務管控方法 | |
CN114860151B (zh) | 控制多缓存系统刷盘的方法以及装置 | |
WO2024093491A9 (zh) | 一种性能调控方法及电子设备 | |
JP6491995B2 (ja) | システム設計支援装置およびシステム設計支援方法 | |
CN114647494A (zh) | 进程管控方法、装置、存储介质及电子设备 | |
CN109992218A (zh) | 一种硬盘更新方法、装置、设备及计算机可读存储介质 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
MM4A | Annulment or lapse of patent due to non-payment of fees |