CN113821273A - 一种应用程序运行方法、计算设备及存储介质 - Google Patents

一种应用程序运行方法、计算设备及存储介质 Download PDF

Info

Publication number
CN113821273A
CN113821273A CN202111117069.9A CN202111117069A CN113821273A CN 113821273 A CN113821273 A CN 113821273A CN 202111117069 A CN202111117069 A CN 202111117069A CN 113821273 A CN113821273 A CN 113821273A
Authority
CN
China
Prior art keywords
information
section
file
module
application program
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.)
Granted
Application number
CN202111117069.9A
Other languages
English (en)
Other versions
CN113821273B (zh
Inventor
钟俊
江峰
柏鑫
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Wuhan Deepin Technology Co ltd
Original Assignee
Wuhan Deepin Technology Co ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Wuhan Deepin Technology Co ltd filed Critical Wuhan Deepin Technology Co ltd
Priority to CN202111117069.9A priority Critical patent/CN113821273B/zh
Publication of CN113821273A publication Critical patent/CN113821273A/zh
Application granted granted Critical
Publication of CN113821273B publication Critical patent/CN113821273B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/44Arrangements for executing specific programs
    • G06F9/445Program loading or initiating
    • G06F9/44505Configuring for program initiating, e.g. using registry, configuration files
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/40Transformation of program code
    • G06F8/41Compilation
    • G06F8/44Encoding
    • G06F8/447Target code generation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/44Arrangements for executing specific programs
    • G06F9/445Program loading or initiating
    • G06F9/44557Code layout in executable memory

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

一种应用程序运行方法、计算设备及存储介质
技术领域
本发明涉及操作***领域,特别涉及一种应用程序运行方法、计算设备及存储介质。
背景技术
随着计算机技术的不断发展,开发出越来越多的应用程序。相应的,应用的数据也越来越多,数据结构也越来越复杂。在使用应用程序的过程中,有时需要在应用程序的基础上实现额外的附加功能,或了解应用的运行情况等。
在现有技术中,应用程序在加载时,经过编译等一些列操作得到二进制文件,无法对该二进制文件进行处理。因此,要实现应用程序的附加功能必须要在应用程序还未编译时,修改其源代码,向其中添加所需要的功能,之后再重新进行编译。这种方式不仅较为复杂,并且不适用于一些特殊场景,如没有源代码文件或者无法对源代码进行修改的时候,就无法实现在应用程序中添加附加功能。
为此,需要一种新的应用程序运行方法。
发明内容
为此,本发明提供一种应用程序运行方法,以力图解决或者至少缓解上面存在的问题。
根据本发明的一个方面,提供一种应用程序运行方法,适于在计算设备中执行,计算设备中包括内部存储器和外部存储器,外部存储器中存储有应用文件和模块文件,方法包括步骤:根据应用文件生成应用程序的可执行文件;根据应用程序的可执行文件,确定应用程序在内部存储器中存储的第一存储信息,第一存储信息包括在内部存储器中所分配的初始化数据区段的第一区段信息;根据第一区段信息和模块文件生成初始化数据区段的第二区段信息;根据第二区段信息和第一存储信息生成第二存储信息;根据第二存储信息将应用程序的可执行文件和模块文件加载到内部存储器;根据内部存储器中的可执行文件和模块文件运行应用程序,并在应用程序中构建功能模块,以实现应用程序的附加功能。
可选地,在根据本发明的方法中,根据应用程序的可执行文件,确定应用程序在内部存储器中存储的第一存储信息包括步骤:根据可执行文件,确定在内部存储器中分配的初始化数据区段的第一区段大小和第一对齐信息;根据第一区段大小和第一对齐信息生成初始化数据区段的第一区段信息;根据第一区段信息生成第一存储信息。
可选地,在根据本发明的方法中,根据第一区段信息和所述模块文件生成第二区段信息包括步骤:根据第一区段大小和模块文件生成第二区段大小;根据第一对齐信息和模块文件生成第二对齐信息;根据第二区段大小和第二对齐信息生成未初始化数据区段的预设区段信息;确定模块文件根据所生成的预设区段信息在内部存储器中存储时是否跨页边界存储;若模块文件不跨页边界存储,则将预设区段信息作为第二区段信息。
可选地,在根据本发明的方法中,若模块文件跨页边界存储,则在模块文件的存储位置之前添加占位区段,使模块文件不跨页边界存储;根据所添加的占位区段和预设区段信息生成第二区段信息。
可选地,在根据本发明的方法中,根据第一区段大小和模块文件生成第二区段大小包括步骤:将第一区段大小和模块文件的文件大小相加,得到第二区段大小。
可选地,在根据本发明的方法中,根据第一区段大小和模块文件生成第二区段大小包括步骤:将第一区段大小和模块文件的文件大小相加,得到第二区段大小。
可选地,在根据本发明的方法中,根据第二存储信息将应用程序的可执行文件和模块文件加载到内部存储器包括步骤:根据第二存储信息在内部存储器中分配初始化数据区段;根据第二存储信息将可执行文件加载到内部存储器;根据第二存储信息的初始化数据区段的第二区段信息,将模块文件加载到初始化数据区段。
可选地,在根据本发明的方法中,根据第二存储信息在内部存储器中分配初始化数据区段包括步骤:根据第二存储信息确定模块文件存储的起始地址;在模块文件存储的起始地址添加初始化标识,以便根据初始化标识***模块文件。
可选地,在根据本发明的方法中,在模块文件存储的起始位置添加初始化标识包括步骤:构建数据地址表,数据地址表包括数据地址行;在数据地址行中添加内部存储器存储模块文件的内存页首地址、模块文件存储的起始位地址和区段类型,区段类型为初始化数据区段。
可选地,在根据本发明的方法中,计算设备中还包括处理器,根据第二存储信息将可执行文件加载到内部存储器包括步骤:当处理器由于初始化数据区段未存储相关数据而产生缺页异常时,将可执行文件的初始化数据写入初始化数据区段。
可选地,在根据本发明的方法中,根据第二存储信息的初始化数据区段的第二区段信息,将模块文件加载到初始化数据区段包括步骤:根据模块文件在内部存储器中存储的内存页首地址,从数据地址表中查询是否有包括内存页首地址的数据地址行;若查询到包括内存页首地址的数据地址行,则确定数据地址行的区段类型;若区段类型为初始化数据区段,则对模块文件的数据进行初始化,得到模块文件的初始化数据;根据模块文件存储的起始地址,将模块文件的初始化数据在初始化数据区段中进行存储。
可选地,在根据本发明的方法中,将模块文件的初始化数据在初始化数据区段中进行存储包括步骤:根据第二区段信息的第二对齐方式确定模块对齐方式;根据模块对齐方式在初始化数据区段中存储模块文件的初始化数据。
可选地,在根据本发明的方法中,将模块文件的初始化数据在初始化数据区段中进行存储包括步骤:根据第二区段信息的第二对齐方式确定模块对齐方式;根据模块对齐方式在初始化数据区段中存储模块文件的初始化数据。
根据本发明的另一方面,提供了一种计算设备,包括:一个或多个处理器;存储器;以及一个或多个程序,其中一个或多个程序存储在存储器中并被配置为由一个或多个处理器执行,一个或多个程序包括用于执行根据本发明的一种应用程序运行方法的指令。
根据本发明的再一个方面,提供了一种存储一个或多个程序的计算机可读存储介质,一个或多个程序包括指令,该指令当由计算设备执行时,使得计算设备执行根据本发明的一种应用程序运行方法中的方法。
本发明中的应用程序运行方法,适于在计算设备中执行,计算设备包括外部存储器和内部存储器,外部存储器中存储有应用文件和模块文件。首先根据应用文件生成应用程序的可执行文件,在对应用进行加载时,需要将外部存储器中的应用文件进行处理得到二进制类型文件的可执行文件,才能将其存入内部存储器中。随后根据应用程序的可执行文件,确定应用程序在内部存储器中存储的第一存储信息,第一存储信息包括在内部存储器中所分配的初始化数据区段的第一区段信息。在内部存储器中加载应用程序的可执行文件时,在内部存储器中划分有多个区段,在每个区段加载可执行文件的相应数据。内部存储器的其中一个区段为初始化数据区段,若需要在应用程序中***的模块文件需要使用到一个新数据,而该数据需要被赋予初始值,则需要将新数据***到初始化数据区段中。为了将模块文件加载到初始化数据区段,需要根据初始化数据区段的第一区段信息和模块文件,重新生成初始化数据区段的第二区段信息。再根据第二区段信息和第一存储信息生成第二存储信息,以便根据第二存储信息将应用程序的可执行文件和模块文件加载到内部存储器。在将应用程序的可执行文件和模块文件一起加载到内部存储器后,即可在应用程序中构建功能模块,以实现应用程序的附加功能。
附图说明
为了实现上述以及相关目的,本文结合下面的描述和附图来描述某些说明性方面,这些方面指示了可以实践本文所公开的原理的各种方式,并且所有方面及其等效方面旨在落入所要求保护的主题的范围内。通过结合附图阅读下面的详细描述,本发明公开的上述以及其它目的、特征和优势将变得更加明显。遍及本公开,相同的附图标记通常指代相同的部件或元素。
图1示出了根据本发明一个示范性实施例的外部存储器和内部存储器的结构示意图;
图2示出了根据本发明一个示范性实施例的计算设备200的结构框图;
图3示出了根据本发明一个示范性实施例的应用程序运行方法300的流程示意图;
图4示出了根据本发明一个示范性实施例的向初始化数据区段***模块文件的示意图;以及
图5示出了根据本发明一个示范性实施例的生成第二区段信息的流程示意图。
具体实施方式
下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。相同的附图标记通常指代相同的部件或元素。
图1示出了根据本发明一个示范性实施例的外部存储器和内部存储器的结构示意图。如图1所示,计算设备200中包括内部存储器230和外部存储器210,并运行有操作***220。本发明对操作***220的种类不做限制。外部存储器210中存储有应用文件111和模块文件112。图1所示的外部存储器210所存储应用文件111和模块文件112的方式仅为示例性的,本发明对外部存储器210中所存储应用文件和模块文件的数量不做限制。
应用文件111可实现为任一种应用程序的应用文件,本发明对应用程序的种类及其应用文件的类型不做限制。根据本发明的一个实施例,应用文件111由操作***220进行编译,汇编,链接等步骤得到应用程序的可执行文件,最终加载到内部存储器230中。
模块文件112可实现为任一种功能模块的模块文件,功能模块可实现应用程序的附加功能,本发明对模块文件112的文件类型,以及实现的应用程序附加功能的种类不做限制。模块文件112可以是未经过编译的文件,在加载到内部存储器230时预先进行处理,得到可以加载到内部存储器230中的功能模块的可执行文件。模块文件112还可以实现为二进制类型文件,方便直接加载到内部存储器230中的相应位置。
模块文件112由开发人员预先进行构建,为了在应用程序中实现附加功能,需要将模块文件112加载到内部存储器230中,具体的需要存储到内部存储器230存储应用程序的可执行文件的相应位置。模块文件112在部署到相应位置后,模块文件112对应用程序透明,应用程序并不感知和使用模块文件112,直接由操作***220调用模块文件112构建功能模块,实现应用程序的附加功能。
内部存储器230在存储应用程序的可执行文件时,为可执行文件分配存储空间。内部存储器230所分配的存储空间包括多个不同的内存区段,将可执行文件以内存区段的形式在内部存储器230中进行存储。内部存储器230将存储空间所划分的内存区段包括堆区段、堆栈区段、初始化数据区段和未初始化数据区段。内存区段由操作***在创建进程时,根据应用程序可执行文件的文件信息确定第一存储信息,根据第一存储器信息在内部存储器230中进行划分。
其中,初始化数据区段用来存放应用程序中已初始化的全局变量,是静态内存分配。若需要在应用程序中***的模块文件需要使用到一个新数据,而该数据需要被赋予初始值,则需要将模块文件***到初始化数据区段中,从而保证能够对模块文件中需要进行初始化的数据进行初始化,正常加载模块文件,实现应用程序的附加功能。
图1中的计算设备200的具体结构如图2所示。图2示出了根据本发明一个示范性实施例的计算设备200的结构框图。如图2所示,在基本的配置202中,计算设备200典型地包括***存储器206和一个或者多个处理器204。存储器总线208可以用于在处理器204和***存储器206之间的通信。
取决于期望的配置,处理器204可以是任何类型的处理,包括但不限于:微处理器(μP)、微控制器(μC)、数字信息处理器(DSP)或者它们的任何组合。处理器204可以包括诸如一级高速缓存210和二级高速缓存212之类的一个或者多个级别的高速缓存、处理器核心214和寄存器216。示例的处理器核心214可以包括运算逻辑单元(ALU)、浮点数单元(FPU)、数字信号处理核心(DSP核心)或者它们的任何组合。示例的存储器控制器218可以与处理器204一起使用,或者在一些实现中,存储器控制器218可以是处理器204的一个内部部分。
取决于期望的配置,***存储器206可以是任意类型的存储器,包括但不限于:易失性存储器(诸如RAM)、非易失性存储器(诸如ROM、闪存等)或者它们的任何组合。***存储器206可以包括操作***220、一个或者多个程序222以及程序数据228。在一些实施方式中,程序222可以布置为在操作***上由一个或者多个处理器204利用程序数据228执行根据本发明的方法300的指令223。
计算设备200还可以包括储存接口总线234。储存接口总线234实现了从储存设备232(例如,可移除储存器236和不可移除储存器238)经由总线/接口控制器230到基本配置202的通信。操作***220、程序222以及数据224的至少一部分可以存储在可移除储存器236和/或不可移除储存器238上,并且在计算设备200上电或者要执行程序222时,经由储存接口总线234而加载到***存储器206中,并由一个或者多个处理器204来执行。
计算设备200还可以包括有助于从各种接口设备(例如,输出设备242、外设接口244和通信设备246)到基本配置202经由总线/接口控制器230的通信的接口总线240。示例的输出设备242包括图形处理单元248和音频处理单元250。它们可以被配置为有助于经由一个或者多个A/V端口252与诸如显示器或者扬声器之类的各种外部设备进行通信。示例***接口244可以包括串行接口控制器254和并行接口控制器256,它们可以被配置为有助于经由一个或者多个I/O端口258和诸如输入设备(例如,键盘、鼠标、笔、语音输入设备、触摸输入设备)或者其他外设(例如打印机、扫描仪等)之类的外部设备进行通信。示例的通信设备246可以包括网络控制器260,其可以被布置为以便经由一个或者多个通信端口264与一个或者多个其他计算设备262通过网络通信链路的通信。
网络通信链路可以是通信介质的一个示例。通信介质通常可以体现为在诸如载波或者其他传输机制之类的调制数据信号中的计算机可读指令、数据结构、程序模块,并且可以包括任何信息递送介质。“调制数据信号”可以这样的信号,它的数据集中的一个或者多个或者它的改变可以在信号中编码信息的方式进行。作为非限制性的示例,通信介质可以包括诸如有线网络或者专线网络之类的有线介质,以及诸如声音、射频(RF)、微波、红外(IR)或者其它无线介质在内的各种无线介质。这里使用的术语计算机可读介质可以包括存储介质和通信介质二者。
在根据本发明的计算设备200中,程序222包括应用程序运行方法300的多条程序指令,这些程序指令可以指示处理器204执行本发明的计算设备200中运行的应用程序运行方法300中的部分步骤,以便计算设备200中的各部分通过执行本发明的应用程序运行方法300来运行应用程序。
计算设备200可以实现为服务器,例如文件服务器240、数据库250、服务器、应用程序服务器等,这些电子设备可以是诸如个人数字助理(PDA)、无线网络浏览设备、应用专用设备、或者可以包括上面任何功能的混合设备。可以实现为包括桌面计算机和笔记本计算机配置的个人计算机,也在一些实施例中,计算设备200被配置为应用程序运行方法300。
图3示出了根据本发明一个示范性实施例的应用程序运行方法300的流程示意图。本发明中的应用程序运行方法300在计算设备中执行,并进一步的适于在如图1所示的计算设备200中执行。如图3所示,指令执行方法300始于步骤S310,根据应用文件111生成应用程序的可执行文件。
在外部存储器210中存储的应用文件111未进行预处理,不能直接加载到内部存储器230中。根据本发明的一个实施例,应用文件111需要由操作***220对其进行编译、汇编和链接等步骤得到应用程序的可执行文件。本发明对操作***220对应用文件111进行预处理的步骤和方法不做限制。
随后,执行步骤S320,根据应用程序的可执行文件,确定应用程序在内部存储器230中存储的第一存储信息,第一存储信息包括在内部存储器230中所分配的初始化数据区段的第一区段信息。
应用程序在内部存储器230中存储的第一存储信息包括多个内存区段的区段信息。内部存储器230中所划分的内存区段包括堆区段、堆栈区段、代码区段、初始化数据区段和未初始化数据区段。内存区段由操作***220在创建进程时,根据应用程序可执行文件的文件信息确定第一存储信息,根据第一存储器信息在内部存储器230中进行划分的。其中,初始化数据区段存储可执行文件中的进行了初始化的初始化数据,包括应用程序中初始化的全局变量。
根据应用程序的可执行文件,确定应用程序在内部存储器230中存储的第一存储信息时,根据可执行文件,确定在内部存储器230中分配的初始化数据区段的第一区段大小和第一对齐信息。具体的根据可执行文件中的初始化数据,即应用程序中有多少初始化的全局变量,确定第一区段大小;随后根据处理器的取指方式决定确定可执行文件在内部存储器230中存储的应用对齐方式,作为第一对齐信息。第一对齐信息指初始化数据区段的起始地址应该从哪个对齐边界开始(比如:2、4、8、32字节对齐等等)它决定了初始化数据区段的起始位置,具体由处理器的取指方式决定。
接着根据第一区段大小和第一对齐信息生成初始化数据区段的第一区段信息,第一区段信息包括第一区段大小和第一对齐信息。
接着根据第一区段信息生成第一存储信息,将初始化数据区段的第一区段信息和其他数据区段的区段信息作为第一存储信息。其他数据区段包括堆区段、堆栈区段、代码区段和未初始化数据区段。
随后,执行步骤S330,根据第一区段信息和模块文件112生成初始化数据区段的第二区段信息。
图4示出了根据本发明一个示范性实施例的向初始化数据区段***模块文件的示意图。如图4所示,将模块文件415***初始化数据区段416,初始化数据区段416的区段信息为根据步骤S310和S320计算得到的第一区段信息。在内部存储器230中加载可执行文件时,增加可执行文件存储时所需要的存储空间;具体的在初始化数据区段416为模块文件415预留存储空间。预留存储空间本身并不在可执行文件存储时所需要的存储空间中,通过增加预留存储空间,即可实现在初始化数据区段416中***模块文件415。模块文件415与图1中的模块文件112相同,但若模块文件112不能直接存储到内部存储器230中时,需要将模块文件112进行预处理得到模块文件415。
将模块文件415***初始化数据区段416后,得到初始化数据区段426。初始化数据区段426相比初始化数据区段416大小和起始位置均发生变化,需要重新计算初始化数据区段426的区段信息,得到第二区段信息。
图5示出了根据本发明一个示范性实施例的生成第二区段信息的流程示意图。如图5所示,首先获取第一区段信息,根据第一区段大小和模块文件112生成第二区段大小,生成第二区段大小时,将第一区段大小和模块文件112的文件大小相加,得到第二区段大小。
接着根据第一对齐信息和模块文件112生成第二对齐信息,第一对齐信息包括应用对齐方式,应用对齐方式指初始化数据区段的起始地址应该从哪个对齐边界开始,决定了初始化数据区段的起始位置。生成第二对齐信息时,根据应用对齐方式生成模块对齐方式,初始化数据区段从哪个对齐边界开始,模块文件112就从哪个对齐边界开始,保证模块文件112在内部存储器230中的模块对齐方式与可执行文件在内部存储器230中的应用对齐方式相同。
根据本发明的一个实施例,初始化数据区段以32位字节对齐,则模块文件112也以32位字节对齐。
接着根据应用对齐方式和模块对齐方式生成第二对齐信息。第二对齐信息包括应用对齐方式和模块对齐方式。
接着根据第二区段大小和第二对齐信息生成初始化数据区段的预设区段信息。预设区段信息包括第二区段大小和第二对齐信息。
接着确定模块文件根据所生成的预设区段信息在内部存储器中存储时是否跨页边界存储。内部存储器在存储数据时应用内存分页机制,以内存页的方式存储数据。若模块文件不跨页边界存储,则将预设区段信息作为第二区段信息。若模块文件跨页边界存储,则在模块文件的存储位置之前添加占位区段,使模块文件不跨页边界存储,便于处理器从内部存储器中读取和处理透明数据。最后根据所添加的占位区段和预设区段信息生成第二区段信息。在占位区段后存储模块文件,随后根据占位区段的大小重新确定第二区段大小和第二对齐信息,根据修改后的第二区段大小和第二对齐信息生成第二区段信息。
随后,执行步骤S340,根据第二区段信息和第一存储信息生成第二存储信息。生成第二存储信息时,将初始化数据区段的第二区段信息,与第一存储信息中的其他数据区段的区段信息进行组合,得到第二存储信息。其他数据区段包括堆区段、堆栈区段、代码区段和未初始化数据区段。
随后,执行步骤S350,根据第二存储信息将应用程序的可执行文件和模块文件112加载到内部存储器230。将应用程序的可执行文件和模块文件112加载到内部存储器230时,首先根据第二存储信息在内部存储器中分配初始化数据区段。
分配初始化数据区段时,根据第二区段大小确定初始化数据区段的大小,并根据第二对齐信息确定存储初始化数据区段的内存页首地址、初始化数据区段所在内存页中模块文件存储的起始地址以及应用文件存储的起始地址。
如图4所示,分配的初始化数据区段426相对于计算的初始化数据区段416大小增加,增加的预留存储空间用于存储模块文件415。将原本初始化数据区段416所要存储的应用程序的未初始化数据依旧在未初始化数据区段426中进行存储。
随后,在模块文件存储的起始地址添加初始化标识,以便根据初始化标识***模块文件。添加初始化标识时,构建数据地址表,数据地址表存储一个或多个数据地址行。数据地址表用于确定是否需要初始化数据,以及检索初始化数据存储的起始位置,以便将初始化的数据存入相应起始位置。
接着在数据地址行中添加内部存储器存储模块文件的内存页首地址、模块文件存储的起始位地址和区段类型,区段类型为初始化数据区段。根据是否有数据地址行存储模块文件的内存页首地址以及区段类型,即可判断该内存页中是否需要进行数据的初始化。若需要进行数据初始化,则根据模块文件存储的起始位地址存入初始化数据。
计算设备中还包括处理器(图1未示出)。处理器从内部存储器中读取并处理数据。在分配数据区段时,仅分配了数据存储的区段,设置了模块文件的初始化标识,未完成应用文件和模块文件的存储。处理器根据模块文件存储的起始地址以及应用文件存储的起始地址访问和获取模块文件和应用文件。处理器会根据文件的存储地址检查相应位置是否存储了相应文件,具有实际的内存,若没有则会抛出缺页异常。
根据第二存储信息将可执行文件加载到内部存储器包括步骤,当处理器由于初始化数据区段未存储相关数据而产生缺页异常时,将可执行文件的初始化数据写入初始化数据区段。在生成应用程序的可执行文件时,将应用程序需要进行初始化的数据进行初始化,得到可执行文件中的初始化数据。
随后,根据第二存储信息的初始化数据区段的第二区段信息,将模块文件加载到初始化数据区段时,首先根据模块文件在内部存储器中存储的内存页首地址,从数据地址表中查询是否有包括内存页首地址的数据地址行。数据地址表中存储有一个或多个数据地址行。并且若查询到包括内存页首地址的数据地址行,则确定数据地址行的区段类型,以便确定是否需要进行数据初始化操作。
若区段类型为初始化数据区段,则对模块文件的数据进行初始化,得到模块文件的初始化数据,根据模块文件存储的起始地址,将模块文件的初始化数据在初始化数据区段中进行存储,从而实现将模块文件***应用程序。将模块文件112的初始化数据加载到初始化数据区段时,根据第二区段信息的第二对齐方式确定模块对齐方式,根据模块对齐方式在初始化数据区段中存储模块文件112。
根据本发明的一个实施例,模块对齐方式为以32位字节对齐时,将模块文件112以32位字节作为对齐边界在初始化数据区段425中进行存储。
最后,执行步骤S360,根据内部存储器230中的可执行文件和模块文件112运行应用程序,并在应用程序中构建功能模块,以实现应用程序的附加功能。内部存储器230中的包括可直接调用执行的可执行文件和模块文件112,由操作***220可直接调用执行可执行文件以运行应用。并且,操作***220根据计算的模块文件112在初始化数据区段所存储的起始位置,调取模块文件,构建功能模块,实现应用程序的附加功能。
本发明中的应用程序运行方法,适于在计算设备中执行,计算设备包括外部存储器和内部存储器,外部存储器中存储有应用文件和模块文件。首先根据应用文件生成应用程序的可执行文件,在对应用进行加载时,需要将外部存储器中的应用文件进行处理得到二进制类型文件的可执行文件,才能将其存入内部存储器中。随后根据应用程序的可执行文件,确定应用程序在内部存储器中存储的第一存储信息,第一存储信息包括在内部存储器中所分配的初始化数据区段的第一区段信息。在内部存储器中加载应用程序的可执行文件时,在内部存储器中划分有多个区段,在每个区段加载可执行文件的相应数据。内部存储器的其中一个区段为初始化数据区段,若需要在应用程序中***的模块文件需要使用到一个新数据,而该数据需要被赋予初始值,则需要将新数据***到初始化数据区段中。为了将模块文件加载到初始化数据区段,需要根据初始化数据区段的第一区段信息和模块文件,重新生成初始化数据区段的第二区段信息。再根据第二区段信息和第一存储信息生成第二存储信息,以便根据第二存储信息将应用程序的可执行文件和模块文件加载到内部存储器。在将应用程序的可执行文件和模块文件一起加载到内部存储器后,即可在应用程序中构建功能模块,以实现应用程序的附加功能。
在此处所提供的说明书中,说明了大量具体细节。然而,能够理解,本发明的实施例可以在没有这些具体细节的情况下被实践。在一些实例中,并未详细示出公知的方法、结构和技术,以便不模糊对本说明书的理解。
A9、如A8所述的方法,其中,所述在所述模块文件存储的起始位置添加初始化标识包括步骤:
构建数据地址表,所述数据地址表包括数据地址行;
在所述数据地址行中添加所述内部存储器存储所述模块文件的内存页首地址、模块文件存储的起始位地址和区段类型,所述区段类型为初始化数据区段。
A10、如A7-A9中任一项所述的方法,其中,所述计算设备中还包括处理器,所述根据所述第二存储信息将所述可执行文件加载到所述内部存储器包括步骤:
当所述处理器由于所述初始化数据区段未存储相关数据而产生缺页异常时,将所述可执行文件的初始化数据写入所述初始化数据区段。
A11、如A10所述的方法,其中,所述根据所述第二存储信息的初始化数据区段的第二区段信息,将所述模块文件加载到所述初始化数据区段包括步骤:
根据所述模块文件在所述内部存储器中存储的内存页首地址,从所述数据地址表中查询是否有包括所述内存页首地址的数据地址行;
若查询到包括所述内存页首地址的数据地址行,则确定所述数据地址行的区段类型;
若所述区段类型为初始化数据区段,则对所述模块文件的数据进行初始化,得到所述模块文件的初始化数据;
根据所述模块文件存储的起始地址,将所述模块文件的初始化数据在所述初始化数据区段中进行存储。
A12、如A11所述的方法,其中,所述将所述模块文件的初始化数据在所述初始化数据区段中进行存储包括步骤:
根据所述第二区段信息的第二对齐方式确定模块对齐方式;
根据所述模块对齐方式在所述初始化数据区段中存储所述模块文件的初始化数据。
A13、如A12所述的方法,其中,在所述应用程序中构建功能模块包括步骤:
根据所述模块文件在所述初始化数据区段所存储的起始位置,调取所述模块文件,构建所述功能模块。
类似地,应当理解,为了精简本公开并帮助理解各个发明方面中的一个或多个,在上面对本发明的示例性实施例的描述中,本发明的各个特征有时被一起分组到单个实施例、图、或者对其的描述中。然而,并不应将该公开的方法解释成反映如下意图:即所要求保护的本发明要求比在每个权利要求中所明确记载的特征更多特征。更确切地说,如下面的权利要求书所反映的那样,发明方面在于少于前面公开的单个实施例的所有特征。因此,遵循具体实施方式的权利要求书由此明确地并入该具体实施方式,其中每个权利要求本身都作为本发明的单独实施例。
本领域那些技术人员应当理解在本文所公开的示例中的设备的模块或单元或组间可以布置在如该实施例中所描述的设备中,或者可替换地可以定位在与该示例中的设备不同的一个或多个设备中。前述示例中的模块可以组合为一个模块或者此外可以分成多个子模块。
本领域那些技术人员可以理解,可以对实施例中的设备中的模块进行自适应性地改变并且把它们设置在与该实施例不同的一个或多个设备中。可以把实施例中的模块或单元或组间组合成一个模块或单元或组间,以及此外可以把它们分成多个子模块或子单元或子组间。除了这样的特征和/或过程或者单元中的至少一些是相互排斥之外,可以采用任何组合对本说明书(包括伴随的权利要求、摘要和附图)中公开的所有特征以及如此公开的任何方法或者设备的所有过程或单元进行组合。除非另外明确陈述,本说明书(包括伴随的权利要求、摘要和附图)中公开的每个特征可以由提供相同、等同或相似目的的替代特征来代替。
此外,本领域的技术人员能够理解,尽管在此所述的一些实施例包括其它实施例中所包括的某些特征而不是其它特征,但是不同实施例的特征的组合意味着处于本发明的范围之内并且形成不同的实施例。例如,在下面的权利要求书中,所要求保护的实施例的任意之一都可以以任意的组合方式来使用。
此外,所述实施例中的一些在此被描述成可以由计算机***的处理器或者由执行所述功能的其它装置实施的方法或方法元素的组合。因此,具有用于实施所述方法或方法元素的必要指令的处理器形成用于实施该方法或方法元素的装置。此外,装置实施例的在此所述的元素是如下装置的例子:该装置用于实施由为了实施该发明的目的的元素所执行的功能。
这里描述的各种技术可结合硬件或软件,或者它们的组合一起实现。从而,本发明的方法和设备,或者本发明的方法和设备的某些方面或部分可采取嵌入有形媒介,例如软盘、CD-ROM、硬盘驱动器或者其它任意机器可读的存储介质中的程序代码(即指令)的形式,其中当程序被载入诸如计算机之类的机器,并被所述机器执行时,所述机器变成实践本发明的设备。
在程序代码在可编程计算机上执行的情况下,计算设备一般包括处理器、处理器可读的存储介质(包括易失性和非易失性存储器和/或存储元件),至少一个输入装置,和至少一个输出装置。其中,存储器被配置用于存储程序代码;处理器被配置用于根据该存储器中存储的所述程序代码中的指令,执行本发明的应用程序运行方法。
以示例而非限制的方式,计算机可读介质包括计算机存储介质和通信介质。计算机可读介质包括计算机存储介质和通信介质。计算机存储介质存储诸如计算机可读指令、数据结构、程序模块或其它数据等信息。通信介质一般以诸如载波或其它传输机制等已调制数据信号来体现计算机可读指令、数据结构、程序模块或其它数据,并且包括任何信息传递介质。以上的任一种的组合也包括在计算机可读介质的范围之内。
如在此所使用的那样,除非另行规定,使用序数词“第一”、“第二”、“第三”等等来描述普通对象仅仅表示涉及类似对象的不同实例,并且并不意图暗示这样被描述的对象必须具有时间上、空间上、排序方面或者以任意其它方式的给定顺序。
尽管根据有限数量的实施例描述了本发明,但是受益于上面的描述,本技术领域内的技术人员明白,在由此描述的本发明的范围内,可以设想其它实施例。此外,应当注意,本说明书中使用的语言主要是为了可读性和教导的目的而选择的,而不是为了解释或者限定本发明的主题而选择的。因此,在不偏离所附权利要求书的范围和精神的情况下,对于本技术领域的普通技术人员来说许多修改和变更都是显而易见的。对于本发明的范围,对本发明所做的公开是说明性的,而非限制性的,本发明的范围由所附权利要求书限定。

Claims (10)

1.一种应用程序运行方法,适于在计算设备中执行,所述计算设备中包括内部存储器和外部存储器,所述外部存储器中存储有应用文件和模块文件,所述方法包括步骤:
根据所述应用文件生成应用程序的可执行文件;
根据所述应用程序的可执行文件,确定应用程序在所述内部存储器中存储的第一存储信息,所述第一存储信息包括在所述内部存储器中所分配的初始化数据区段的第一区段信息;
根据所述第一区段信息和所述模块文件生成所述初始化数据区段的第二区段信息;
根据所述第二区段信息和所述第一存储信息生成第二存储信息;
根据所述第二存储信息将所述应用程序的可执行文件和模块文件加载到所述内部存储器;
根据所述内部存储器中的可执行文件和模块文件运行所述应用程序,并在所述应用程序中构建功能模块,以实现所述应用程序的附加功能。
2.如权利要求1所述的方法,其中,所述根据所述应用程序的可执行文件,确定应用程序在所述内部存储器中存储的第一存储信息包括步骤:
根据所述可执行文件,确定在所述内部存储器中分配的初始化数据区段的第一区段大小和第一对齐信息;
根据所述第一区段大小和第一对齐信息生成所述初始化数据区段的第一区段信息;
根据所述第一区段信息生成第一存储信息。
3.如权利要求2所述的方法,其中,所述根据所述第一区段信息和所述模块文件生成第二区段信息包括步骤:
根据所述第一区段大小和所述模块文件生成第二区段大小;
根据所述第一对齐信息和所述模块文件生成第二对齐信息;
根据所述第二区段大小和第二对齐信息生成所述未初始化数据区段的预设区段信息;
确定所述模块文件根据所生成的预设区段信息在所述内部存储器中存储时是否跨页边界存储;
若所述模块文件不跨页边界存储,则将所述预设区段信息作为第二区段信息。
4.如权利要求3所述的方法,其中,所述方法还包括步骤:
若所述模块文件跨页边界存储,则在所述模块文件的存储位置之前添加占位区段,使所述模块文件不跨页边界存储;
根据所添加的占位区段和所述预设区段信息生成第二区段信息。
5.如权利要求3或4所述的方法,其中,所述根据所述第一区段大小和所述模块文件生成第二区段大小包括步骤:
将所述第一区段大小和所述模块文件的文件大小相加,得到所述第二区段大小。
6.如权利要求3-5中任一项所述的方法,其中,所述第一对齐信息包括应用对齐方式,所述根据所述第一对齐信息和所述模块文件生成第二对齐信息包括步骤:
根据所述应用对齐方式生成模块对齐方式;
根据所述应用对齐方式和模块对齐方式生成第二对齐信息,以保证所述模块文件在所述内部存储器中的模块对齐方式与可执行文件在内部存储器中的应用对齐方式相同。
7.如权利要求6所述的方法,其中,所述根据所述第二存储信息将所述应用程序的可执行文件和模块文件加载到所述内部存储器包括步骤:
根据所述第二存储信息在所述内部存储器中分配初始化数据区段;
根据所述第二存储信息将所述可执行文件加载到所述内部存储器;
根据所述第二存储信息的初始化数据区段的第二区段信息,将所述模块文件加载到所述初始化数据区段。
8.如权利要求7所述的方法,其中,所述根据所述第二存储信息在所述内部存储器中分配初始化数据区段包括步骤:
根据所述第二存储信息确定所述模块文件存储的起始地址;
在所述模块文件存储的起始地址添加初始化标识,以便根据所述初始化标识***模块文件。
9.一种计算设备,包括:
一个或多个处理器;
存储器;以及
一个或多个装置,所述一个或多个装置包括用于执行根据权利要求1-8中任一项所述的方法的指令。
10.一种存储一个或多个程序的计算机可读存储介质,所述一个或多个程序包括指令,所述指令当由计算设备执行时,使得所述计算设备执行根据权利要求1-8中任一项所述的方法。
CN202111117069.9A 2021-09-23 2021-09-23 一种应用程序运行方法、计算设备及存储介质 Active CN113821273B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202111117069.9A CN113821273B (zh) 2021-09-23 2021-09-23 一种应用程序运行方法、计算设备及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202111117069.9A CN113821273B (zh) 2021-09-23 2021-09-23 一种应用程序运行方法、计算设备及存储介质

Publications (2)

Publication Number Publication Date
CN113821273A true CN113821273A (zh) 2021-12-21
CN113821273B CN113821273B (zh) 2023-10-13

Family

ID=78920994

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202111117069.9A Active CN113821273B (zh) 2021-09-23 2021-09-23 一种应用程序运行方法、计算设备及存储介质

Country Status (1)

Country Link
CN (1) CN113821273B (zh)

Citations (18)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1329309A (zh) * 2000-06-13 2002-01-02 微软公司 操作***的多语言用户接口
CN101452402A (zh) * 2008-11-28 2009-06-10 珠海金山软件股份有限公司 软件运行***和软件运行方法
CN103473059A (zh) * 2013-09-11 2013-12-25 江苏中科梦兰电子科技有限公司 一种支持多种体系架构的通用操作***
CN103677937A (zh) * 2013-12-23 2014-03-26 腾讯科技(深圳)有限公司 升级软件和运行软件的方法及装置
CN104572224A (zh) * 2015-02-04 2015-04-29 南车株洲电力机车研究所有限公司 一种out文件加载方法、装置及***
CN105005491A (zh) * 2015-08-11 2015-10-28 上海斐讯数据通信技术有限公司 一种Linux内核和应用程序的升级方法及***
CN105068832A (zh) * 2015-07-30 2015-11-18 北京奇虎科技有限公司 一种生成可执行文件的方法和装置
US9974492B1 (en) * 2015-06-05 2018-05-22 Life365, Inc. Health monitoring and communications device
US20190095119A1 (en) * 2015-06-05 2019-03-28 Life365, Inc. Device configured for dynamic software change
CN110069459A (zh) * 2019-03-14 2019-07-30 北京字节跳动网络技术有限公司 文件监控方法、装置和电子设备
CN110457870A (zh) * 2019-08-01 2019-11-15 浙江大华技术股份有限公司 可执行文件的处理方法及装置、嵌入式设备和存储介质
CN111290952A (zh) * 2020-01-22 2020-06-16 北京深之度科技有限公司 一种动态链接库函数的跟踪方法及装置
CN111930467A (zh) * 2020-07-02 2020-11-13 联想(北京)有限公司 虚拟机启动方法、装置、设备及计算机可读存储介质
CN113377370A (zh) * 2021-05-18 2021-09-10 龙芯中科(西安)科技有限公司 一种文件处理方法、装置、电子设备及存储介质
CN113805971A (zh) * 2021-09-23 2021-12-17 武汉深之度科技有限公司 一种应用程序运行方法、计算设备及存储介质
CN113821272A (zh) * 2021-09-23 2021-12-21 武汉深之度科技有限公司 一种应用程序运行方法、计算设备及存储介质
CN113849245A (zh) * 2021-09-23 2021-12-28 武汉深之度科技有限公司 一种应用程序运行方法、计算设备及存储介质
CN114003289A (zh) * 2021-11-02 2022-02-01 武汉深之度科技有限公司 一种应用程序运行方法、计算设备及存储介质

Patent Citations (18)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1329309A (zh) * 2000-06-13 2002-01-02 微软公司 操作***的多语言用户接口
CN101452402A (zh) * 2008-11-28 2009-06-10 珠海金山软件股份有限公司 软件运行***和软件运行方法
CN103473059A (zh) * 2013-09-11 2013-12-25 江苏中科梦兰电子科技有限公司 一种支持多种体系架构的通用操作***
CN103677937A (zh) * 2013-12-23 2014-03-26 腾讯科技(深圳)有限公司 升级软件和运行软件的方法及装置
CN104572224A (zh) * 2015-02-04 2015-04-29 南车株洲电力机车研究所有限公司 一种out文件加载方法、装置及***
US20190095119A1 (en) * 2015-06-05 2019-03-28 Life365, Inc. Device configured for dynamic software change
US9974492B1 (en) * 2015-06-05 2018-05-22 Life365, Inc. Health monitoring and communications device
CN105068832A (zh) * 2015-07-30 2015-11-18 北京奇虎科技有限公司 一种生成可执行文件的方法和装置
CN105005491A (zh) * 2015-08-11 2015-10-28 上海斐讯数据通信技术有限公司 一种Linux内核和应用程序的升级方法及***
CN110069459A (zh) * 2019-03-14 2019-07-30 北京字节跳动网络技术有限公司 文件监控方法、装置和电子设备
CN110457870A (zh) * 2019-08-01 2019-11-15 浙江大华技术股份有限公司 可执行文件的处理方法及装置、嵌入式设备和存储介质
CN111290952A (zh) * 2020-01-22 2020-06-16 北京深之度科技有限公司 一种动态链接库函数的跟踪方法及装置
CN111930467A (zh) * 2020-07-02 2020-11-13 联想(北京)有限公司 虚拟机启动方法、装置、设备及计算机可读存储介质
CN113377370A (zh) * 2021-05-18 2021-09-10 龙芯中科(西安)科技有限公司 一种文件处理方法、装置、电子设备及存储介质
CN113805971A (zh) * 2021-09-23 2021-12-17 武汉深之度科技有限公司 一种应用程序运行方法、计算设备及存储介质
CN113821272A (zh) * 2021-09-23 2021-12-21 武汉深之度科技有限公司 一种应用程序运行方法、计算设备及存储介质
CN113849245A (zh) * 2021-09-23 2021-12-28 武汉深之度科技有限公司 一种应用程序运行方法、计算设备及存储介质
CN114003289A (zh) * 2021-11-02 2022-02-01 武汉深之度科技有限公司 一种应用程序运行方法、计算设备及存储介质

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
WEI DONG等: ""Enabling efficient reprogramming through reduction of executable modules in networked embedded systems"", 《AD HOC NETWORKS》 *
高永惠: ""C语言多模块文件的处理"", 《湖南科技学院学报》, pages 141 - 142 *

Also Published As

Publication number Publication date
CN113821273B (zh) 2023-10-13

Similar Documents

Publication Publication Date Title
US10324694B2 (en) Arranging binary code based on call graph partitioning
CN105393217B (zh) 用于编译器优化的方法和***
CN112988252B (zh) 一种操作***启动方法及计算设备
CN114691240A (zh) 驱动硬件配置信息加载方法、装置和***,以及计算设备
JP2007531074A (ja) プログラムコード変換においてコードのパーティショニングを行う方法及び装置
US20170329704A1 (en) Dynamically sized locals with precise garbage collection reporting
CN113127100B (zh) 一种异构程序执行方法、装置、计算设备及可读存储介质
CN114003289A (zh) 一种应用程序运行方法、计算设备及存储介质
CN112947976A (zh) 一种操作***升级方法、计算设备及存储介质
CN102930005B (zh) 在宿主文件中捆绑文件的方法及装置
CN113849245B (zh) 一种应用程序运行方法、计算设备及存储介质
CN113835620B (zh) 一种提高安全芯片应用执行效率的方法及***
US8762976B2 (en) Static extensibility models with dynamic languages and scripts
CN113805971B (zh) 一种应用程序运行方法、计算设备及存储介质
CN111752620B (zh) 内核模块的处理方法和加载方法
CN113821272B (zh) 一种应用程序运行方法、计算设备及存储介质
CN113821273B (zh) 一种应用程序运行方法、计算设备及存储介质
CN102982073B (zh) 文件至宿主文件中的捆绑方法和装置
CN113791873B (zh) 一种虚拟机创建方法、计算设备及存储介质
CN114780173A (zh) 一种在应用中加载插件的方法、计算设备及存储介质
CN111913814A (zh) 对象拷贝方法及计算设备
CN114168489B (zh) 一种函数信息获取方法、计算设备及存储介质
CN113835927B (zh) 一种指令执行方法、计算设备及存储介质
US20220108003A1 (en) Apparatus and method for kernel runtime randomization
CN114706828A (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
GR01 Patent grant
GR01 Patent grant