CN111736817A - 函数执行耗时的确定方法、装置、终端设备及存储介质 - Google Patents
函数执行耗时的确定方法、装置、终端设备及存储介质 Download PDFInfo
- Publication number
- CN111736817A CN111736817A CN202010703704.0A CN202010703704A CN111736817A CN 111736817 A CN111736817 A CN 111736817A CN 202010703704 A CN202010703704 A CN 202010703704A CN 111736817 A CN111736817 A CN 111736817A
- Authority
- CN
- China
- Prior art keywords
- function
- time
- proxy
- determining
- target
- 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
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/30—Creation or generation of source code
- G06F8/31—Programming languages or programming paradigms
- G06F8/315—Object-oriented languages
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/32—Monitoring with visual or acoustical indication of the functioning of the machine
- G06F11/324—Display of status information
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/34—Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
- G06F11/3409—Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for performance assessment
- G06F11/3419—Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for performance assessment by assessing time
- G06F11/3423—Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for performance assessment by assessing time where the assessed time is active or idle time
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Software Systems (AREA)
- Quality & Reliability (AREA)
- Computer Hardware Design (AREA)
- Computing Systems (AREA)
- Stored Programmes (AREA)
Abstract
本申请适用于计算机技术领域,提供了函数执行耗时的确定方法、装置、终端设备及存储介质,方法包括:拦截待执行的目标函数;将所述目标函数替换为代理函数,所述代理函数包含所述目标函数和预设的耗时确定函数;执行所述代理函数,并基于所述代理函数中的耗时确定函数,得到所述目标函数的执行耗时时长。通过拦截目标函数,从而仅确定和显示目标函数的耗时情况,比Android Profiler CPU的显示所有函数的耗时情况的结果更直观;通过将目标函数的调用逻辑直接替换为代理函数的调用逻辑,以调用包含目标函数和耗时确定函数的代理函数,而不需要直接对目标函数使用注解,相比Hugo对预设函数原本性能的影响更小,对目标函数几乎无入侵。
Description
技术领域
本申请属于计算机技术领域,尤其涉及函数执行耗时的确定方法、装置、终端设备及存储介质。
背景技术
在安卓android应用进行性能优化时,需要确定函数执行耗时时长以辅助性能优化。目前,确定函数执行耗时的工具包括谷歌官方提供的AndriodProfiler CPU和市场上常见的安卓性能优化工具Hugo,但是以上工具存在结果不够直观、确定过程不够安全等局限性。例如,安卓分析中央处理器Andriod Profiler CPU无法显示某一函数的耗时情况,只能全量显示执行过的函数的耗时情况,这样结果不够直观,不利于排查特定函数的耗时情况,并且Andriod Profiler CPU工具需要依赖于Android Studio,具有一定的局限性;Hugo工具需要在确定耗时的函数中添加注解,这样对代码函数的入侵性非常高,且对代码函数的执行性能造成不良影响。
发明内容
本申请实施例提供了函数执行耗时的确定方法、装置、终端设备及存储介质,可以解决当前函数执行耗时的确定结果不够直观、确定过程不够安全等局限性的问题。
第一方面,本申请实施例提供了一种函数执行耗时的确定方法,包括:
拦截待执行的目标函数;
将目标函数替换为代理函数,代理函数包含目标函数和预设的耗时确定函数;
执行代理函数,并基于代理函数中的耗时确定函数,得到目标函数的执行耗时时长。
本申请实施例通过拦截目标函数,从而仅确定和显示目标函数的耗时情况,比Android Profiler CPU的显示所有函数的耗时情况的结果更直观,而且在确定目标函数的执行耗时过程中不需要与个人计算机(Personal Computer,PC)连接,更加方便快捷;通过将目标函数的调用逻辑直接替换为代理函数的调用逻辑,以调用包含目标函数和耗时确定函数的代理函数,而不需要直接对目标函数使用注解,相比Hugo对预设函数原本性能的影响更小,对目标函数几乎无入侵,本申请解决了当前函数执行耗时的确定结果不够直观、确定过程不够安全等局限性的问题。
第二方面,本申请实施例提供了一种函数执行耗时的确定装置,包括:
拦截模块,用于拦截待执行的目标函数;
替换模块,用于将目标函数替换为代理函数,代理函数包含目标函数和预设耗时确定函数;
确定模块,用于执行代理函数,并基于代理函数中的耗时确定函数,得到目标函数的执行耗时时长。
第三方面,本申请实施例提供了一种终端设备,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现如上述第一方面中任一项所述的函数执行耗时的确定方法。
第四方面,本申请实施例提供了一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序被处理器执行时实现如上述第一方面中任一项所述的函数执行耗时的确定方法。
第五方面,本申请实施例提供了一种计算机程序产品,当计算机程序产品在终端设备上运行时,使得终端设备执行上述第一方面中任一项所述的函数执行耗时的确定方法。
可以理解的是,上述第二方面至第五方面的有益效果可以参见上述第一方面中的相关描述,在此不再赘述。
附图说明
为了更清楚地说明本申请实施例中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
图1是本申请一实施例提供的函数执行耗时的确定方法的流程示意图;
图2是本申请另一实施例提供的函数执行耗时的确定方法的流程示意图;
图3是本申请又一实施例提供的函数执行耗时的确定方法的流程示意图;
图4是本申请一实施例提供的应用程序调用目标函数的流程示意图;
图5是本申请实施例提供的函数执行耗时的确定装置的结构示意图;
图6是本申请实施例提供的终端设备的结构示意图。
具体实施方式
以下描述中,为了说明而不是为了限定,提出了诸如特定系统结构、技术之类的具体细节,以便透彻理解本申请实施例。然而,本领域的技术人员应当清楚,在没有这些具体细节的其它实施例中也可以实现本申请。在其它情况中,省略对众所周知的系统、装置、电路以及方法的详细说明,以免不必要的细节妨碍本申请的描述。
应当理解,当在本申请说明书和所附权利要求书中使用时,术语“包括”指示所描述特征、整体、步骤、操作、元素和/或组件的存在,但并不排除一个或多个其它特征、整体、步骤、操作、元素、组件和/或其集合的存在或添加。
还应当理解,在本申请说明书和所附权利要求书中使用的术语“和/或”是指相关联列出的项中的一个或多个的任何组合以及所有可能组合,并且包括这些组合。
如在本申请说明书和所附权利要求书中所使用的那样,术语“如果”可以依据上下文被解释为“当...时”或“一旦”或“响应于确定”或“响应于检测到”。类似地,短语“如果确定”或“如果检测到[所描述条件或事件]”可以依据上下文被解释为意指“一旦确定”或“响应于确定”或“一旦检测到[所描述条件或事件]”或“响应于检测到[所描述条件或事件]”。
另外,在本申请说明书和所附权利要求书的描述中,术语“第一”、“第二”、“第三”等仅用于区分描述,而不能理解为指示或暗示相对重要性。
在本申请说明书中描述的参考“一个实施例”或“一些实施例”等意味着在本申请的一个或多个实施例中包括结合该实施例描述的特定特征、结构或特点。由此,在本说明书中的不同之处出现的语句“在一个实施例中”、“在一些实施例中”、“在其他一些实施例中”、“在另外一些实施例中”等不是必然都参考相同的实施例,而是意味着“一个或多个但不是所有的实施例”,除非是以其他方式另外特别强调。术语“包括”、“包含”、“具有”及它们的变形都意味着“包括但不限于”,除非是以其他方式另外特别强调。
如背景技术相关记载,Andriod Profiler CPU无法显示某一函数的耗时情况,只能全量显示执行过的函数的耗时情况,这样结果不够直观,不利于排查特定函数的耗时情况,并且Andriod Profiler CPU工具需要依赖于Android Studio,具有一定的局限性;Hugo工具将需要确定耗时的函数中添加注解,这样对代码函数的入侵性非常高,且对代码函数的执行性能造成不良影响。
因此,本申请实施例提供一种函数执行耗时的确定方法,实现仅统计和显示目标函数的耗时情况,相比Android Profiler CPU的显示所有函数的耗时情况,本方法的确定结果更直观;通过将目标函数的调用逻辑直接替换为代理函数的调用逻辑,以调用包含目标函数和耗时统计函数的代理函数,而不需要直接对目标函数使用注解,相比Hugo工具,本方法对预设函数原本性能的影响更小,对目标函数几乎无入侵。
本申请实施例提供的函数执行耗时的确定方法可以应用于终端设备,该终端设备包括但不限于手机、平板电脑、可穿戴设备、增强现实(augmented reality,AR)/虚拟现实(virtual reality,VR)设备、笔记本电脑、超级移动个人计算机(ultra-mobile personalcomputer,UMPC)、上网本或个人数字助理(personal digital assistant,PDA)、服务器等终端设备,本申请实施例对终端设备的具体类型不作任何限制。
作为示例而非限定,终端设备的操作系统以Andriod系统为例,在一些实施例中,将Andriod系统分为应用程序层、应用程序框架层、系统层和硬件抽象层,各层之间通过软件接口通信。应用程序层可以包括一系列应用程序包,应用程序包可以包括短信息,日历,相机,视频,导航,图库,通话等应用程序。应用程序框架层为应用程序层的应用程序提供应用编程接口(application programming interface,API)和编程框架。系统层可以包括多个功能模块。例如:传感器服务模块,物理状态识别模块,三维图形处理库(例如:OpenGLES)等。硬件抽象层是硬件和软件之间的层。硬件抽象层可以包括显示驱动,摄像头驱动,传感器驱动等,用于驱动硬件层的相关硬件,如显示屏、摄像头、传感器等。
其中应用程序可以为Android程序,程序文件为存储应用的源程序和可执行程序的文件,应用程序可基于程序文件中的程序(目标函数)完成特定事项活动。当终端设备安装应用程序时,终端设备编译程序文件,将程序文件存储至指定内存区域,使得程序文件能够被终端设备识别和调用,从而使终端设备可以执行程序文件中的目标函数。
为了确定应用程序的函数耗时情况,则为应用程序配置函数耗时确定功能。作为示例而非限定,将预先编写好的耗时确定函数写入到预设的String数组,将写入耗时确定函数后的String数组作为参数,传入耗时确定工具的Android二进制归档文件(AndroidArchive,aar)文件包,将该aar文件包引入到应用程序的程序文件中,将该程序文件进行编译安装至终端设备,以使应用程序启动函数耗时确定功能。
上述string数组为C++、java、VB(Visual Basic)等编程语言中的字符串数组,字符串是一个特殊的对象,属于引用类型。将耗时确定函数写入到string数组内,以便于耗时确定函数后续作为对象被引用。aar为Android库项目的二进制归档文件,包含所有资源(如class和resources等资源文件)。耗时确定工具的aar为后缀名为.aar的文件包。将string数组作为参数传入耗时确定工具的aar,以将包含耗时确定函数的string数组作为参数替换aar内的原string数组的值,从而将耗时确定函数存储至耗时统计工具的aar内。通过Maven仓库的仓库地址,将耗时确定工具的aar引入到应用程序的程序文件中。具体地,输入Maven仓库的仓库地址,根据该仓库地址,加载Maven仓库中耗时确定工具的aar,并将该aar引入到应用程序的程序文件中,从而使得应用程序具备耗时确定工具的功能。
图1示出了本申请提供的函数执行耗时的确定方法的示意性流程图,作为示例而非限定,该方法可以应用于上述手机。
S101,拦截待执行的目标函数。
在上述S101中,上述目标函数为计算机函数,可以是程序文件中的某段代码,其也可以理解为脚本文件中的脚本段。目标函数可以是基于安卓系统、iOS系统(苹果公司开发的移动操作系统)或windows系统下的代码逻辑函数或算法函数,如java函数和native(C/C++)函数。应理解,目标函数也可以是其他系统下的函数,如Centos系统下的函数等。
可选地,可基于窗口子类化SubClass实现或基于钩子Hook实现拦截目标函数。在一种可能实现的方式中,基于窗口化子类SubClass实现拦截目标函数,包括:编写子类化窗口过程函数,该函数的格式为标准的窗口过程函数格式;调用GetWindowLong函数获取原窗口函数的地址并保存;调用SetWindowLong函数将原窗口函数设置为上述子类化窗口过程函数,从而实现windows系统拦截原窗口函数。
在另一种可能实现的方式中,基于钩子Hook实现拦截目标函数,包括:
基于预设的Hook机制,监听是否预调用目标函数;若监听到预调用目标函数,则拦截目标函数的调用逻辑。
在本实施例中,上述Hook机制为钩子机制,在对特定的系统事件进行Hook监听后,一旦发生已Hook的事件,对该事件进行Hook监听的程序就会收到系统通知,该程序能够对该事件作出响应。具体地,终端设备接收用户输入的目标函数的函数名,耗时确定工具对该目标函数设置hook监听,当该目标函数被调用时,系统向耗时确定工具发出通知,耗时确定工具收到系统通知后,立即阻止该目标函数的传输过程。
上述Hook机制可以是Andriod Hook机制,也可以是Windows Hook机制。对目标函数设置Hook,使得Hook监听目标函数,若Hook监听到目标函数被预调用,则阻止目标函数被调用,即拦截目标函数的调用进程。本实施例基于Hook机制监听目标函数,从而实现对特定的目标函数实施执行耗时统计。
可选地,对于Windows Hook机制,当Hook所监视的函数出现时,Windows调用链表中的第一个钩子子程,第一个过程完成后将函数传递链表中的下一个钩子子程,直至链表中所有钩子子程都执行完成。
可选地,对于Andriod Hook机制,可基于java反射机制实现或基于java动态代理实现。其中java反射为在动态运行时,对于任意一个类,可以获得该类所有函数或变量,从而调用该类的私有方法,以实现拦截该类中的目标函数。Java动态代理为在运行时动态生成代理类,从而由代理类实现拦截目标函数,可选地,可基于InvocationHandler实现java动态代理。
S102,将目标函数替换为代理函数,代理函数包含目标函数和预设的耗时确定函数。
在上述S102中,上述耗时确定函数为用于记录目标函数的执行耗时时长的代码。上述代理函数利用耗时确定函数确定目标函数的执行耗时时长的函数,其可以是预先设置的函数,也可以是实时生成的函数。若代理函数为预设设置的函数,则预先获取或预先编写目标函数和耗时确定函数,并将目标函数与耗时确定函数融合为代理函数;若代理函数为实时生成的函数,则获取目标函数的第一调用逻辑和耗时确定函数的第二调用逻辑,将第一调用逻辑和第二调用逻辑融合为调用目标函数和耗时确定函数的第三调用逻辑,将根据第三调用逻辑所调用的目标函数和耗时确定函数作为代理函数。
上述替换是指将某一函数的调用过程替换为另一个函数的调用过程,例如,应用程序调用目标函数,则将应用程序调用目标函数的调用过程替换为代理函数的调用过程,从而使应用程序调用代理函数。具体地,对于目标函数为java函数,将待加载至应用程序的java虚拟机(Java Virtual Machine,JVM)内存中的目标函数替换为代理函数,以使应用程序的JVM内存后续不再加载目标函数,而是加载代理函数。对于目标函数为native(C/C++)函数,将待加入到应用程序的函数执行进程的目标函数替换为代理函数,以使应用程序后续不再执行目标函数,而是执行代理函数。应理解,在本实施例中,若拦截到目标函数,则使应用程序执行代理函数,即本实施例的代理函数不属于还原执行。
S103,执行代理函数,并基于代理函数中的耗时确定函数,得到目标函数的执行耗时时长。
在上述S103中,在一实施例中,在目标函数开始执行时,耗时确定函数从0开始计时,在目标函数执行结束时,耗时确定函数停止计时,将停止计时后所记录的时长作为目标函数的执行耗时时长。
在另一实施例中,基于所述代理函数中的耗时确定函数,得到所述目标函数执行前以及执行结束后分别对应的时刻,进而得到所述目标函数的执行耗时时长。具体地,包括:
获取在代理函数中目标函数执行前,通过执行耗时确定函数记录的第一时间戳,获取在代理函数中目标函数执行结束后,通过执行耗时确定函数记录的第二时间戳;将第一时间戳与第二时间戳之间的时间差作为目标函数的执行耗时时长。
在本实施例中,目标函数开始执行时,应用程序中的耗时确定工具会先执行耗时确定函数以确定目标函数开始执行时的第一时间戳,在目标函数结束执行后会立即执行耗时确定函数以确定目标函数结束执行时的第二时间戳,将两个时间戳之间的时间差作为目标函数的执行耗时时长。
在图1所示实施例的基础上,图2示出了本申请实施例提供的另一种函数执行耗时的确定方法的流程性示意图。相对于图1实施例,如图2,上述S103中的执行目标函数具体包括S201和S202。需要说明的是,与图1实施例相同的步骤,在此不再赘述。
S201,将代理函数中所包含的目标函数和所包含的耗时确定函数加载至java虚拟机的内存中。
在上述S201中,上述目标函数为java函数。在编译阶段,编译器将java文件编译为.class文件,在运行阶段,jvm将.class文件通过类加载器classloader加载一个类对应的类对象到jvm内存中进行处理,其中在本实施例中,类加载器classloader所加载的类对象为代理函数。
可选地,通过java反射的方式修改java接口的动态代理对象。具体地,在耗时确定函数中融入目标函数,这样耗时确定函数就包含有目标函数,将类加载器所加载的类对象(即java接口的动态代理对象)由原来的目标函数修改为融入目标函数后的耗时确定函数,以使类加载器加载代理函数到JVM内存进行执行。
S202,通过java虚拟机的预设线程,执行java虚拟机的内存中的目标函数和耗时确定函数。
在上述S202中,上述预设线程可以是main线程。在JVM实现过程中,线程为Execution Engine的一个实例,main函数是JVM指令执行的起点,JVM会创建main线程来执行main函数,以触发JVM一系列指令(如目标函数和耗时确定函数)的执行,从而使JVM 运行起来。
在图1实施例的基础上,图3示出了本申请实施例提供的又一种函数执行耗时的确定方法的流程性示意图。相对于图1所示实施例,如图3,本实施例中的S102具体包括S301和S302。需要说明的是,与图1实施例相同的步骤,在此不再赘述。
S301,获取用于调用目标函数的第一函数地址,以及获取用于调用耗时确定函数的第二函数地址。
在上述S301中,上述目标函数为native(C/C++)函数。上述第一函数地址可以为用于调用目标函数的存储空间地址,上述第二函数地址为调用耗时确定函数的另一个存储空间地址。
S302,将第一函数地址中的首地址和末地址替换为耗时确定函数的第二函数地址。
在上述S302中,可通过Inline hook的方式修改函数执行流程。具体地,通过汇编指令的jmp指令,将目标函数的首地址和末地址的代码修改为耗时统计函数的第二函数地址。例如,对某进程的kernel32.dll的CreateFile()函数进行Hook,先在指定进程中的内存中找到CreateFile()函数的地址,然后修改CreateFile()函数的首地址和末地址的代码为jmpTimeConsuming的指令,其中TimeConsuming为第二函数地址。
在一种可能实现的方式中,在图3实施例的基础上,上述S103中的的执行目标函数具体包括S303至S306。
S303,根据首地址以及末地址替换后的第一函数地址中的首地址,将耗时确定函数传入预设执行进程中。
S304,根据首地址以及末地址替换后的第一函数地址,将目标函数传入预设执行进程中。
S305,根据首地址以及末地址替换后的第一函数地址中的末地址,将耗时确定函数再次传入预设执行进程中。
S306,通过运行预设执行进程,以执行代理函数。
在上述S303至S306中,上述预设执行进程在执行目标函数时,先跳转耗时确定函数的函数地址对应的存储空间,以获取耗时确定函数并执行,当耗时确定函数执行结束后,返回至目标函数的函数地址对应的存储空间,以获取目标函数并执行,当目标函数执行结束后,再次跳转至耗时确定函数的函数地址对应的存储空间,以获取耗时确定函数并执行,并基于耗时确定函数,计算目标函数的执行耗时时长。
例如,如图4示出的应用程序调用目标函数的流程示意图。CreateFile()函数为目标函数,TimeConsuming()函数为耗时确定函数。S1,当指定进程kernel32.dll调用第一动态链接库(Dynamic Link Library,DLL)空间中的CreateFile()函数时,预设执行进程先跳转到TimeConsuming()函数的第二DLL空间中去执行TimeConsuming()函数对应的流程;S2,当TimeConsuming()函数执行结束后,预设执行进程返回至CreateFile()函数的第一DLL空间去执行CreateFile()函数对应的流程;S3,当CreateFile()函数执行结束后,预设执行进程再次跳转至TimeConsuming()函数的第二DLL空间,从而使得TimeConsuming()函数在CreateFile()函数执行的前后各执行一次得到两个时间戳,根据两个时间戳可以得到CreateFile()函数的执行耗时时长。
为了进一步保证上述所有出现的数据的私密和安全性,在本申请的所有实施例中,基于代理函数中的耗时确定函数得到目标函数对应的执行耗时时长,具体来说,目标函数的执行耗时时长由代理函数中的耗时确定函数对目标函数执行过程中所消耗的时间进行统计得到。将目标函数的执行耗时时长和/或代理函数上传至区块链可保证其安全性和对用户的公正透明性。用户设备可以从区块链中下载得该目标函数的执行耗时时长和/或代理函数,以便查证目标函数的执行耗时时长和/或代理函数是否被篡改。本示例所指区块链是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。区块链(Blockchain),本质上是一个去中心化的数据库,是一串使用密码学方法相关联产生的数据块,每一个数据块中包含了一批次网络交易的信息,用于验证其信息的有效性(防伪)和生成下一个区块。区块链可以包括区块链底层平台、平台产品服务层以及应用服务层等。
应理解,上述实施例中各步骤的序号的大小并不意味着执行顺序的先后,各过程的执行顺序应以其功能和内在逻辑确定,而不应对本申请实施例的实施过程构成任何限定。
对应于上文实施例所述的函数执行耗时的确定方法,图5示出了本申请实施例提供的函数执行耗时的确定装置的结构框图,为了便于说明,仅示出了与本申请实施例相关的部分。
参照图5,该装置包括:
拦截模块501,用于拦截待执行的目标函数;
替换模块502,用于将目标函数替换为代理函数,代理函数包含目标函数和预设的耗时确定函数;
确定模块503,用于执行代理函数,并基于代理函数中的耗时确定函数,得到目标函数的执行耗时时长。
需要说明的是,上述装置/单元之间的信息交互、执行过程等内容,由于与本申请方法实施例基于同一构思,其具体功能及带来的技术效果,具体可参见方法实施例部分,此处不再赘述。
所属领域的技术人员可以清楚地了解到,为了描述的方便和简洁,仅以上述各功能单元、模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能单元、模块完成,即将所述装置的内部结构划分成不同的功能单元或模块,以完成以上描述的全部或者部分功能。实施例中的各功能单元、模块可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中,上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。另外,各功能单元、模块的具体名称也只是为了便于相互区分,并不用于限制本申请的保护范围。上述系统中单元、模块的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
图6为本申请一实施例提供的终端设备的结构示意图。如图6所示,该实施例的终端设备6包括:至少一个处理器60(图6中仅示出一个)处理器、存储器61以及存储在所述存储器61中并可在所述至少一个处理器60上运行的计算机程序62,所述处理器60执行所述计算机程序62时实现上述任意方法实施例中的步骤。
所述终端设备6可以是手机、桌上型计算机、笔记本、掌上电脑及云端服务器等计算设备。该终端设备可包括但不仅限于处理器60、存储器61。本领域技术人员可以理解,图6仅仅是终端设备6的举例,并不构成对终端设备6的限定,可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件,例如还可以包括输入输出设备、网络接入设备等。
所称处理器60可以是中央处理单元(Central Processing Unit,CPU),该处理器60还可以是其他通用处理器、数字信号处理器 (Digital Signal Processor,DSP)、专用集成电路 (Application Specific Integrated Circuit,ASIC)、现成可编程门阵列(Field-Programmable Gate Array,FPGA) 或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
所述存储器61在一些实施例中可以是所述终端设备6的内部存储单元,例如终端设备6的硬盘或内存。所述存储器61在另一些实施例中也可以是所述终端设备6的外部存储设备,例如所述终端设备6上配备的插接式硬盘,智能存储卡(Smart Media Card, SMC),安全数字(Secure Digital, SD)卡,闪存卡(Flash Card)等。进一步地,所述存储器61还可以既包括所述终端设备6的内部存储单元也包括外部存储设备。所述存储器61用于存储操作系统、应用程序、引导装载程序(BootLoader)、数据以及其他程序等,例如所述计算机程序的程序代码等。所述存储器61还可以用于暂时地存储已经输出或者将要输出的数据。
本申请实施例还提供了一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序被处理器执行时实现可实现上述各个方法实施例中的步骤。
本申请实施例提供了一种计算机程序产品,当计算机程序产品在移动终端上运行时,使得移动终端执行时实现可实现上述各个方法实施例中的步骤。
所述集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本申请实现上述实施例方法中的全部或部分流程,可以通过计算机程序来指令相关的硬件来完成,所述的计算机程序可存储于一计算机可读存储介质中,该计算机程序在被处理器执行时,可实现上述各个方法实施例的步骤。其中,所述计算机程序包括计算机程序代码,所述计算机程序代码可以为源代码形式、对象代码形式、可执行文件或某些中间形式等。所述计算机可读介质至少可以包括:能够将计算机程序代码携带到拍照装置/终端设备的任何实体或装置、记录介质、计算机存储器、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,RandomAccess Memory)、电载波信号、电信信号以及软件分发介质。例如U盘、移动硬盘、磁碟或者光盘等。在某些司法管辖区,根据立法和专利实践,计算机可读介质不可以是电载波信号和电信信号。
在上述实施例中,对各个实施例的描述都各有侧重,某个实施例中没有详述或记载的部分,可以参见其它实施例的相关描述。
本领域普通技术人员可以意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、或者计算机软件和电子硬件的结合来实现。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本申请的范围。
在本申请所提供的实施例中,应该理解到,所揭露的装置/网络设备和方法,可以通过其它的方式实现。例如,以上所描述的装置/网络设备实施例仅仅是示意性的,例如,所述模块或单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通讯连接可以是通过一些接口,装置或单元的间接耦合或通讯连接,可以是电性,机械或其它的形式。
所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
以上所述实施例仅用以说明本申请的技术方案,而非对其限制;尽管参照前述实施例对本申请进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本申请各实施例技术方案的精神和范围,均应包含在本申请的保护范围之内。
Claims (10)
1.一种函数执行耗时的确定方法,其特征在于,包括:
拦截待执行的目标函数;
将所述目标函数替换为代理函数,所述代理函数包含所述目标函数和预设的耗时确定函数;
执行所述代理函数,并基于所述代理函数中的耗时确定函数,得到所述目标函数的执行耗时时长。
2.如权利要求1所述的确定方法,其特征在于,所述拦截待执行的目标函数,包括:
基于预设的钩子Hook机制,监听是否预调用所述目标函数;
若监听到预调用所述目标函数,则拦截所述目标函数。
3.如权利要求1所述的确定方法,其特征在于,所述目标函数为java函数;相应地,所述执行所述代理函数,包括:
将所述代理函数中所包含的所述java函数和所包含的所述耗时确定函数加载至java虚拟机的内存中;
通过所述java虚拟机的预设线程,执行所述java虚拟机的内存中的所述java函数和所述耗时确定函数。
4.如权利要求1所述的确定方法,其特征在于,所述目标函数为native函数;相应地,所述将所述目标函数替换为代理函数,包括:
获取用于调用所述native函数的第一函数地址,以及获取用于调用所述耗时确定函数的第二函数地址;
将所述第一函数地址中的首地址和末地址替换为所述耗时确定函数的第二函数地址。
5.如权利要求4所述的确定方法,其特征在于,所述执行所述代理函数,包括:
根据所述首地址以及所述末地址替换后的第一函数地址中的首地址,将所述耗时确定函数传入预设执行进程中;
根据所述首地址以及所述末地址替换后的第一函数地址,将所述目标函数传入所述预设执行进程中;
根据所述首地址以及所述末地址替换后的第一函数地址中的末地址,将所述耗时确定函数再次传入所述预设执行进程中;
通过运行所述预设执行进程,以执行所述代理函数。
6.如权利要求1至5任一项所述的确定方法,其特征在于,所述耗时确定函数在所述代理函数中的目标函数运行前以及运行后执行;
相应地,所述基于所述代理函数中的耗时确定函数,确定所述目标函数的执行耗时时长,包括:
获取在所述代理函数中所述目标函数执行前,通过执行所述耗时确定函数记录的第一时间戳,获取在所述代理函数中所述目标函数执行结束后,通过执行所述耗时确定函数记录的第二时间戳;
将所述第一时间戳与所述第二时间戳之间的时间差作为所述目标函数的执行耗时时长。
7.如权利要求1至5任一项所述的确定方法,其特征在于,所述方法还包括:
将所述目标函数的执行耗时时长和/或所述代理函数存储至预设区块链中。
8.一种函数执行耗时的确定装置,其特征在于,包括:
拦截模块,用于拦截待执行的目标函数;
替换模块,用于将所述目标函数替换为代理函数,所述代理函数包含所述目标函数和预设的耗时确定函数;
确定模块,用于执行所述代理函数,并基于所述代理函数中的耗时确定函数,得到所述目标函数的执行耗时时长。
9.一种终端设备,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时实现如权利要求1至7任一项所述的方法。
10.一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现如权利要求1至7任一项所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010703704.0A CN111736817B (zh) | 2020-07-21 | 2020-07-21 | 函数执行耗时的确定方法、装置、终端设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010703704.0A CN111736817B (zh) | 2020-07-21 | 2020-07-21 | 函数执行耗时的确定方法、装置、终端设备及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN111736817A true CN111736817A (zh) | 2020-10-02 |
CN111736817B CN111736817B (zh) | 2021-01-15 |
Family
ID=72655184
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202010703704.0A Active CN111736817B (zh) | 2020-07-21 | 2020-07-21 | 函数执行耗时的确定方法、装置、终端设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN111736817B (zh) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112698890A (zh) * | 2020-12-31 | 2021-04-23 | 百果园技术(新加坡)有限公司 | 函数耗时采集方法、装置、设备及存储介质 |
CN116483734A (zh) * | 2023-06-16 | 2023-07-25 | 荣耀终端有限公司 | 一种基于编译器的插桩方法、系统及相关电子设备 |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101477491A (zh) * | 2009-01-16 | 2009-07-08 | 杭州华三通信技术有限公司 | 一种统计函数运行状态的方法和装置 |
CN108021357A (zh) * | 2017-11-20 | 2018-05-11 | 北京奇虎科技有限公司 | 程序调用的优化方法及装置 |
CN111240927A (zh) * | 2020-01-03 | 2020-06-05 | 北京小米移动软件有限公司 | 检测程序中方法耗时的方法、装置及存储介质 |
-
2020
- 2020-07-21 CN CN202010703704.0A patent/CN111736817B/zh active Active
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101477491A (zh) * | 2009-01-16 | 2009-07-08 | 杭州华三通信技术有限公司 | 一种统计函数运行状态的方法和装置 |
CN108021357A (zh) * | 2017-11-20 | 2018-05-11 | 北京奇虎科技有限公司 | 程序调用的优化方法及装置 |
CN111240927A (zh) * | 2020-01-03 | 2020-06-05 | 北京小米移动软件有限公司 | 检测程序中方法耗时的方法、装置及存储介质 |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112698890A (zh) * | 2020-12-31 | 2021-04-23 | 百果园技术(新加坡)有限公司 | 函数耗时采集方法、装置、设备及存储介质 |
CN116483734A (zh) * | 2023-06-16 | 2023-07-25 | 荣耀终端有限公司 | 一种基于编译器的插桩方法、系统及相关电子设备 |
CN116483734B (zh) * | 2023-06-16 | 2024-03-19 | 荣耀终端有限公司 | 一种基于编译器的插桩方法、系统及相关电子设备 |
Also Published As
Publication number | Publication date |
---|---|
CN111736817B (zh) | 2021-01-15 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110096338B (zh) | 智能合约执行方法、装置、设备及介质 | |
CN108027722B (zh) | 在编译和部署中动态更新应用 | |
US9684786B2 (en) | Monitoring an application in a process virtual machine | |
US8875106B2 (en) | Automated testing process | |
US20150113242A1 (en) | Restricting access to sensitive data in system memory dumps | |
US9355003B2 (en) | Capturing trace information using annotated trace output | |
CN111736817B (zh) | 函数执行耗时的确定方法、装置、终端设备及存储介质 | |
US8656367B1 (en) | Profiling stored procedures | |
US10084637B2 (en) | Automatic task tracking | |
CN113569246A (zh) | 漏洞检测方法、装置、计算机设备和存储介质 | |
US20120226944A1 (en) | Static data race detection and anaylsis | |
CN112671609A (zh) | 一种资产普查与安全检测方法、装置及终端设备 | |
CN112817831A (zh) | 应用性能监测方法、装置、计算机系统和可读存储介质 | |
CN114356779A (zh) | 编程语言调试方法、装置及终端设备 | |
CN114895935A (zh) | 刷写车辆ecu的方法、装置、电子设备及存储介质 | |
Decan et al. | On the outdatedness of workflows in the GitHub Actions ecosystem | |
CN113986679A (zh) | 基于配置信息热加载的性能分析方法及装置 | |
US9064042B2 (en) | Instrumenting computer program code by merging template and target code methods | |
CN112965736A (zh) | 代码处理方法、装置、电子设备及介质 | |
CN109254856B (zh) | 智能pos服务端提供接口给客户端的方法 | |
CN111930478A (zh) | 基于动态字节码的服务调用方法及装置 | |
CN111859403A (zh) | 依赖关系漏洞的确定方法、装置、电子设备及存储介质 | |
CN118092886B (zh) | 移动应用中间层组件调用方法、装置、设备及存储介质 | |
KR102666486B1 (ko) | 소스 코드 관리 방법 및 시스템 | |
CN112015394B (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 |