CN118227222A - 应用管理方法、服务器、电子设备及系统 - Google Patents
应用管理方法、服务器、电子设备及系统 Download PDFInfo
- Publication number
- CN118227222A CN118227222A CN202211651152.9A CN202211651152A CN118227222A CN 118227222 A CN118227222 A CN 118227222A CN 202211651152 A CN202211651152 A CN 202211651152A CN 118227222 A CN118227222 A CN 118227222A
- Authority
- CN
- China
- Prior art keywords
- application
- installation package
- library file
- electronic device
- server
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
- 238000007726 management method Methods 0.000 title claims abstract description 56
- 238000009434 installation Methods 0.000 claims abstract description 327
- 238000000034 method Methods 0.000 claims abstract description 71
- 238000004590 computer program Methods 0.000 claims description 24
- 230000004044 response Effects 0.000 claims description 20
- 230000006870 function Effects 0.000 description 40
- 238000004891 communication Methods 0.000 description 37
- 238000012545 processing Methods 0.000 description 24
- 238000010586 diagram Methods 0.000 description 23
- 230000000694 effects Effects 0.000 description 22
- 239000010410 layer Substances 0.000 description 19
- 230000008569 process Effects 0.000 description 13
- 238000010295 mobile communication Methods 0.000 description 12
- 230000003287 optical effect Effects 0.000 description 6
- 238000011161 development Methods 0.000 description 5
- 238000013461 design Methods 0.000 description 4
- 230000005236 sound signal Effects 0.000 description 4
- 230000008878 coupling Effects 0.000 description 3
- 238000010168 coupling process Methods 0.000 description 3
- 238000005859 coupling reaction Methods 0.000 description 3
- 238000005516 engineering process Methods 0.000 description 3
- 238000013519 translation Methods 0.000 description 3
- 229920001621 AMOLED Polymers 0.000 description 2
- 238000013473 artificial intelligence Methods 0.000 description 2
- 230000003416 augmentation Effects 0.000 description 2
- 230000008859 change Effects 0.000 description 2
- 230000007774 longterm Effects 0.000 description 2
- 238000009877 rendering Methods 0.000 description 2
- 230000003068 static effect Effects 0.000 description 2
- 238000012546 transfer Methods 0.000 description 2
- 230000001133 acceleration Effects 0.000 description 1
- 238000013528 artificial neural network Methods 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 230000015572 biosynthetic process Effects 0.000 description 1
- 210000000988 bone and bone Anatomy 0.000 description 1
- 238000004422 calculation algorithm Methods 0.000 description 1
- 238000004364 calculation method Methods 0.000 description 1
- 230000000295 complement effect Effects 0.000 description 1
- 239000012792 core layer Substances 0.000 description 1
- 238000013500 data storage Methods 0.000 description 1
- 238000001914 filtration Methods 0.000 description 1
- 230000004927 fusion Effects 0.000 description 1
- 230000036541 health Effects 0.000 description 1
- 230000003993 interaction Effects 0.000 description 1
- 239000004973 liquid crystal related substance Substances 0.000 description 1
- 230000004807 localization Effects 0.000 description 1
- 229910044991 metal oxide Inorganic materials 0.000 description 1
- 150000004706 metal oxides Chemical class 0.000 description 1
- 230000037361 pathway Effects 0.000 description 1
- 230000002093 peripheral effect Effects 0.000 description 1
- 239000002096 quantum dot Substances 0.000 description 1
- 230000005855 radiation Effects 0.000 description 1
- 239000004065 semiconductor Substances 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
- 238000003786 synthesis reaction Methods 0.000 description 1
- 230000000007 visual effect Effects 0.000 description 1
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/44—Arrangements for executing specific programs
- G06F9/445—Program loading or initiating
- G06F9/44568—Immediately runnable code
- G06F9/44578—Preparing or optimising for loading
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/60—Software deployment
- G06F8/61—Installation
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Stored Programmes (AREA)
Abstract
本申请提供应用管理方法、服务器、电子设备及系统。本申请服务器将安装包中的库文件与安装包解耦,向电子设备下发的安装包中按需配置库文件,从而在保证应用功能的同时,降低库文件对电子设备存储空间的占用。该方法包括:服务器在接收到电子设备发送的应用下载请求后,确定该应用下载请求中携带的电子设备的共享库的第一信息。之后在确定应用下载请求对应的第一安装包后,根据第一信息,确定电子设备是否包括第一安装包对应的第一库文件。当电子设备包括第一库文件时,直接向电子设备发送第一安装包;当电子设备不包括第一库文件时,根据第一库文件和第一安装包生成第二安装包后,再向电子设备发送第二安装包。
Description
技术领域
本申请实施例涉及终端技术领域,尤其涉及一种应用管理方法、服务器、电子设备及系统。
背景技术
随着终端技术的发展,应用可实现的功能越来越丰富,应用包的大小也随之增加。一般的,在应用开发过程中使用三方库来提升应用的可用性和灵活性,如通过在应用包中配置三方库实现对应的应用的文字自动翻译功能等。应用包中可配置一个或多个三方库,每一三方库均会占用部分存储空间,那么通过三方库增强应用功能,会导致应用占用较多的存储空间。
发明内容
为了解决上述的技术问题,本申请提供了一种应用管理方法、服务器、电子设备及系统。本申请提供的技术方案,服务器将应用安装包中的库文件与安装包解耦,向电子设备下发的安装包中按需配置库文件,从而在保证应用功能的同时,降低库文件对电子设备存储空间的占用。
为了实现上述的技术目的,本申请提供了如下技术方案:
第一方面,提供一种应用管理方法,应用于服务器。该方法包括:接收第一电子设备发送的第一应用下载请求,该第一应用下载请求中携带有第一电子设备中的共享库的第一信息。根据第一应用下载请求,确定第一安装包。确定第一安装包对应的第一库文件,并根据第一信息,确定第一电子设备是否包括第一库文件。当第一电子设备包括第一库文件时,向第一电子设备发送第一安装包;或者,当第一电子设备不包括第一库文件时,根据第一库文件和第一安装包生成第二安装包,向第一电子设备发送第二安装包。
如此,服务器可根据第一电子设备中的库文件的情况,按需向第一电子设备下发库文件,从而在保证安装包功能的同时,降低安装包体积,从而提升安装包下载速度。
示例性的,第一电子设备响应于用户操作,向服务器发送应用A下载请求,并且在该应用A下载请求中携带共享库信息。之后,服务器根据应用A下载请求,可确定对应的应用A安装包,并根据其中的引用目录1,确定应用A安装包所需的三方库文件为三方库文件A。之后服务器根据获取到的共享库信息,确定第一电子设备中不包括三方库文件A,那么服务器可将三方库文件A重新打包至应用A安装包。之后,服务器可将重新打包的应用A安装包发送至第一电子设备。之后,第一电子设备可根据获取到的应用A安装包,启动并显示应用A。
如此,服务器可根据电子设备中的库文件情况,在电子设备中未配置待下载安装包的库文件的情况下,可将安装包所需的库文件重新打包至安装包。之后,服务器可再将重新打包的安装包下发至电子设备,从而减小下发的安装包体积的同时,保证安装包的功能。
又示例性的,第一电子设备响应于用户操作,向服务器发送应用B下载请求,并且在该应用B下载请求中携带共享库信息,如该共享库信息用于指示第一电子设备中包括三方库文件A。之后,服务器根据应用B下载请求,确定对应的应用B安装包,并根据其中的引用目录2,确定应用B安装包所需的三方库文件为三方库文件A。服务器根据获取到的共享库信息,确定第一电子设备中已经包括三方库文件A,那么服务器可直接向第一电子设备发送应用B安装包。之后,第一电子设备可根据获取到的应用B安装包中的引用目录2,从共享库中获取到三方库文件A,之后第一电子设备根据应用B安装包和三方库文件A,可启动并显示应用B。
如此,服务器可根据电子设备中的库文件情况,在电子设备中已配置待下载安装包的库文件的情况下,可直接向电子设备下发解耦的安装包,从而减小下发的安装包体积,提升安装包下载效率。并且,电子设备中不同的应用可共享库文件,降低库文件对于存储空间的占用。
根据第一方面,在接收第一电子设备发送的第一应用下载请求之前,该方法还包括:接收第二电子设备上传的第三安装包,第三安装包中包括第一库文件。将第一库文件拆分出第三安装包,并生成引用目录,引用目录用于指示第一库文件。基于引用目录和拆分后的第三安装包,生成第一安装包。
如此,服务器在接收到开发者上传的安装包后,解耦其中包括的库文件,并生成相应的引用目录。从而后续,服务器可按需向电子设备下发安装包。
一些示例中,服务器可根据三方库文件的版本号,确定三方库文件的新旧版本,进而确定是否需要保存开发侧的电子设备(即第二电子设备)上传的安装包中的三方库文件。
根据第一方面,或者以上第一方面的任意一种实现方式,确定第一安装包对应的第一库文件,包括:根据第一安装包中的引用目录,确定第一安装包所需的第一库文件。
根据第一方面,或者以上第一方面的任意一种实现方式,第一安装包所需的库文件为第一版本的第一库文件;当第一电子设备包括第一库文件时,向第一电子设备发送第一安装包,包括:根据第一信息,确定第一电子设备包括第二版本的第一库文件,第二版本和第一版本的版本相同,或第二版本高于第一版本。向第一电子设备发送第一安装包。
根据第一方面,或者以上第一方面的任意一种实现方式,第一安装包所需的库文件为第一版本的第一库文件;当第一电子设备不包括第一库文件时,根据第一库文件和第一安装包生成第二安装包,向第一电子设备发送第二安装包,包括:根据第一信息,确定第一电子设备不包括第一版本的第一库文件;或者,确定第一电子设备包括第三版本的第一库文件,第三版本高于或低于第一版本。根据第一版本的第一库文件和第一安装包,生成第二安装包。向第一电子设备发送第二安装包。
如此,服务器可根据三方库文件的版本号,确定三方库文件的新旧版本,进而确定是否需要向用户侧的电子设备(即第一电子设备)下发三方库文件。
根据第一方面,或者以上第一方面的任意一种实现方式,服务器中包括用于保存包括第一库文件的公共库。
如此,服务器在公共库中保存解耦后的库文件,后续在需要向电子设备下发库文件时,可从公共库中获取到该库文件。
第二方面,提供一种安装包应用管理方法,应用于第一电子设备。该方法包括:接收服务器发送的第一应用对应的第一安装包。根据第一安装包中的引用目录,在共享库中获取第一库文件。根据第一安装包和第一库文件,显示第一应用的界面。
如此,第一电子设备中不同的应用可共用共享库中的库文件,从而降低第一电子设备中的库文件对于存储空间的占用。
根据第二方面,在接收服务器发送的第一安装包之前,方法还包括:接收用户的第一操作;该第一操作用于打开第一应用。响应于第一操作,确定共享库的第一信息,第一信息用于指示共享库中包括第一库文件。向服务器发送第一应用下载请求,第一应用下载请求中携带有第一信息,第一应用下载请求用于请求下载第一应用的安装包。
根据第二方面,或者以上第二方面的任意一种实现方式,方法还包括:接收用户的第二操作;该第二操作用于打开第二应用。响应于第二操作,确定共享库的第二信息,第二信息用于指示共享库中包括第一版本的第一库文件。向服务器发送第二应用下载请求,第二应用下载请求中携带有第二信息,第二应用下载请求用于请求下载第二应用。接收服务器发送的第四安装包,第四安装包中包括第二版本的第一库文件,第二版本高于或者低于第一版本。根据第四安装包,显示第二应用的界面,并将第二版本的第一库文件保存至共享库。
根据第二方面,或者以上第二方面的任意一种实现方式,方法还包括:删除共享库中的第一版本的第一库文件。
如此,服务器可根据安装包所需的库文件的版本号,以及电子设备中包括的相应的库文件的版本号,向电子设备下发新版本的库文件。相应的,电子设备在接收到安装包后,可根据新版本的库文件更新旧版本的库文件,从而为用户提供更加新的应用功能体验。
第三方面,提供一种安装包管理系统。该系统包括:服务器和第一电子设备。其中,服务器,用于:接收第一电子设备发送的第一应用下载请求,第一应用下载请求中携带有第一电子设备中的共享库的第一信息。根据第一应用下载请求,确定第一安装包。确定第一安装包对应的第一库文件,并根据第一信息,确定第一电子设备是否包括第一库文件。服务器,还用于:当第一电子设备包括第一库文件时,向第一电子设备发送第一安装包。第一电子设备,用于:接收服务器发送的对应于第一应用的第一安装包。根据第一安装包中的引用目录,在共享库中获取第一库文件。根据第一安装包和第一库文件,显示第一应用的界面。或者,服务器,还用于:当第一电子设备不包括第一库文件时,根据第一库文件和第一安装包生成第二安装包,向第一电子设备发送第二安装包。第一电子设备,用于:接收第二安装包。根据第二安装包,显示第一应用的界面。
根据第三方面,服务器,还用于:接收第二电子设备上传的第三安装包,第三安装包中包括第一库文件。将第一库文件拆分出第三安装包,并生成引用目录,引用目录用于指示第一库文件。基于引用目录和拆分后的第三安装包,生成第一安装包。
根据第三方面,或者以上第三方面的任意一种实现方式,服务器,还用于:根据第一安装包中的引用目录,确定第一安装包所需的第一库文件。
根据第三方面,或者以上第三方面的任意一种实现方式,服务器,还用于:接收用户的第一操作;第一操作用于打开第一应用。响应于第一操作,确定共享库的第一信息,第一信息用于指示共享库中包括第一库文件。向服务器发送第一应用下载请求,第一应用下载请求中携带有第一信息,第一应用下载请求用于请求下载第一应用的安装包。
根据第三方面,或者以上第三方面的任意一种实现方式,第一安装包所需的库文件为第一版本的第一库文件;服务器,还用于:根据第一信息,确定第一电子设备包括第二版本的第一库文件,第二版本和第一版本的版本相同,或第二版本高于第一版本。向第一电子设备发送第一安装包。
根据第三方面,或者以上第三方面的任意一种实现方式,第一安装包所需的库文件为第一版本的第一库文件;服务器,还用于:根据第一信息,确定第一电子设备不包括第一版本的第一库文件,或者确定第一电子设备包括第三版本的第一库文件,第三版本高于或第一版本。根据第一版本的第一库文件和第一安装包生成第二安装包。向第一电子设备发送第二安装包。
根据第三方面,或者以上第三方面的任意一种实现方式,服务器中包括用于保存包括第一库文件的公共库。
第三方面以及第三方面中任意一种实现方式所对应的技术效果,可参见上述第一方面及第一方面中任意一种实现方式所对应的技术效果,此处不再赘述。
第四方面,提供一种服务器。该服务器包括:处理器和存储器,存储器和处理器耦合,存储器用于存储计算机程序代码,计算机程序代码包括计算机指令,当处理器从存储器中读取计算机指令,使得服务器执行:接收第一电子设备发送的第一应用下载请求,该第一应用下载请求中携带有第一电子设备中的共享库的第一信息。根据第一应用下载请求,确定第一安装包。确定第一安装包对应的第一库文件,并根据第一信息,确定第一电子设备是否包括第一库文件。当第一电子设备包括第一库文件时,向第一电子设备发送第一安装包;或者,当第一电子设备不包括第一库文件时,根据第一库文件和第一安装包生成第二安装包,向第一电子设备发送第二安装包。
根据第四方面,当处理器从存储器中读取计算机指令,还使得服务器执行:接收第二电子设备上传的第三安装包,第三安装包中包括第一库文件。将第一库文件拆分出第三安装包,并生成引用目录,引用目录用于指示第一库文件。基于引用目录和拆分后的第三安装包,生成第一安装包。
根据第四方面,或者以上第四方面的任意一种实现方式,确定第一安装包对应的第一库文件,包括:根据第一安装包中的引用目录,确定第一安装包所需的第一库文件。
根据第四方面,或者以上第四方面的任意一种实现方式,第一安装包所需的库文件为第一版本的第一库文件;当第一电子设备包括第一库文件时,向第一电子设备发送第一安装包,包括:根据第一信息,确定第一电子设备包括第二版本的第一库文件,第二版本和第一版本的版本相同,或第二版本高于第一版本。向第一电子设备发送第一安装包。
根据第四方面,或者以上第四方面的任意一种实现方式,第一安装包所需的库文件为第一版本的第一库文件;当第一电子设备不包括第一库文件时,根据第一库文件和第一安装包生成第二安装包,向第一电子设备发送第二安装包,包括:根据第一信息,确定第一电子设备不包括第一版本的第一库文件;或者,确定第一电子设备包括第三版本的第一库文件,第三版本高于或低于第一版本。根据第一版本的第一库文件和第一安装包,生成第二安装包。向第一电子设备发送第二安装包。
根据第四方面,或者以上第四方面的任意一种实现方式,服务器中包括用于保存包括第一库文件的公共库。
第四方面以及第四方面中任意一种实现方式所对应的技术效果,可参见上述第一方面及第一方面中任意一种实现方式所对应的技术效果,此处不再赘述。
第五方面,提供一种电子设备。该电子设备包括:处理器和存储器,存储器和处理器耦合,存储器用于存储计算机程序代码,计算机程序代码包括计算机指令,当处理器从存储器中读取计算机指令,使得电子设备执行:接收服务器发送的第一应用对应的第一安装包。根据第一安装包中的引用目录,在共享库中获取第一库文件。根据第一安装包和第一库文件,显示第一应用的界面。
根据第五方面,当处理器从存储器中读取计算机指令,还使得电子设备执行:接收用户的第一操作;该第一操作用于打开第一应用。响应于第一操作,确定共享库的第一信息,第一信息用于指示共享库中包括第一库文件。向服务器发送第一应用下载请求,第一应用下载请求中携带有第一信息,第一应用下载请求用于请求下载第一应用的安装包。
根据第五方面,或者以上第五方面的任意一种实现方式,当处理器从存储器中读取计算机指令,还使得电子设备执行:接收用户的第二操作;该第二操作用于打开第二应用。响应于第二操作,确定共享库的第二信息,第二信息用于指示共享库中包括第一版本的第一库文件。向服务器发送第二应用下载请求,第二应用下载请求中携带有第二信息,第二应用下载请求用于请求下载第二应用。接收服务器发送的第四安装包,第四安装包中包括第二版本的第一库文件,第二版本高于或者低于第一版本。根据第四安装包,显示第二应用的界面,并将第二版本的第一库文件保存至共享库。
根据第五方面,或者以上第五方面的任意一种实现方式,当处理器从存储器中读取计算机指令,还使得电子设备执行:删除共享库中的第一版本的第一库文件。
第五方面以及第五方面中任意一种实现方式所对应的技术效果,可参见上述第一方面及第一方面中任意一种实现方式所对应的技术效果,此处不再赘述。
第六方面,本申请提供一种服务器,该服务器具有实现如上述第一方面及其中任一种可能的实现方式中所述的应用管理方法的功能。该功能可以通过硬件实现,也可以通过硬件执行相应地软件实现。该硬件或软件包括一个或多个与上述功能相对应的模块。
第六方面以及第六方面中任意一种实现方式所对应的技术效果,可参见上述第一方面及第一方面中任意一种实现方式所对应的技术效果,此处不再赘述。
第七方面,本申请提供一种电子设备,该电子设备具有实现如上述第一方面及其中任一种可能的实现方式中所述的应用管理方法的功能。该功能可以通过硬件实现,也可以通过硬件执行相应地软件实现。该硬件或软件包括一个或多个与上述功能相对应的模块。
第七方面以及第七方面中任意一种实现方式所对应的技术效果,可参见上述第二方面及第二方面中任意一种实现方式所对应的技术效果,此处不再赘述。
第八方面,提供一种计算机可读存储介质。计算机可读存储介质存储有计算机程序(也可称为指令或代码),当该计算机程序被服务器执行时,使得服务器执行第一方面或第一方面中任意一种实施方式的方法。
第八方面以及第八方面中任意一种实现方式所对应的技术效果,可参见上述第一方面及第一方面中任意一种实现方式所对应的技术效果,此处不再赘述。
第九方面,提供一种计算机可读存储介质。计算机可读存储介质存储有计算机程序(也可称为指令或代码),当该计算机程序被电子设备执行时,使得电子设备执行第二方面或第二方面中任意一种实施方式的方法。
第九方面以及第九方面中任意一种实现方式所对应的技术效果,可参见上述第二方面及第二方面中任意一种实现方式所对应的技术效果,此处不再赘述。
第十方面,本申请提供一种计算机程序产品,当计算机程序产品在服务器上运行时,使得服务器执行第一方面或第一方面中任意一种实施方式的方法。
第十方面以及第十方面中任意一种实现方式所对应的技术效果,可参见上述第一方面及第一方面中任意一种实现方式所对应的技术效果,此处不再赘述。
第十一方面,本申请提供一种计算机程序产品,当计算机程序产品在电子设备上运行时,使得电子设备执行第二方面或第二方面中任意一种实施方式的方法。
第十一方面以及第十一方面中任意一种实现方式所对应的技术效果,可参见上述第二方面及第二方面中任意一种实现方式所对应的技术效果,此处不再赘述。
附图说明
图1A为本申请实施例提供的一种应用管理方法应用的通信系统的示意图一;
图1B为本申请实施例提供的一种应用管理方法应用的通信系统的示意图二;
图2为本申请实施例提供的服务器的硬件结构示意图;
图3A为本申请实施例提供的电子设备的硬件结构示意图;
图3B为本申请实施例提供的电子设备的软件结构框图示意图;
图4为本申请实施例提供的应用包上传场景示意图一;
图5为本申请实施例提供的应用包下载场景示意图一;
图6为本申请实施例提供的应用包下载场景示意图二;
图7为本申请实施例提供的应用包下载场景示意图三;
图8为本申请实施例提供的应用包下载场景示意图四;
图9为本申请实施例提供的应用包下载场景示意图五;
图10为本申请实施例提供的应用包下载场景示意图六;
图11为本申请实施例提供的应用包上传场景示意图二;
图12为本申请实施例提供的应用包上传场景示意图三;
图13为本申请实施例提供的应用包上传场景示意图四;
图14为本申请实施例提供的应用包上传场景示意图五;
图15为本申请实施例提供的应用管理方法的流程示意图;
图16为本申请实施例提供的服务器的结构示意图;
图17为本申请实施例提供的第一电子设备的结构示意图。
具体实施方式
下面结合本申请实施例中的附图,对本申请实施例中的技术方案进行描述。其中,在本申请实施例的描述中,以下实施例中所使用的术语只是为了描述特定实施例的目的,而并非旨在作为对本申请的限制。如在本申请的说明书和所附权利要求书中所使用的那样,单数表达形式“一个”、“一种”、“所述”、“上述”、“该”和“这一”旨在包括例如“一个或多个”这种表达形式,除非其上下文中明确地有相反指示。还应当理解,在本申请以下各实施例中,“至少一个”、“一个或多个”是指一个或两个以上(包含两个)。
在本说明书中描述的参考“一个实施例”或“一些实施例”等意味着在本申请的一个或多个实施例中包括结合该实施例描述的特定特征、结构或特点。由此,在本说明书中的不同之处出现的语句“在一个实施例中”、“在一些实施例中”、“在其他一些实施例中”、“在另外一些实施例中”等不是必然都参考相同的实施例,而是意味着“一个或多个但不是所有的实施例”,除非是以其他方式另外特别强调。术语“包括”、“包含”、“具有”及它们的变形都意味着“包括但不限于”,除非是以其他方式另外特别强调。术语“连接”包括直接连接和间接连接,除非另外说明。“第一”、“第二”仅用于描述目的,而不能理解为指示或暗示相对重要性或者隐含指明所指示的技术特征的数量。
在本申请实施例中,“示例性地”或者“例如”等词用于表示作例子、例证或说明。本申请实施例中被描述为“示例性地”或者“例如”的任何实施例或设计方案不应被解释为比其它实施例或设计方案更优选或更具优势。确切而言,使用“示例性地”或者“例如”等词旨在以具体方式呈现相关概念。
图1A为本申请实施例提供的一种应用管理方法应用的通信系统的示意图。如图1A所示,该通信系统包括服务器100和开发者侧的电子设备200。
在一些实施例中,服务器100可以用于管理开发者上传的应用包,例如,服务器100为应用市场服务器。一些示例中,服务器100可接收开发者侧的电子设备200上传的应用包。
图1B为本申请实施例提供的又一种应用管理方法应用的通信系统的示意图。如图1B所示,该通信系统包括服务器100和用户侧的电子设备300。
在一些实施例中,服务器100响应于用户侧的电子设备300的请求,向用户侧的电子设备300下发相应的应用包。用户侧的电子设备300可根据获取到的应用包,完成应用的下载安装。
请参考图1A或图1B,服务器100可以是云服务器或者网络服务器等具有计算功能的设备或服务器。上述服务器可以是一台服务器,也可以是由多台服务器组成的服务器集群,或者是一个云计算服务中心。
请参考图1A或图1B,电子设备(如开发者侧的电子设备200或用户侧的电子设备300)例如可以为手机、平板电脑、笔记本电脑、智慧屏、车载终端、超级移动个人计算机(ultra-mobile personal computer,UMPC)、上网本、个人数字助理(personal digitalassistant,PDA)、可穿戴设备、人工智能(artificial intelligence,AI)设备等终端设备,电子设备安装的操作系统包括但不限于或者其它操作系统。本申请对电子设备的具体类型、所安装的操作系统均不作限制。
示例性的,图2示出了服务器100的一种结构示意图。
服务器包括至少一个处理器201,通信线路202,存储器203以及至少一个通信接口204。其中,存储器203还可以包括于处理器201中。
处理器201可以是一个通用中央处理器(central processing unit,CPU),微处理器,特定应用集成电路(application-specific integrated circuit,ASIC),或一个或多个用于控制本申请方案程序执行的集成电路。
通信线路202可包括一通路,在上述组件之间传送信息。
通信接口204,用于与其他设备通信。在本申请实施例中,通信接口可以是模块、电路、总线、接口、收发器或者其它能实现通信功能的装置,用于与其他设备通信。可选的,当通信接口是收发器时,该收发器可以为独立设置的发送器,该发送器可用于向其他设备发送信息,该收发器也可以为独立设置的接收器,用于从其他设备接收信息。该收发器也可以是将发送、接收信息功能集成在一起的部件,本申请实施例对收发器的具体实现不做限制。
存储器203可以是只读存储器(read-only memory,ROM)或可存储静态信息和指令的其他类型的静态存储设备,随机存取存储器(random access memory,RAM)或者可存储信息和指令的其他类型的动态存储设备,也可以是电可擦可编程只读存储器(electricallyerasable programmable read-only memory,EEPROM)、只读光盘(compact disc read-only memory,CD-ROM)或其他光盘存储、光碟存储(包括压缩光碟、激光碟、光碟、数字通用光碟、蓝光光碟等)、磁盘存储介质或者其他磁存储设备、或者能够用于携带或存储具有指令或数据结构形式的期望的程序代码并能够由计算机存取的任何其他介质,但不限于此。存储器可以是独立存在,通过通信线路202与处理器相连接。存储器也可以和处理器集成在一起。
其中,存储器203用于存储用于实现本申请方案的计算机执行指令,并由处理器201来控制执行。处理器201用于执行存储器203中存储的计算机执行指令,从而实现本申请下述实施例提供的应用管理方法。
可选的,本申请实施例中的计算机执行指令也可以称之为应用程序代码、指令、计算机程序或者其它名称,本申请实施例对此不作具体限定。
在具体实现中,作为一种实施例,处理器201可以包括一个或多个CPU,例如图2中的CPU0和CPU1。
在具体实现中,作为一种实施例,服务器可以包括多个处理器,例如图2中的处理器201和处理器205。这些处理器中的每一个可以是一个单核(single-CPU)处理器,也可以是一个多核(multi-CPU)处理器。这里的处理器可以指一个或多个设备、电路、和/或用于处理数据(例如计算机程序指令)的处理核。
在一些实施例中,服务器100在接收到开发者侧的电子设备200上传的应用包后,通过处理器201将应用包中包括的三方库文件与应用包解耦,并在应用包中记录其已经解耦的三方库文件的信息。之后,服务器100将解耦后的三方库文件合并到存储器203中的公共库中,用于后续用户侧的电子设备300请求下载使用。
在一些实施例中,服务器100接收到用户侧的电子设备300发送的应用下载请求后,通过处理器201确定用户侧的电子设备300中已配置的三方库文件的情况以及待下载的应用包所需的三方库文件的情况。若用户侧的电子设备300中已经配置有待下载的应用包所需的三方库文件,可通过通信接口204直接将解耦后应用包下发至用户侧的电子设备300。若用户侧的电子设备300中没有配置有待下载的应用包所需的三方库文件,可通过处理器201重新将三方库文件打包至应用包,之后再通过通信接口204将重建打包的应用包下发至用户侧的电子设备300。
在另一些实施例中,服务器100在接收到用户侧的电子设备300发送的应用下载请求后,通过处理器201确定电子设备300请求下载的应用包,该应用包中不包括三方库文件。之后,服务器100通过通信接口204向电子设备300下发该确定的应用包。后续,电子设备300可按需向服务器100请求下载所需的应用包。比如,电子设备300在应用运行过程中,确定本地已配置所需的三方库文件,可直接获取该本地的三方库文件。又比如,电子设备300在应用运行过程中,确定本地未配置所需的三方库文件,可向服务器100请求下载所需的三方库文件。
示例性的,图3A示出了电子设备的一种结构示意图。
电子设备可以包括处理器110,外部存储器接口120,内部存储器121,通用串行总线(universal serial bus,USB)接口130,充电管理模块140,电源管理模块141,电池142,天线1,天线2,移动通信模块150,无线通信模块160,音频模块170,传感器模块180,按键190,马达191,指示器192,摄像头193,显示屏194,以及用户标识模块(subscriberidentification module,SIM)卡接口195等。
可以理解的是,本申请实施例示意的结构并不构成对电子设备的具体限定。在本申请另一些实施例中,电子设备可以包括比图示更多或更少的部件,或者组合某些部件,或者拆分某些部件,或者不同的部件布置。图示的部件可以以硬件,软件或软件和硬件的组合实现。
处理器110可以包括一个或多个处理单元,例如:处理器110可以包括应用处理器(application processor,AP),调制解调处理器,图形处理器(graphics processingunit,GPU),图像信号处理器(image signal processor,ISP),控制器,视频编解码器,数字信号处理器(digital signal processor,DSP),基带处理器,和/或神经网络处理器(neural-network processing unit,NPU)等。其中,不同的处理单元可以是独立的器件,也可以集成在一个或多个处理器中。
控制器可以根据指令操作码和时序信号,产生操作控制信号,完成取指令和执行指令的控制。
处理器110中还可以设置存储器,用于存储指令和数据。在一些实施例中,处理器110中的存储器为高速缓冲存储器。该存储器可以保存处理器110刚用过或循环使用的指令或数据。如果处理器110需要再次使用该指令或数据,可从所述存储器中直接调用。避免了重复存取,减少了处理器110的等待时间,因而提高了系统的效率。
在一些实施例中,处理器110可以包括一个或多个接口。接口可以包括集成电路(inter-integrated circuit,I2C)接口,集成电路内置音频(inter-integrated circuitsound,I2S)接口,脉冲编码调制(pulse code modulation,PCM)接口,通用异步收发传输器(universal asynchronous receiver/transmitter,UART)接口,移动产业处理器接口(mobile industry processor interface,MIPI),通用输入输出(general-purposeinput/output,GPIO)接口,用户标识模块(subscriber identity module,SIM)接口,和/或通用串行总线(universal serial bus,USB)接口等。
USB接口130是符合USB标准规范的接口,具体可以是Mini USB接口,Micro USB接口,USB Type C接口等。USB接口130可以用于连接充电器为电子设备充电,也可以用于电子设备与外围设备之间传输数据。也可以用于连接耳机,通过耳机播放音频。该接口还可以用于连接其他第一电子设备,例如AR设备等。
充电管理模块140用于从充电器接收充电输入。其中,充电器可以是无线充电器,也可以是有线充电器。在一些有线充电的实施例中,充电管理模块140可以通过USB接口130接收有线充电器的充电输入。在一些无线充电的实施例中,充电管理模块140可以通过电子设备的无线充电线圈接收无线充电输入。充电管理模块140为电池142充电的同时,还可以通过电源管理模块141为电子设备供电。
电源管理模块141用于连接电池142,充电管理模块140与处理器110。电源管理模块141接收电池142和/或充电管理模块140的输入,为处理器110,内部存储器121,显示屏194,摄像头193,和无线通信模块160等供电。电源管理模块141还可以用于监测电池容量,电池循环次数,电池健康状态(漏电,阻抗)等参数。在其他一些实施例中,电源管理模块141也可以设置于处理器110中。在另一些实施例中,电源管理模块141和充电管理模块140也可以设置于同一个器件中。
电子设备的无线通信功能可以通过天线1,天线2,移动通信模块150,无线通信模块160,调制解调处理器以及基带处理器等实现。
天线1和天线2用于发射和接收电磁波信号。电子设备中的每个天线可用于覆盖单个或多个通信频带。不同的天线还可以复用,以提高天线的利用率。例如:可以将天线1复用为无线局域网的分集天线。在另外一些实施例中,天线可以和调谐开关结合使用。
移动通信模块150可以提供应用在电子设备上的包括2G/3G/4G/5G等无线通信的解决方案。移动通信模块150可以包括至少一个滤波器,开关,功率放大器,低噪声放大器(low noise amplifier,LNA)等。移动通信模块150可以由天线1接收电磁波,并对接收的电磁波进行滤波,放大等处理,传送至调制解调处理器进行解调。移动通信模块150还可以对经调制解调处理器调制后的信号放大,经天线1转为电磁波辐射出去。在一些实施例中,移动通信模块150的至少部分功能模块可以被设置于处理器110中。在一些实施例中,移动通信模块150的至少部分功能模块可以与处理器110的至少部分模块被设置在同一个器件中。
调制解调处理器可以包括调制器和解调器。其中,调制器用于将待发送的低频基带信号调制成中高频信号。解调器用于将接收的电磁波信号解调为低频基带信号。随后解调器将解调得到的低频基带信号传送至基带处理器处理。低频基带信号经基带处理器处理后,被传递给应用处理器。应用处理器通过音频设备输出声音信号,或通过显示屏194显示图像或视频。在一些实施例中,调制解调处理器可以是独立的器件。在另一些实施例中,调制解调处理器可以独立于处理器110,与移动通信模块150或其他功能模块设置在同一个器件中。
无线通信模块160可以提供应用在电子设备上的包括无线局域网(wirelesslocal area networks,WLAN)(如无线保真(wireless fidelity,Wi-Fi)网络),蓝牙(bluetooth,BT),全球导航卫星系统(global navigation satellite system,GNSS),调频(frequency modulation,FM),近距离无线通信技术(near field communication,NFC),红外技术(infrared,IR)等无线通信的解决方案。无线通信模块160可以是集成至少一个通信处理模块的一个或多个器件。无线通信模块160经由天线2接收电磁波,将电磁波信号调频以及滤波处理,将处理后的信号发送到处理器110。无线通信模块160还可以从处理器110接收待发送的信号,对其进行调频,放大,经天线2转为电磁波辐射出去。
在一些实施例中,电子设备的天线1和移动通信模块150耦合,天线2和无线通信模块160耦合,使得电子设备可以通过无线通信技术与网络以及其他设备通信。所述无线通信技术可以包括全球移动通讯系统(global system for mobile communications,GSM),通用分组无线服务(general packet radio service,GPRS),码分多址接入(code divisionmultiple access,CDMA),宽带码分多址(wideband code division multiple access,WCDMA),时分码分多址(time-division code division multiple access,TD-SCDMA),长期演进(long term evolution,LTE),BT,GNSS,WLAN,NFC,FM,和/或IR技术等。所述GNSS可以包括全球卫星定位系统(global positioning system,GPS),全球导航卫星系统(globalnavigation satellite system,GLONASS),北斗卫星导航系统(beidou navigationsatellite system,BDS),准天顶卫星系统(quasi-zenith satellite system,QZSS)和/或星基增强系统(satellite based augmentation systems,SBAS)。
电子设备通过GPU,显示屏194,以及应用处理器等实现显示功能。GPU为图像处理的微处理器,连接显示屏194和应用处理器。GPU用于执行数学和几何计算,用于图形渲染。处理器110可包括一个或多个GPU,其执行程序指令以生成或改变显示信息。
显示屏194用于显示图像,视频等。显示屏194包括显示面板。显示面板可以采用液晶显示屏(liquid crystal display,LCD),例如采用有机发光二极管(organic light-emitting diode,OLED),有源矩阵有机发光二极体或主动矩阵有机发光二极体(active-matrix organic light emitting diode的,AMOLED),柔性发光二极管(flex light-emitting diode,FLED),Mini-led,Micro-led,Micro-oled,量子点发光二极管(quantumdot light emitting diodes,QLED)等生产制造。在一些实施例中,电子设备可以包括1个或N个显示屏194,N为大于1的正整数。
摄像头193用于捕获静态图像或视频。物体通过镜头生成光学图像投射到感光元件。感光元件可以是电荷耦合器件(charge coupled device,CCD)或互补金属氧化物半导体(complementary metal-oxide-semiconductor,CMOS)光电晶体管。感光元件把光信号转换成电信号,之后将电信号传递给ISP转换成数字图像信号。ISP将数字图像信号输出到DSP加工处理。DSP将数字图像信号转换成标准的RGB,YUV等格式的图像信号。在一些实施例中,电子设备可以包括1个或N个摄像头193,N为大于1的正整数。
外部存储器接口120可以用于连接外部存储卡,例如Micro SD卡,实现扩展电子设备的存储能力。外部存储卡通过外部存储器接口120与处理器110通信,实现数据存储功能。例如将音乐,视频等文件保存在外部存储卡中。
内部存储器121可以用于存储计算机可执行程序代码,所述可执行程序代码包括指令。内部存储器121可以包括存储程序区和存储数据区。其中,存储程序区可存储操作系统,至少一个功能所需的应用程序(比如声音播放功能,图像播放功能等)等。存储数据区可存储电子设备使用过程中所创建的数据(比如音频数据,电话本等)等。此外,内部存储器121可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件,闪存器件,通用闪存存储器(universal flash storage,UFS)等。处理器110通过运行存储在内部存储器121的指令,和/或存储在设置于处理器中的存储器的指令,执行电子设备的各种功能应用以及数据处理。
在一些实施例中,用户侧的电子设备300的内部存储器121中配置有共享库,该共享库用于存储三方库文件。用户侧的电子设备300中安装的不同应用可复用相同的共享库。一些示例中,该共享库例如为内部存储器121中的文件夹,配置相应的物理地址。
例如,用户侧的电子设备300在运行应用调用共享库时,操作系统根据共享库的物理地址,查询到共享库,将其中应用所需的三方库文件映射到内存中,使应用在内存中调用该三方库文件。应理解,该内存可以包括RAM,也可以包括一些能运行应用的ROM。
在一些实施例中,用户侧的电子设备300响应于用户操作,向服务器100发送应用下载请求,并在该应用下载请求中携带内部存储器121中配置的共享库的共享库信息。从而服务器100响应于接收到的应用下载请求,可根据共享库信息,确定是否需要向用户侧的电子设备300下发对应的三方库文件。
音频模块170用于将数字音频信息转换成模拟音频信号输出,也用于将模拟音频输入转换为数字音频信号。音频模块170还可以用于对音频信号编码和解码。在一些实施例中,音频模块170可以设置于处理器110中,或将音频模块170的部分功能模块设置于处理器110中。电子设备可以通过音频模块170,例如音乐播放,录音等。音频模块170可以包括扬声器,受话器,麦克风,耳机接口,以及应用处理器等实现音频功能。
传感器模块180可以包括压力传感器,陀螺仪传感器,气压传感器,磁传感器,加速度传感器,距离传感器,接近光传感器,指纹传感器,温度传感器,触摸传感器,环境光传感器,骨传导传感器等。
按键190包括开机键,音量键等。按键190可以是机械按键。也可以是触摸式按键。电子设备可以接收按键输入,产生与电子设备的用户设置以及功能控制有关的键信号输入。
马达191可以产生振动提示。马达191可以用于来电振动提示,也可以用于触摸振动反馈。
指示器192可以是指示灯,可以用于指示充电状态,电量变化,也可以用于指示消息,未接来电,通知等。
SIM卡接口195用于连接SIM卡。电子设备可以支持1个或N个SIM卡接口,N为大于1的正整数。
电子设备的软件系统可以采用分层架构,事件驱动架构,微核架构,微服务架构,或云架构。本申请实施例以分层架构的Android系统为例,示例性说明电子设备的软件结构。
图3B是本申请实施例的电子设备的软件结构框图。
分层架构将软件分成若干个层,每一层都有清晰的角色和分工。层与层之间通过软件接口通信。在一些实施例中,将Android系统分为四层,从上至下分别为应用程序层,应用程序框架层,安卓运行时(Android runtime)和系统库,以及内核层。
应用程序层可以包括一系列应用包(也可以描述为应用程序包)。
如图3B所示,应用包可以包括相机,图库,日历,通话,地图,导航,WLAN,蓝牙,音乐,视频,短信息等应用程序。
应用程序框架层为应用程序层的应用程序提供应用编程接口(applicationprogramming interface,API)和编程框架。应用程序框架层包括一些预先定义的函数。
如图3B所示,应用程序框架层可以包括窗口管理器,内容提供器,视图系统,电话管理器,资源管理器,通知管理器等。
包管理服务可用于解析、安装应用包。
窗口管理器用于管理窗口程序。窗口管理器可以获取显示屏大小,判断是否有状态栏,锁定屏幕,截取屏幕等。
内容提供器用来存放和获取数据,并使这些数据可以被应用程序访问。所述数据可以包括视频,图像,音频,拨打和接听的电话,浏览历史和书签,电话簿等。
视图系统包括可视控件,例如显示文字的控件,显示图片的控件等。视图系统可用于构建应用程序。显示界面可以由一个或多个视图组成的。例如,包括短信通知图标的显示界面,可以包括显示文字的视图以及显示图片的视图。
电话管理器用于提供电子设备的通信功能。例如通话状态的管理(包括接通,挂断等)。
资源管理器为应用程序提供各种资源,比如本地化字符串,图标,图片,布局文件,视频文件等等。
通知管理器使应用程序可以在状态栏中显示通知信息,可以用于传达告知类型的消息,可以短暂停留后自动消失,无需用户交互。通知管理器还可以是以图表或者滚动条文本形式出现在系统顶部状态栏的通知。
Android runtime包括核心库和虚拟机。Android runtime负责安卓系统的调度和管理。
核心库包含两部分:一部分是java语言需要调用的功能函数,另一部分是安卓的核心库。
应用程序层和应用程序框架层运行在虚拟机中。虚拟机将应用程序层和应用程序框架层的java文件执行为二进制文件。虚拟机用于执行对象生命周期的管理,堆栈管理,线程管理,安全和异常的管理,以及垃圾回收等功能。
系统库可以包括多个功能模块。例如:表面管理器(surface manager),媒体库(Media Libraries),三维图形处理库(例如:OpenGL ES),二维图形引擎(例如:SGL)等。
表面管理器用于对显示子系统进行管理,并且为多个应用程序提供了2D和3D图层的融合。
媒体库支持多种常用的音频,视频格式回放和录制,以及静态图像文件等。媒体库可以支持多种音视频编码格式,例如:MPEG4,H.264,MP3,AAC,AMR,JPG,PNG等。
三维图形处理库用于实现三维图形绘图,图像渲染,合成,和图层处理等。
二维图形引擎是2D绘图的绘图引擎。
内核层是硬件和软件之间的层。内核层至少包含显示驱动,摄像头驱动,音频驱动,传感器驱动。在本申请实施例中,电子设备可以包括文件系统;示例性的,文件系统可以在内核层中。该文件系统用于管理内部存储器121中存储的数据。具体的,文件系统可以将内部存储器121中存储的数据抽象为具体的文件,并提供对文件的增、删、改等操作。例如,如图3B所示,文件系统可以包括共享库,该共享库用于管理三方库文件。可选的,处理器110通过文件系统调用共享库中的三方库文件。
在一些实施例中,为了提升应用的可用性和灵活性,开发者通常在应用包中打包三方库文件。比如,安卓系统支持三方库(Android support library)可用于提升旧设备的用户体验。又比如,应用中配置Google Play服务的三方库,可用于实现应用的文字自动翻译功能。
一些示例中,开发者可根据应用需求,在应用包中配置一个或多个三方库文件。其中,不同的三方库文件的大小从几十千字节(kb)到上百兆(M)不等。那么,应用在通过三方库文件提升性能的同时,会由于配置三方库文件导致应用包体积较大,导致后续用户侧的电子设备300应用包下载速度的降低,以及内存占用的增加。
一些示例中,不同操作系统支持的三方库文件的文件类型可能不同。例如,三方库文件为共享对象(shared object,SO)文件、动态链接库(dynamic link library,DLL)文件等。下文以三方库文件的文件类型为SO文件为例,对本申请实施例提供的应用管理方法进行详细介绍。
一些示例中,应用包例如为用于安装应用的安装包,不同操作系统支持的应用包类型可能不同。例如,应用包例如为Android系统安装包(Android package,APK),鸿蒙系统能力安装包(HarmonyOS ability package,HAP)包等。
在一些实施例中,服务器100中配置有公共库,该公共库用于保存多种类型的三方库文件,不同类型的三方库文件用于实现不同的功能,如实现文字的自动翻译功能,实现应用的可用性和灵活性的功能等。服务器100在接收到开发者侧的电子设备200上传的应用包后,将应用包中的三方库文件与应用包解耦,将解耦后的三方库文件合并到公共库中。
一些示例中,服务器100的公共库中已经保存有开发者侧的电子设备200上传的应用包中包括的三方库文件。那么,服务器100可丢弃该解耦后的三方库文件。或者,服务器100的公共库中未保存或保存有部分开发者侧的电子设备200上传的应用包中包括的三方库文件。那么,服务器100可将公共库中未保存的三方库文件添加到公共库中,以丰富公共库中存储的三方库文件。
一些示例中,服务器100根据解耦后的三方库文件,生成相应的引用目录,该引用目录用于记录当前应用包中包括的三方库文件。之后,服务器100将解耦后的应用包和引用目录重新打包并存储。例如,服务器100在引用目录中,记录应用包中包括的三方库文件的版本号。其中,不同的三方库文件的版本号不同。一些示例中,引用目录例如为module.json配置文件。
示例性的,如图4所示,服务器100接收开发者侧的电子设备200上传的应用A安装包后,对应用A安装包进行拆包,将应用A安装包中的三方库文件与应用A安装包解耦。之后,服务器100可生成该解耦后的三方库文件对应的引用目录1,用于记录应用A安装包中包括的三方库文件的版本号。之后,服务器100将解耦后的应用A安装包和引用目录1重新打包并存储。
例如,引用目录1为module.json配置文件,解耦后的三方库文件的版本号为1.1.13。示例性的,服务器100可通过下述指令,重新打包应用A安装包。
又示例性的,如图4所示,服务器100接收开发者侧的电子设备200上传的应用B安装包后,对应用B安装包进行拆包,将应用B安装包中的三方库文件与应用B安装包解耦。之后,服务器100可生成该解耦后的三方库文件对应的引用目录2,用于记录应用B安装包中包括的三方库文件的版本号。之后,服务器100将解耦后的应用B安装包和引用目录2重新打包并存储。
例如,引用目录2为module.json配置文件,解耦后的三方库文件的版本号为1.1.13。一些示例中,服务器100确定该应用B安装包解耦后的三方库文件的版本号与应用A安装包解耦后的三方库文件的版本号相同,服务器100的公共库中已经保存有应用A安装包解耦后的三方库文件,那么服务器100可丢弃该应用B安装包解耦后的三方库文件。
示例性的,服务器100可通过下述指令,重新打包应用B安装包。
在一些实施例中,用户侧的电子设备300响应于用户操作,确定用户指示下载应用,可向服务器100发送应用下载请求,并在该应用下载请求中携带共享库信息。
一些示例中,用户侧的电子设备300中配置有共享库,该共享库用于管理电子设备300中应用使用的三方库文件。比如,在电子设备300运行已安装的应用1调用共享库时,操作系统将共享库中应用1所需的三方库文件映射到内存中,使处理器在内存中调用该三方库文件。
一些示例中,共享库信息例如包括共享库中包括的三方库文件的版本号。
一些示例中,用户侧的电子设备300中可配置一个或多个共享库,电子设备300中的应用可共享该一个或多个共享库中的三方库文件。
一些示例中,用户指示下载应用的操作例如包括对应用图标的操作、对应用下载链接的操作等。
在一些实施例中,服务器100在接收到用户侧的电子设备300发送的应用下载请求后,可根据该应用下载请求确定电子设备300请求下载的应用。之后,服务器100可获取到电子设备300请求下载的应用包,并获取到该应用包中包括的引用目录,进而服务器100可确定该应用运行所需的三方库文件。之后,服务器100可根据应用下载请求中携带的共享库信息,确定电子设备300的共享库中是否包括引用目录指示的三方库文件。
当电子设备300的三方库中包括引用目录指示的三方库文件时,服务器100可直接将确定的应用包下发至电子设备300;当电子设备300的三方库中不包括引用目录指示的三方库文件时服务器100可根据引用目录,将对应的三方库文件重新打包至确定的应用包中,之后向电子设备300发送该重新打包的应用包。
相应的,电子设备300接收到应用包后,可安装应用。如应用包中包括三方库文件,电子设备300可将该三方库文件添加到共享库中。
示例性的,如图5所示,用户侧的电子设备300响应于用户操作,向服务器100发送应用A下载请求,并在该应用A下载请求中携带电子设备300中包括的共享库的共享库信息。
如下示例一种共享库信息的指令,用户侧的电子设备300在应用A下载请求中携带该指令。
{
CommonSoLibrary:[]
}
相应的,如图5所示,服务器100接收用户侧的电子设备300发送的应用A下载请求。并且对应于上述图4所示场景,服务器100中管理的应用包中包括带有引用目录的应用A的安装包和应用B的安装包。服务器100根据应用A下载请求,确定电子设备300请求下载应用A,可获取到对应的应用A安装包以及应用A安装包中带有的引用目录1。之后,服务器100根据该引用目录1以及应用A下载请求中携带的共享库信息,确定电子设备300中不包括引用目录1指示的三方库文件。那么,如图5所示,服务器100可根据引用目录1,将三方库文件A重新打包至应用A安装包,并将该重新打包后的应用A安装包下发至电子设备300。
应理解,服务器100中管理的应用包可以为已经解耦的应用包,其中可以不包括三方库文件,但带有用于指示解耦的三方库文件的引用目录。
相应的,如图5所示,用户侧的电子设备300接收服务器100发送的应用A安装包,安装应用A。并且,电子设备300根据应用A安装包中的引用目录1,确定共享库中不包括三方库文件A。那么,电子设备300可将应用A安装包中包括的三方库文件A添加至共享库中,允许应用A和其他应用引用该三方库文件A。
一些示例中,服务器100在根据引用目录和共享库信息,确定用户侧的电子设备300的共享库中是否包括引用目录指示的三方库文件的过程中,可确定电子设备300的共享库中包括引用目录指示的三方库文件中的部分三方库文件。那么,服务器100可将电子设备300的共享库中不包括的引用目录指示的三方库文件放入应用包中,以减小应用包的大小,降低后续对于电子设备300的存储空间的占用。
又示例性的,如图6所示用户侧的电子设备300响应于用户操作,向服务器100发送应用B下载请求,并在该应用B下载请求中携带电子设备300中包括的共享库的共享库信息。其中,对应于上述图5所示场景,电子设备300的共享库中包括三方库文件A。并且,对应于上述图4所示场景,拆包前的应用A安装包中的三方库文件的版本号为1.1.13。那么,三方库文件A的版本号为1.1.13。
那么,如下示例又一种共享库信息的指令,用户侧的电子设备300在应用B下载请求中携带该指令。
相应的,如图6所示,服务器100接收用户侧的电子设备300发送的应用B下载请求。并且对应于上述图4所示场景,服务器100中管理的应用包中包括带有引用目录的应用A的安装包和应用B的安装包。服务器100根据应用B下载请求,确定电子设备300请求下载应用B,可获取到对应的应用B安装包以及应用B安装包中打包的引用目录2。其中,对应于上述图4所示场景,拆包前的应用A安装包和应用B安装包中的三方库文件的版本号均为1.1.13。那么,服务器100根据该引用目录2以及应用B下载请求中携带的共享库信息,确定电子设备300中包括引用目录2指示的三方库文件。那么,如图6所示,服务器100可直接将保存的应用B安装包下发至电子设备300,该应用B安装包中不包括三方库文件。
相应的,如图6所示,用户侧的电子设备300接收服务器100发送的应用B安装包,安装应用B。并且,电子设备300根据应用B安装包中的引用目录2,确定不必更新共享库。
为了便于更明显的体现本申请实施例提供的应用管理方法的有益效果,如下表1所示,示例性的说明采用原应用管理方法和采用本申请实施例提供的应用管理方法,应用安装包对于存储空间的占用情况。
可以看出,通过服务器100将应用包中的三方库文件拆包,按需向用户侧的电子设备300下发三方库文件,能够有效减小应用包的大小,进而提升应用下载速度。并且,用户侧的电子设备300共享三方库文件,在降低应用包对于存储空间占用的同时,不会对应用的运行产生影响。
表1
在一些实施例中,随着终端技术的发展,开发者可对三方库文件进行更新,新版本的三方库文件能够兼容旧版本的三方库文件。一些示例中,通过版本号区分相同类型的三方库文件的新旧版本。应理解,三方库文件的新旧版本为相对而言,不限于最新版本和之前的版本。例如,版本号为1.1.12的三方库文件A相对于版本号为1.1.13的三方库文件A’为旧版本的三方库文件,但是相对于版本号为1.1.11的三方库文件A”为新版本的三方库文件。
一些示例中,服务器100在应用包下发过程中,确定用户侧的电子设备300的共享库中包括待下载应用对应的旧版本的三方库文件。那么,服务器100可通过重新打包应用包,向电子设备300下发待下载应用对应的新版本的三方库文件。相应的,电子设备300在获取到应用包后,可通过获取到的新版本的三方库文件,更新本地共享库中保存的旧版本的三方库文件。
示例性的,如图7所示,服务器100根据获取到的应用B下载请求,确定用户侧的电子设备300请求下载应用B,可获取应用B安装包,并确定其中包括的引用目录2。之后,服务器100根据引用目录2,确定应用B引用的三方库文件为三方库文件A’,如版本号为1.1.13。服务器100根据应用B下载请求中携带的共享库信息,确定电子设备300的共享库中包括旧版本的三方库文件A,如版本号为1.1.12。那么,服务器100可将新版本的三方库文件A’重新打包至应用B安装包,并将该重新打包后的应用B安装包下发至电子设备300。
相应的,如图7所示,用户侧的电子设备300接收服务器100发送的应用B安装包,安装应用B。并且,电子设备300根据应用B安装包中的引用目录2,确定应用B安装包中包括新版本的三方库文件A’。在共享库中包括旧版本的三方库文件A的场景下,电子设备300可将应用B安装包中包括的新版本的三方库文件A’添加至共享库中,并删除旧版本的三方库文件A。即,电子设备300通过新版本的三方库文件A’替换旧版本的三方库文件A,完成三方库文件的更新,后续允许应用B和其他应用引用该三方库文件A’。
另一些示例中,服务器100在应用包下发过程中,确定用户侧的电子设备300的共享库中包括待下载应用对应的旧版本的三方库文件。那么,服务器100可通过重新打包应用包,向电子设备300下发待下载应用对应的新版本的三方库文件。相应的,电子设备300在获取到应用包后,可获取到新版本的三方库文件,并在本地共享库中保存的旧版本的三方库文件以及新版本的三方库文件。后续在应用引用三方库的过程中,可根据应用包中的引用目录,确定该应用引用的三方库文件。
示例性的,如图8所示,服务器100根据获取到的应用B下载请求,确定用户侧的电子设备300请求下载应用B,可获取应用B安装包,并确定其中包括的引用目录2。之后,服务器100根据引用目录2,确定应用B引用的三方库文件为三方库文件A’,如版本号为1.1.13。服务器100根据应用B下载请求中携带的共享库信息,确定电子设备300的共享库中包括旧版本的三方库文件A,如版本号为1.1.12。那么,服务器100可将新版本的三方库文件A’重新打包至应用B安装包,并将该重新打包后的应用B安装包下发至电子设备300。
相应的,如图8所示,用户侧的电子设备300接收服务器100发送的应用B安装包,安装应用B。并且,电子设备300根据应用B安装包中的引用目录2,确定应用B安装包中包括新版本的三方库文件A’,并可确定共享库中包括旧版本的三方库文件A。那么,电子设备300可将应用B安装包中包括的新版本的三方库文件A’添加至共享库中,这样如图8所示,共享库中包括旧版本的三方库文件A和新版本的三方库文件A’。
另一些示例中,服务器100在应用包下发过程中,确定服务器100的公共库中包括待下载应用对应的旧版本的三方库文件,用户侧的电子设备300的共享库中包括待下载应用对应的新版本的三方库文件。那么,服务器100可直接向电子设备300下发待下载应用对应的应用包,该应用包中不包括三方库文件。
示例性的,如图9所示,服务器100根据获取到的应用B下载请求,确定用户侧的电子设备300请求下载应用B,可获取应用B安装包,并确定其中包括的引用目录2。之后,服务器100根据引用目录2,确定应用B引用的三方库文件为公共库中的三方库文件A,如版本号为1.1.12。服务器100根据应用B下载请求中携带的共享库信息,确定用户侧的电子设备300的共享库中包括新版本的三方库文件A’,如版本号为1.1.13。那么,服务器100可直接将应用B安装包下发至电子设备300,该应用B安装包中不包括三方库文件。
相应的,如图9所示,用户侧的电子设备300接收服务器100发送的应用B安装包,安装应用B。并且,电子设备300根据应用B安装包中的引用目录2,确定应用B引用的三方库文件为三方库文件A’。
又一些示例中,服务器100在应用包下发过程中,确定服务器100的公共库中包括待下载应用对应的旧版本的三方库文件,用户侧的电子设备300的共享库中包括待下载应用对应的新版本的三方库文件。那么,服务器100可通过重新打包应用包,将公共库中的旧版本的三方库文件重新打包至应用包,并向电子设备300下发待下载应用对应的重新打包后的应用包。相应的,电子设备300在获取到应用包后,可获取到其中包括的旧版本的三方库文件,并在本地共享库中保存的旧版本的三方库文件以及新版本的三方库文件。后续在应用引用三方库的过程中,可根据应用包中的引用目录,确定该应用引用的三方库文件。
示例性的,如图10所示,服务器100根据获取到的应用B下载请求,确定用户侧的电子设备300请求下载应用B,可获取应用B安装包,并确定其中包括的引用目录2。之后,服务器100根据引用目录2,确定应用B引用的三方库文件为公共库中的三方库文件A,如版本号为1.1.12。服务器100根据应用B下载请求中携带的共享库信息,确定电子设备300的共享库中包括新版本的三方库文件A’,如版本号为1.1.13。那么,服务器100可将公共库中的旧版本的三方库文件A重新打包至应用B安装包,并将该重新打包的应用B安装包下发至电子设备300。
相应的,如图10所示,用户侧的电子设备300接收服务器100发送的应用B安装包,安装应用B。并且,电子设备300根据应用B安装包中的引用目录2,确定应用B安装包中包括旧版本的三方库文件A。那么,电子设备300可将应用B安装包中包括的旧版本的三方库文件A添加至共享库中,这样如图10所示,共享库中包括旧版本的三方库文件A和新版本的三方库文件A’。
如此,服务器100可根据三方库文件的版本号,确定三方库文件的新旧版本,进而确定是否需要向用户侧的电子设备300下发三方库文件。
在一些实施例中,服务器100在接收到开发者侧的电子设备200上传的应用包,拆包获取到其中包括的三方库文件后,可确定该拆包后获取到的三方库文件的版本号。服务器100在确定公共库中包括对应的三方库文件后,可通过比较该拆包后获取到的三方库文件的版本号和公共库中的三方库文件的版本号,确定是否需要更新公共库。
一些示例中,服务器100在接收到开发者侧的电子设备200上传的应用包,拆包获取到其中包括的三方库文件后,根据该拆包获取到的三方库文件的版本号以及公共库中的三方库文件的版本号,确定应用包中包括的三方库文件为新版本的三方库文件。那么,服务器100可通过拆包获取到的新版本的三方库文件更新公共库中的三方库文件。即,服务器100在公共库中,相同类型的三方库文件中可以只保存最新版本的三方库文件,用于后续用户侧的电子设备300的下载。
示例性的,如图11所示,服务器100获取到开发者侧的电子设备200上传的应用A安装包,拆包获取其中包括的三方库文件A’,如版本号为1.1.13。之后,服务器100确定公共库中包括相应的旧版本的三方库文件A,版本号为1.1.12。那么,服务器100可将三方库文件A’保存至公共库,并丢弃公共库中的旧版本的三方库文件A。
另一些示例中,服务器100在接收到开发者侧的电子设备200上传的应用包,拆包获取到其中包括的三方库文件后,根据该拆包获取到的三方库文件的版本号以及公共库中的三方库文件的版本号,确定应用包中包括的三方库文件为新版本的三方库文件。那么,服务器100可保存该拆包获取到的新版本的三方库文件。即,服务器100在公共库中保存相同类型的多个版本的三方库文件,用于后续用户侧的电子设备300的下载。
示例性的,如图12所示,服务器100获取到开发者侧的电子设备200上传的应用A安装包,拆包获取其中包括的三方库文件A’,如版本号为1.1.13。之后,服务器100确定公共库中包括相应的旧版本的三方库文件A,版本号为1.1.12。那么,服务器100可将三方库文件A’保存至公共库,那么,公共库中可包括旧版本的三方库文件A以及新版本的三方库文件A’。
另一些示例中,服务器100在接收到开发者侧的电子设备200上传的应用包,拆包获取到其中包括的三方库文件后,根据该拆包获取到的三方库文件的版本号以及公共库中的三方库文件的版本号,确定应用包中包括的三方库文件为旧版本的三方库文件。那么,服务器100可丢弃该拆包获取到的旧版本的三方库文件。即,服务器100在公共库中,相同类型的三方库文件中只保存最新版本的三方库文件,用于后续用户侧的电子设备300的下载。
示例性的,如图13所示,服务器100获取到开发者侧的电子设备200上传的应用A安装包,拆包获取其中包括的三方库文件A,版本号为1.1.12。之后,服务器100确定公共库中包括相应的新版本的三方库文件A’,如版本号为1.1.13。那么,服务器100可丢弃该拆包获取到的旧版本的三方库文件A。
又一些示例中,服务器100在接收到开发者侧的电子设备200上传的应用包,拆包获取到其中包括的三方库文件后,根据该拆包获取到的三方库文件的版本号以及公共库中的三方库文件的版本号,确定应用包中包括的三方库文件为旧版本的三方库文件。那么,服务器100可保存该拆包获取到的旧版本的三方库文件。即,服务器100在公共库中保存相同类型的多个版本的三方库文件,用于后续用户侧的电子设备300的下载。
示例性的,如图14所示,服务器100获取到开发者侧的电子设备200上传的应用A安装包,拆包获取其中包括的三方库文件A,版本号为1.1.12。之后,服务器100确定公共库中包括相应的新版本的三方库文件A’,版本号为1.1.13。那么,服务器100可将三方库文件A保存至公共库,那么公共库中包括旧版本的三方库文件A以及新版本的三方库文件A’。
如此,服务器100可根据三方库文件的版本号,确定三方库文件的新旧版本,进而确定是否需要保存开发侧的电子设备200上传的应用包中的三方库文件。
应理解,服务器100也可通过其他方式获取到不同版本的三方库文件,以更新公共库。比如,服务器100获取到开发者单独上传的三方库文件等。
示例性的,图15为本申请实施例提供的一种应用管理方法的流程示意图。如图15所示,该方法包括如下步骤。
S1501、服务器接收第一电子设备发送的第一应用下载请求,该第一应用下载请求中携带有第一电子设备中的共享库的第一信息。
在一些实施例中,电子设备接收用户的第一操作,该第一操作用于打开第一应用,响应于该第一操作,第一电子设备确定共享库的第一信息,第一信息用于指示共享库中包括的库文件的信息,如包括第一库文件等。之后,第一电子设备可向服务器发送第一应用下载请求,该第一应用下载请求中携带第一信息,该第一应用下载请求用于请求下载第一应用。相应的,服务器接收第一电子设备发送的应用下载请求。
一些示例中,第一操作例如为对应用图标的操作、对应用下载链接的操作等。
S1502、服务器根据第一应用下载请求,确定第一安装包。
在一些实施例中,服务器在接收到第一应用下载请求后,能够根据第一应用下载请求,确定请求下载的第一应用对应的第一安装包。
一些示例中,第一应用下载请求中携带有待下载的第一应用的标识,服务器根据该标识可确定对应的第一安装包。
S1503、服务器确定第一安装包对应的第一库文件,并根据第一信息,确定第一电子设备是否包括第一库文件。
在一些实施例中,服务器接收第二电子设备上传的第三安装包,第三安装包中包括第一库文件。服务器将第一库文件拆分出第三安装包,并生成引用目录,该引用目录用于指示第一库文件。服务器基于引用目录和拆分后的第三安装包,生成第一安装包。
示例性的,如图4所示,服务器100接收开发者侧的电子设备200上传的应用A安装包后,对应用A安装包进行拆包,将应用A安装包中的三方库文件与应用A安装包解耦。之后,服务器100可生成该解耦后的三方库文件对应的引用目录1,用于记录应用A安装包中包括的三方库文件的版本号。之后,服务器100将解耦后的应用A安装包和引用目录1重新打包并存储。
在一些实施例中,服务器根据第一安装包中包括的引用目录,确定第一安装包所需的第一库文件。之后,服务器可根据用于指示第一电子设备中包括的库文件的第一信息,确定第一电子设备中是否包括第一库文件。
如果第一电子设备中包括第一库文件,那么服务器可直接向第一电子设备发送解耦后的第一安装包。即,执行下述步骤S1504a-S1506a。或者,如果第一电子设备中不包括第一库文件,那么服务器将解耦后的第一库文件再次添加到第一安装包中后,再向第一电子设备下发包括第一库文件的安装包。即,执行下述步骤S1504b-S1506b。
S1504a、当第一电子设备包括第一库文件时,服务器向第一电子设备发送第一安装包。
在一些实施例中,服务器确定第一电子设备中包括第一安装包所需的第一库文件,那么服务器可直接向第一电子设备下发第一应用。
在一些实施例中,第一安装包所需的库文件为第一版本的第一库文件。服务器根据第一信息,确定第一电子设备包括第二版本的第一库文件,第二版本和第一版本的版本相同,或第二版本高于第一版本。那么,服务器向第一电子设备发送第一安装包。
S1505a、第一电子设备根据第一安装包中的引用目录,在共享库中获取第一库文件。
在一些实施例中,第一电子设备接收到服务器发送的第一安装包后,可根据其中的引用目录,确定该第一安装包所需的第一库文件。之后,第一电子设备可从共享库中获取到该第一库文件。
S1506a、第一电子设备根据第一安装包和第一库文件,显示第一应用的界面。
在一些实施例中,第一电子设备根据获取的第一安装包以及确定的第一库文件,可显示第一应用,以供用户使用。
示例性的,如图6所示,用户侧的电子设备300响应于用户操作,向服务器100发送应用B下载请求,并且在该应用B下载请求中携带共享库信息,如用于指示电子设备300中包括三方库文件A。之后,服务器100根据应用B下载请求,确定对应的应用B安装包,并根据其中的引用目录2,确定应用B安装包所需的三方库文件为三方库文件A。服务器100根据获取到的共享库信息,确定电子设备300中已经包括三方库文件A,那么服务器100可直接向电子设备300发送应用B安装包。之后,电子设备300可根据获取到的应用B安装包中的引用目录2,从共享库中获取到三方库文件A,之后电子设备300根据应用B安装包和三方库文件A,可启动并显示应用B。
在一些实施例中,第一电子设备在根据第一安装包中的引用目录,在共享库中确定第一库文件后,可将第一库文件的地址索引到第一安装包对应的第一应用的安装信息中,以建立第一应用和第一库文件之间的链接。第一应用在运行过程中,可按需索引到对应的第一库文件。
如此,服务器可根据电子设备中的库文件情况,在电子设备中已配置待下载安装包的库文件的情况下,可直接向电子设备下发解耦的安装包,从而减小下发的安装包体积,提升安装包下载效率。并且,电子设备中不同的应用可共享库文件,降低库文件对于存储空间的占用。
S1504b、当第一电子设备不包括第一库文件时,根据第一库文件和第一安装包生成第二安装包。
在一些实施例中,服务器确定第一电子设备中不包括第一安装包所需的第一库文件,那么服务器可将第一安装包所需的第一库文件添加到第一安装包,以获取包括第一库文件的第二安装包。
在一些实施例中,第一安装包所需的库文件为第一版本的第一库文件,服务器根据第一信息,确定第一电子设备不包括第一版本的第一库文件;或者,确定第一电子设备包括第三版本的第一库文件,第三版本高于或低于第一版本。根据第一版本的第一库文件和第一安装包生成第二安装包。
在一些实施例中,服务器中包括用于保存包括第一库文件的公共库。服务器在确定第一电子设备中不包括第一安装包所需的第一库文件后,可从公共库中获取该第一库文件,以将第一库文件打包至第一安装包。
S1505b、服务器向第一电子设备发送第二安装包。
在一些实施例中,服务器在根据第一安装包和第一库文件,生成第二安装包后,可将第二安装包发送至第一电子设备。相应的,第一电子设备接收服务器发送的第二安装包。
S1506b、第一电子设备根据第二安装包,显示第一应用的界面。
在一些实施例中,第一电子设备根据获取的第二安装包以及第二安装包中包括的第一库文件,可显示第一应用的界面,以供用户使用。
示例性的,如图5所示,用户侧的电子设备300响应于用户操作,向服务器100发送应用A下载请求,并且在该应用A下载请求中携带共享库信息。之后,服务器100根据应用A下载请求,确定对应的应用A安装包,并根据其中的引用目录1,确定应用A安装包所需的三方库文件为三方库文件A。服务器100根据获取到的共享库信息,确定电子设备300中不包括三方库文件A,那么服务器100可将三方库文件A重新打包至应用A安装包。之后,服务器100可将重新打包的应用A安装包发送至电子设备300。之后,电子设备300可根据获取到的应用A安装包,启动并显示应用A。
如此,服务器可根据电子设备中的库文件情况,在电子设备中未配置待下载安装包的库文件的情况下,可将安装包所需的库文件重新打包至安装包。之后,服务器可再将重新打包的安装包下发至电子设备,从而减小下发的安装包体积的同时,保证安装包的功能。
在一些实施例中,第一电子设备接收用户的第二操作,该第二操作用于打开第二应用。响应于第二操作,第一电子设备确定共享库的第二信息,第二信息用于指示共享库中包括第一版本的第一库文件。第一电子设备向服务器发送第二应用下载请求,第二应用下载请求中携带有第二信息,第二应用下载请求用于请求下载第二应用。之后,第一电子设备接收服务器发送的第四安装包,第四安装包中包括第二版本的第一库文件,第二版本高于或低于第一版本。根据第四安装包,显示第二应用的界面,并将第二版本的第一库文件保存至共享库。
一些示例中,第一电子设备删除共享库中的第一版本的第一库文件。
如此,服务器可根据安装包所需的库文件的版本号,以及电子设备中包括的相应的库文件的版本号,向电子设备下发新版本的库文件。相应的,电子设备在接收到安装包后,可根据新版本的库文件更新旧版本的库文件,从而为用户提供更加新的应用功能体验。
以上结合图4-图15详细说明了本申请实施例提供的应用管理方法。以下结合图16详细说明本申请实施例提供的服务器,以及结合图17详细说明本申请实施例提供的第一电子设备。
在一种可能的设计中,图16为本申请实施例提供的服务器的结构示意图。如图16所示,服务器1600可以包括:收发单元1601和处理单元1602。服务器1600可用于实现上述方法实施例中涉及的服务器100的功能。
可选地,收发单元1601,用于支持服务器1600执行图15中的S1501、S1504a以及S1505b。
可选地,处理单元1602,用于支持服务器1600执行图15中的S1502、S1503以及S1504b。
其中,收发单元可以包括接收单元和发送单元,可以由收发器或收发器相关电路组件实现,可以为收发器或收发模块。服务器1600中的各个单元的操作和/或功能分别为了实现上述方法实施例中所述的应用管理方法的相应流程,上述方法实施例涉及的各步骤的所有相关内容均可以援引到对应功能单元的功能描述,为了简洁,在此不再赘述。
可选地,图16所示的服务器1600还可以包括存储单元(图16中未示出),该存储单元中存储有程序或指令。当收发单元1601和处理单元1602执行该程序或指令时,使得图16所示的服务器1600可以执行上述方法实施例中所述的应用管理方法。
图16所示的服务器1600的技术效果可以参考上述方法实施例中所述的应用管理方法的技术效果,此处不再赘述。
除了以服务器1600的形式以外,本申请提供的技术方案也可以为服务器中的功能单元或者芯片,或者与服务器匹配使用的装置。
在一种可能的设计中,图17为本申请实施例提供的电子设备的结构示意图。如图17所示,电子设备1700可以包括:收发单元1701、处理单元1702以及显示单元1703。电子设备1700可用于实现上述方法实施例中涉及的用户侧的电子设备300的功能。
可选地,收发单元1701,用于支持电子设备1700执行图15中的S1501、S1504a以及S1505b。
可选地,处理单元1702,用于支持电子设备1700执行图15中的S1505a、S1506a以及S1506b。
可选地,显示单元1703,用于支持电子设备1700执行图15中的S1506a和S1506b。
其中,收发单元可以包括接收单元和发送单元,可以由收发器或收发器相关电路组件实现,可以为收发器或收发模块。电子设备1700中的各个单元的操作和/或功能分别为了实现上述方法实施例中所述的应用管理方法的相应流程,上述方法实施例涉及的各步骤的所有相关内容均可以援引到对应功能单元的功能描述,为了简洁,在此不再赘述。
可选地,图17所示的电子设备1700还可以包括存储单元(图17中未示出),该存储单元中存储有程序或指令。当收发单元1701、处理单元1702以及显示单元1703执行该程序或指令时,使得图17所示的电子设备1700可以执行上述方法实施例中所述的应用管理方法。
图17所示的电子设备1700的技术效果可以参考上述方法实施例中所述的应用管理方法的技术效果,此处不再赘述。
除了以电子设备1700的形式以外,本申请提供的技术方案也可以为电子设备中的功能单元或者芯片,或者与电子设备匹配使用的装置。
本申请实施例还提供一种芯片系统,包括:处理器,所述处理器与存储器耦合,所述存储器用于存储程序或指令,当所述程序或指令被所述处理器执行时,使得该芯片系统实现上述任一方法实施例中的方法。
可选地,该芯片系统中的处理器可以为一个或多个。该处理器可以通过硬件实现也可以通过软件实现。当通过硬件实现时,该处理器可以是逻辑电路、集成电路等。当通过软件实现时,该处理器可以是一个通用处理器,通过读取存储器中存储的软件代码来实现。
可选地,该芯片系统中的存储器也可以为一个或多个。该存储器可以与处理器集成在一起,也可以和处理器分离设置,本申请实施例并不限定。示例性地,存储器可以是非瞬时性处理器,例如只读存储器ROM,其可以与处理器集成在同一块芯片上,也可以分别设置在不同的芯片上,本申请实施例对存储器的类型,以及存储器与处理器的设置方式不作具体限定。
示例性地,该芯片系统可以是现场可编程门阵列(field programmable gatearray,FPGA),可以是专用集成芯片(application specific integrated circuit,ASIC),还可以是系统芯片(system on chip,SoC),还可以是中央处理器(central processorunit,CPU),还可以是网络处理器(network processor,NP),还可以是数字信号处理电路(digital signal processor,DSP),还可以是微控制器(micro controller unit,MCU),还可以是可编程控制器(programmable logic device,PLD)或其他集成芯片。
应理解,上述方法实施例中的各步骤可以通过处理器中的硬件的集成逻辑电路或者软件形式的指令完成。结合本申请实施例所公开的方法步骤可以直接体现为硬件处理器执行完成,或者用处理器中的硬件及软件模块组合执行完成。
本申请实施例还提供一种计算机可读存储介质,该计算机可读存储介质中存储有计算机程序,当该计算机程序在计算机上运行时,使得计算机执行上述相关步骤,以实现上述实施例中的应用管理方法。
本申请实施例还提供一种计算机程序产品,当该计算机程序产品在计算机上运行时,使得计算机执行上述相关步骤,以实现上述实施例中的应用管理方法。
另外,本申请实施例还提供一种装置。该装置具体可以是组件或模块,该装置可包括相连的一个或多个处理器和存储器。其中,存储器用于存储计算机程序。当该计算机程序被一个或多个处理器执行时,使得装置执行上述各方法实施例中的应用管理方法。
其中,本申请实施例提供的装置、计算机可读存储介质、计算机程序产品或芯片均用于执行上文所提供的对应的方法。因此,其所能达到的有益效果可参考上文所提供的对应的方法中的有益效果,此处不再赘述。
结合本申请实施例公开内容所描述的方法或者算法的步骤可以硬件的方式来实现,也可以是由处理器执行软件指令的方式来实现。软件指令可以由相应地软件模块组成,软件模块可以被存放于随机存取存储器(random access memory,RAM)、闪存、只读存储器(read only memory,ROM)、可擦除可编程只读存储器(erasable programmable ROM,EPROM)、电可擦可编程只读存储器(electrically EPROM,EEPROM)、寄存器、硬盘、移动硬盘、只读光盘(CD-ROM)或者本领域熟知的任何其它形式的存储介质中。一种示例性的存储介质耦合至处理器,从而使处理器能够从该存储介质读取信息,且可向该存储介质写入信息。当然,存储介质也可以是处理器的组成部分。处理器和存储介质可以位于专用集成电路(application specific integrated circuit,ASIC)中。
通过以上的实施方式的描述,本领域技术人员可以清楚地了解到,为描述的方便和简洁,仅以上述各功能模块的划分进行举例说明。实际应用中,可以根据需要而将上述功能分配由不同的功能模块完成;即将装置的内部结构划分成不同的功能模块,以完成以上描述的全部或者部分功能。上述描述的系统,装置和单元的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
在本申请所提供的几个实施例中,应该理解到,所揭露的方法,可以通过其它的方式实现。以上所描述的装置实施例仅仅是示意性的。例如,所述模块或单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式;例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另外,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,模块或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
另外,在本申请各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。
计算机可读存储介质包括但不限于以下的任意一种:U盘、移动硬盘、只读存储器(read-only memory,ROM)、随机存取存储器(random access memory,RAM)、磁碟或者光盘等各种可以存储程序代码的介质。
以上所述,仅为本申请的具体实施方式,但本申请的保护范围并不局限于此,任何在本申请揭露的技术范围内的变化或替换,都应涵盖在本申请的保护范围之内。因此,本申请的保护范围应以所述权利要求的保护范围为准。
Claims (19)
1.一种应用管理方法,其特征在于,应用于服务器,所述方法包括:
接收第一电子设备发送的第一应用下载请求,所述第一应用下载请求中携带有所述第一电子设备中的共享库的第一信息;
根据所述第一应用下载请求,确定第一安装包;
确定所述第一安装包对应的第一库文件,并根据所述第一信息,确定所述第一电子设备是否包括所述第一库文件;
当所述第一电子设备包括所述第一库文件时,向所述第一电子设备发送所述第一安装包;或者,
当所述第一电子设备不包括所述第一库文件时,根据所述第一库文件和所述第一安装包生成第二安装包,向所述第一电子设备发送所述第二安装包。
2.根据权利要求1所述的方法,其特征在于,在所述接收第一电子设备发送的第一应用下载请求之前,所述方法还包括:
接收第二电子设备上传的第三安装包,所述第三安装包中包括所述第一库文件;
将所述第一库文件拆分出所述第三安装包,并生成引用目录,所述引用目录用于指示所述第一库文件;
基于所述引用目录和拆分后的所述第三安装包,生成所述第一安装包。
3.根据权利要求1或2所述的方法,其特征在于,所述确定所述第一安装包对应的第一库文件,包括:
根据所述第一安装包中的引用目录,确定所述第一安装包所需的所述第一库文件。
4.根据权利要求1-3任一项所述的方法,其特征在于,所述第一安装包所需的库文件为第一版本的第一库文件;
所述当所述第一电子设备包括所述第一库文件时,向所述第一电子设备发送所述第一安装包,包括:
根据所述第一信息,确定所述第一电子设备包括第二版本的第一库文件,所述第二版本和所述第一版本的版本相同,或所述第二版本高于所述第一版本;
向所述第一电子设备发送所述第一安装包。
5.根据权利要求1-3任一项所述的方法,其特征在于,所述第一安装包所需的库文件为第一版本的第一库文件;
所述当所述第一电子设备不包括所述第一库文件时,根据所述第一库文件和所述第一安装包生成第二安装包,向所述第一电子设备发送所述第二安装包,包括:
根据所述第一信息,确定所述第一电子设备不包括所述第一版本的第一库文件;或者,确定所述第一电子设备包括第三版本的第一库文件,所述第三版本高于或者低于所述第一版本;
根据所述第一版本的第一库文件和所述第一安装包生成第二安装包;
向所述第一电子设备发送所述第二安装包。
6.根据权利要求1-5任一项所述的方法,其特征在于,所述服务器中包括用于保存包括所述第一库文件的公共库。
7.一种应用管理方法,其特征在于,应用于第一电子设备,所述方法包括:
接收服务器发送的对应第一应用的第一安装包;
根据所述第一安装包中的引用目录,在共享库中获取第一库文件;
根据所述第一安装包,安装所述第一应用;
根据所述第一安装包和所述第一库文件,显示所述第一应用的界面。
8.根据权利要求7所述的方法,其特征在于,在所述接收服务器发送的对应于第一应用的第一安装包之前,所述方法还包括:
接收用户的第一操作;所述第一操作用于打开所述第一应用;
响应于所述第一操作,确定所述共享库的第一信息,所述第一信息用于指示所述共享库中包括所述第一库文件;
向所述服务器发送第一应用下载请求,所述第一应用下载请求中携带有所述第一信息,所述第一应用下载请求用于请求下载所述第一应用的安装包。
9.根据权利要求7或8所述的方法,其特征在于,所述方法还包括:
接收用户的第二操作;所述第二操作用于打开第二应用;
响应于所述第二操作,确定所述共享库的第二信息,所述第二信息用于指示所述共享库中包括第一版本的所述第一库文件;
向所述服务器发送第二应用下载请求,所述第二应用下载请求中携带有所述第二信息,所述第二应用下载请求用于请求下载所述第二应用的安装包;
接收所述服务器发送的第四安装包,所述第四安装包中包括第二版本的第一库文件,所述第二版本高于或者低于所述第一版本;
根据所述第四安装包,显示所述第二应用的界面,并将所述第二版本的第一库文件保存至所述共享库。
10.根据权利要求9所述的方法,其特征在于,所述方法还包括:
删除所述共享库中的所述第一版本的第一库文件。
11.一种应用管理系统,其特征在于,所述系统包括服务器和第一电子设备;
所述服务器,用于:
接收第一电子设备发送的第一应用下载请求,所述第一应用下载请求中携带有所述第一电子设备中的共享库的第一信息;
根据所述第一应用下载请求,确定第一安装包;
确定所述第一安装包对应的第一库文件,并根据所述第一信息,确定所述第一电子设备是否包括所述第一库文件;
所述服务器,还用于:
当所述第一电子设备包括所述第一库文件时,向所述第一电子设备发送所述第一安装包;
所述第一电子设备,用于:
接收服务器发送的对应于第一应用的第一安装包;
根据所述第一安装包中的引用目录,在所述共享库中获取第一库文件;
根据所述第一安装包和所述第一库文件,显示所述第一应用的界面;
或者,
所述服务器,还用于:
当所述第一电子设备不包括所述第一库文件时,根据所述第一库文件和所述第一安装包生成第二安装包,向所述第一电子设备发送所述第二安装包;
所述第一电子设备,用于:
接收所述第二安装包;
根据所述第二安装包,显示所述第一应用的界面。
12.根据权利要求11所述的系统,其特征在于,
所述服务器,还用于:
接收第二电子设备上传的第三安装包,所述第三安装包中包括所述第一库文件;
将所述第一库文件拆分出所述第三安装包,并生成引用目录,所述引用目录用于指示所述第一库文件;
基于所述引用目录和拆分后的所述第三安装包,生成所述第一安装包。
13.根据权利要求11或12所述的系统,其特征在于,
所述服务器,还用于:
根据所述第一安装包中的引用目录,确定所述第一安装包所需的所述第一库文件。
14.根据权利要求11-13任一项所述的系统,其特征在于,
所述电子设备,还用于:
接收用户的第一操作;所述第一操作用于打开所述第一应用;
响应于所述第一操作,确定所述共享库的第一信息,所述第一信息用于指示所述共享库中包括所述第一库文件;
向服务器发送所述第一应用下载请求,所述第一应用下载请求中携带有所述第一信息,所述第一应用下载请求用于请求下载所述第一应用的安装包。
15.一种服务器,其特征在于,包括:处理器和存储器,所述存储器和所述处理器耦合,所述存储器用于存储计算机程序代码,所述计算机程序代码包括计算机指令,当所述处理器从所述存储器中读取所述计算机指令,使得所述服务器执行如权利要求1-6中任意一项所述的方法。
16.一种电子设备,其特征在于,包括:处理器、存储器和显示屏,所述存储器、所述显示屏和所述处理器耦合,所述存储器用于存储计算机程序代码,所述计算机程序代码包括计算机指令,当所述处理器从所述存储器中读取所述计算机指令,使得所述电子设备执行如权利要求7-10任意一项所述的方法。
17.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质包括计算机程序,当所述计算机程序在服务器上运行时,使得所述服务器执行如权利要求1-6中任意一项所述的方法。
18.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质包括计算机程序,当所述计算机程序在电子设备上运行时,使得所述电子设备执行如权利要求7-10中任意一项所述的方法。
19.一种计算机程序产品,其特征在于,当所述计算机程序产品在计算机上运行时,使得所述计算机执行如权利要求1-6中任意一项所述的方法;或者,使得所述计算机执行如权利要求7-10中任意一项所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202211651152.9A CN118227222A (zh) | 2022-12-21 | 2022-12-21 | 应用管理方法、服务器、电子设备及系统 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202211651152.9A CN118227222A (zh) | 2022-12-21 | 2022-12-21 | 应用管理方法、服务器、电子设备及系统 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN118227222A true CN118227222A (zh) | 2024-06-21 |
Family
ID=91498565
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202211651152.9A Pending CN118227222A (zh) | 2022-12-21 | 2022-12-21 | 应用管理方法、服务器、电子设备及系统 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN118227222A (zh) |
-
2022
- 2022-12-21 CN CN202211651152.9A patent/CN118227222A/zh active Pending
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP4002108B1 (en) | Application start method and electronic device | |
WO2022089207A1 (zh) | 一种跨设备应用交互方法、电子设备与服务器 | |
CN114461239B (zh) | 软件升级系统和软件升级方法 | |
CN112860445B (zh) | 一种快应用与原生应用间数据共享的方法及终端 | |
CN118427176A (zh) | 文件共享方法、系统及相关设备 | |
WO2020037560A1 (zh) | 一种应用的安装方法及终端 | |
CN114968384B (zh) | 一种功能调用方法和装置 | |
CN116136826B (zh) | 内存访问方法、芯片、电子设备及计算机可读存储介质 | |
US20230350738A1 (en) | Method for Reusing Shared Library and Electronic Device | |
CN118227222A (zh) | 应用管理方法、服务器、电子设备及系统 | |
CN115278642B (zh) | 获取sim卡的信息的方法、电子设备及终端设备 | |
CN115221255A (zh) | 地图数据更新方法、装置及系统 | |
CN117389638B (zh) | 一种电子设备开机方法及电子设备 | |
CN117729561B (zh) | 系统升级方法、终端及存储介质 | |
WO2024022119A1 (zh) | 数据同步方法、电子设备及系统 | |
WO2024193526A1 (zh) | 一种备份方法及装置 | |
CN117707562B (zh) | 参数更新方法和终端设备 | |
WO2023142696A1 (zh) | 缩略图存储方法及电子设备 | |
CN117971305B (zh) | 操作系统的升级方法、服务器及电子设备 | |
CN117009023B (zh) | 显示通知信息的方法及相关装置 | |
CN117786706A (zh) | 访问控制方法及电子设备 | |
CN118034823A (zh) | 显示方法、电子设备、存储介质及程序产品 | |
CN117632534A (zh) | 一种进程间通信方法与电子设备 | |
CN118233492A (zh) | 应用下载方法、服务器、电子设备及系统 | |
CN118277120A (zh) | 一种管理系统服务的方法及相关装置 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination |