CN113391811A - 函数编译方法、装置、电子设备及计算机可读存储介质 - Google Patents

函数编译方法、装置、电子设备及计算机可读存储介质 Download PDF

Info

Publication number
CN113391811A
CN113391811A CN202010176438.0A CN202010176438A CN113391811A CN 113391811 A CN113391811 A CN 113391811A CN 202010176438 A CN202010176438 A CN 202010176438A CN 113391811 A CN113391811 A CN 113391811A
Authority
CN
China
Prior art keywords
function
template
target
class
compiled
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
CN202010176438.0A
Other languages
English (en)
Other versions
CN113391811B (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.)
Beijing ByteDance Network Technology Co Ltd
Original Assignee
Beijing ByteDance Network 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 Beijing ByteDance Network Technology Co Ltd filed Critical Beijing ByteDance Network Technology Co Ltd
Priority to CN202010176438.0A priority Critical patent/CN113391811B/zh
Publication of CN113391811A publication Critical patent/CN113391811A/zh
Application granted granted Critical
Publication of CN113391811B publication Critical patent/CN113391811B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/40Transformation of program code
    • G06F8/41Compilation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/70Software maintenance or management
    • G06F8/73Program documentation

Landscapes

  • Engineering & Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Software Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Library & Information Science (AREA)
  • Devices For Executing Special Programs (AREA)

Abstract

本公开提供了一种函数编译方法、装置、电子设备及计算机可读存储介质,该方法包括:获取待编译函数,待编译函数标记有目标注解类;基于目标注解类,以及预先建立的对应关系,确定待编译函数对应的目标实现类模板;基于待编译函数对目标实现类模板中的模板函数进行修改,并在编译待编译函数时,将修改后的目标实现类模板的字节码织入到待编译函数中,以实现对待编译函数的编译。通过本公开的方案,在开发一个基于注解类的新功能时,程序人员可基于该新功能编写一个实现类模板,建立该实现类模板与新的注解类之间的对应关系,不需要编写一个插件,在编译时,通过该对应关系即可获取到待编译函数对应的实现类模板,从而提高函数编译效率。

Description

函数编译方法、装置、电子设备及计算机可读存储介质
技术领域
本公开涉及计算机处理技术领域,具体而言,本公开涉及一种函数编译方法、装置、电子设备及计算机可读存储介质。
背景技术
现有技术中,为了在编译时插入获取函数运行信息的代码,可通过注解类标记函数的方式实现,即每次开发一个基于注解类的新功能,都需要写一个新的插件,基于该插件可获取到该函数编译时对应的运行信息的代码,则可基于该函数的注解类,通过该注解类对应插件获取该函数对应的代码,将该代码插入至该函数,对该函数进行编译即可获取该函数的运行信息。通过上述方式,一个注解类对应一个插件,每次开发一个基于注解类的新功能,都需要写一个新的插件,这样从代码实现的复杂度来看,增加了开发成本,并且,在编译某个函数时,都需要通过对应的插件才可实现,影响编译耗时。
发明内容
提供该发明内容部分以便以简要的形式介绍构思,这些构思将在后面的具体实施方式部分被详细描述。该发明内容部分并不旨在标识要求保护的技术方案的关键特征或必要特征,也不旨在用于限制所要求的保护的技术方案的范围。
第一方面,本公开提供了一种函数编译方法,该方法包括:
获取待编译函数,待编译函数标记有目标注解类;
基于目标注解类,以及预先建立的对应关系,确定待编译函数对应的目标实现类模板,对应关系包括目标注解类与目标实现类模板之间的对应关系;
基于待编译函数对目标实现类模板中的模板函数进行修改,得到修改后的目标实现类模板;
将修改后的目标实现类模板的字节码织入到待编译函数中,以实现对待编译函数的编译。
第二方面,本公开提供了一种函数编译装置,该装置包括:
函数获取模块,用于获取待编译函数,待编译函数标记有目标注解类;
实现类模板确定模块,用于基于目标注解类,以及预先建立的对应关系,确定待编译函数对应的目标实现类模板,对应关系包括目标注解类与目标实现类模板之间的对应关系;
模板处理模块,用于基于待编译函数对目标实现类模板中的模板函数进行修改,得到修改后的目标实现类模板;
函数编译模块,用于将修改后的目标实现类模板的字节码织入到待编译函数中,以实现对待编译函数的编译。
第三方面,本公开提供了一种电子设备,该电子设备包括:
处理器和存储器;
存储器,用于存储计算机操作指令;
处理器,用于通过调用计算机操作指令,执行如本公开的第一方面任一实施例中所示的方法。
第四方面,本公开提供了一种计算机可读存储介质,该计算机可读存储介质存储有至少一条指令、至少一段程序、代码集或指令集,至少一条指令、至少一段程序、代码集或指令集由处理器加载并执行以实现如本公开的第一方面任一实施例中所示的方法。
本公开实施例提供的技术方案带来的有益效果是:
本公开实施例的函数编译方法、装置、电子设备及计算机可读存储介质,在开发一个基于注解类的新功能时,可预先建立该注解类和该新功能对应的实现类模板之间的对应关系,该实现类模板对应有该新功能对应的代码;在想要对待编译函数进行编译时,可基于该待编译函数的注解类,以及预先建立的对应关系,确定该待编译函数对应的目标实现类模板,并基于该待编译函数对目标实现类模板中的模板函数进行修改,在编译该待编译函数时,将修改后的目标实现类模板的字节码织入到待编译函数中,以实现对待编译函数的编译。通过该方案,在开发一个基于注解类的新功能时,程序人员可基于该新功能编写一个实现类模板,建立该实现类模板与对应的新的注解类之间的新的对应关系,不需要编写一个新的插件,在编译时,通过该建立的对应关系即可获取到待编译函数对应的实现类模板,从而提高编译效率,节省开发成本。
附图说明
为了更清楚地说明本公开实施例中的技术方案,下面将对本公开实施例描述中所需要使用的附图作简单地介绍。
图1为本公开的实施例提供的一种函数编译方法的流程示意图;
图2为本公开的实施例提供的一种函数编译装置的结构示意图;
图3为本公开的实施例提供的一种电子设备的结构示意图。
具体实施方式
下面将参照附图更详细地描述本公开的实施例。虽然附图中显示了本公开的某些实施例,然而应当理解的是,本公开可以通过各种形式来实现,而且不应该被解释为限于这里阐述的实施例,相反提供这些实施例是为了更加透彻和完整地理解本公开。应当理解的是,本公开的附图及实施例仅用于示例性作=用,并非用于限制本公开的保护范围。
应当理解,本公开的方法实施方式中记载的各个步骤可以按照不同的顺序执行,和/或并行执行。此外,方法实施方式可以包括附加的步骤和/或省略执行示出的步骤。本公开的范围在此方面不受限制。
本文使用的术语“包括”及其变形是开放性包括,即“包括但不限于”。术语“基于”是“至少部分地基于”。术语“一个实施例”表示“至少一个实施例”;术语“另一实施例”表示“至少一个另外的实施例”;术语“一些实施例”表示“至少一些实施例”。其他术语的相关定义将在下文描述中给出。
需要注意,本公开中提及的“第一”、“第二”等概念仅用于对装置、模块或单元进行区分,并非用于限定这些装置、模块或单元一定为不同的装置、模块或单元,也并非用于限定这些装置、模块或单元所执行的功能的顺序或者相互依存关系。
需要注意,本公开中提及的“一个”、“多个”的修饰是示意性而非限制性的,本领域技术人员应当理解,除非在上下文另有明确指出,否则应该理解为“一个或多个”。
下面以具体地实施例对本公开的技术方案以及本公开的技术方案如何解决上述技术问题进行详细说明。下面这几个具体的实施例可以相互结合,对于相同或相似的概念或过程可能在某些实施例中不再赘述。下面将结合附图,对本公开的实施例进行描述。
针对上述技术问题,本公开的实施例提供的一种函数编译方法,该方法可由服务器执行,如图1所示,该方法可以包括:
步骤S110,获取待编译函数,待编译函数标记有目标注解类。
其中,注解类用于对函数进行注解标记,一个注解类可以对应标记至少一个函数,目标注解类是待编译函数的注解标记。
在一可选方案中,待编译函数可以通过以下方式获取,在待编译函数对应的字节码中,可以通过遍历该字节码以获取其中的待编译函数。
步骤S120,基于目标注解类,以及预先建立的对应关系,确定待编译函数对应的目标实现类模板,对应关系包括目标注解类与目标实现类模板之间的对应关系。
其中,对应关系是注解类与对应的实现类模板之间的对应关系,基于目标注解类,可以找到唯一一个对应的实现类模板(目标实现类模板)。注解类相当于一个接口,实现类模板相当于实现类,建立两者之间的对应关系,该实现类是该接口的实现类,也就是基于建立的对应关系,将两者的关系绑定,从而实现基于接口找到对应的实现类。
其中,一个实现类模板对应一段可实现一个功能的代码,该实现类模板可以由程序人员通过高级编程语言编写,该高级编程语言可以是通用的编程语言,比如,JAVA等编程语言。在函数编译时,可将用高级编程语言编写的实现类模板转换为字节码编写的模板,以使该模板对应的字节码运行在虚拟机上。通过高级编程语言编写实现类模板,可便于程序开发,同时节省开发成本。
步骤S130,基于待编译函数对目标实现类模板中的模板函数进行修改,得到修改后的目标实现类模板。
步骤S140,将修改后的目标实现类模板的字节码织入到待编译函数中,以实现对待编译函数的编译。
其中,一个实现类模板可对应实现一种功能,比如,清理磁盘,对于一待编译函数,如果需要实现该功能,则可以通过注解类调用该模板,并将模板中的模板函数修改。实现类模板中的模板函数是固定的,在不同的待编译函数需要调用该实现类模板时,需要基于待编译函数对模板函数进行修改。
待编译函数与实现类模板对应实现的是同一种功能,则实现类模板应该具有动态能力,比如,获取函数名的能力,即该目标实现类的模板函数不是写死的,是可以进行动态修改的,修改后的实现类模板的模板函数可以对应实现待编译函数对应的功能。则在对编译待编译函数之前,对实现类模板中的模板函数进行修改,从而在编译待编译函数时,可将修改后的实现类模板的字节码织入到待编译函数中,以实现对待编译函数的编译。
作为一个示例,实现类模板A可实现的功能为清理磁盘,该实现类模板A对应的注解类为注解类Q,该实现类模板A中的模板函数可实现清理磁盘的功能,待编译函数也是可以是实现清理磁盘功能的函数。可实现清理磁盘的函数共有两个,分别为函数1和函数2,函数1实现的是清理磁盘C,函数2实现的是清理磁盘D,函数1和函数2对应的功能相同,都是清理磁盘,则这两个函数可对应同一个实现类模板A,且这两个函数均可以作为待编译函数,这两个函数所标记的注解类均可以为注解类Q。建立起注解类Q与实现类模板A之间的对应关系,待编译函数为函数1,则在对待编译函数编译时,可通过该待编译函数所标记的注解类Q,以及上述对应关系,将该注解类Q对应的实现类模板A作为该待编译函数的目标实现类模板,然后基于该待编译函数对实现类模板A中的模板函数进行修改,使得修改后的实现类模板A对应实现的是函数1对应的功能(清理磁盘C),将修改后的实现类模板A的字节码织入到待编译函数(函数1)中,以实现对该待编译函数的编译。
通过上述方式,如果增加一种新的功能播放音乐,基于该新的功能程序人员可编写对应的实现类模板B,该实现类模板B可实现播放音乐的功能,为该实现类模板B创建一个注解类W,即通过该注解类W注解标记该实现类模板B,建立该注解类W和实现类模板B之间的对应关系。待编译函数标记有注解类W,则可基于上述图1中的方案,对该待编译函数进行编译。不需要为注解类W标记的实现类模板B编写一个插件,只需建立注解W与实现类模板B之间的对应关系即可,从而可节省开发成本。
本公开的实施例中的方案,在开发一个基于注解类的新功能时,可预先建立该注解类和该新功能对应的实现类模板之间的对应关系,该实现类模板对应有该新功能对应的代码;在想要对待编译函数进行编译时,可基于该待编译函数所标记的注解类,以及预先建立的对应关系,确定该待编译函数对应的目标实现类模板,并基于该待编译函数对目标实现类模板中的模板函数进行修改,在编译该待编译函数时,将修改后的目标实现类模板的字节码织入到待编译函数中,以实现对待编译函数的编译。通过该方案,在开发一个基于注解类的新功能时,程序人员可基于该新功能编写一个实现类模板,建立该实现类模板与对应的新的注解类之间的新的对应关系,不需要编写一个新的插件,在编译时,通过该建立的对应关系即可获取到待编译函数对应的实现类模板,从而提高编译效率,节省开发成本。
本公开的实施例中,对应关系是通过以下方式建立的:
创建目标注解类;
获取目标实现类模板;
基于目标注解类对目标实现类模板进行注解标记,以建立起目标注解类和目标实现类模板之间的对应关系。
其中,基于上述对应关系的建立方式,其他注解与对应的实现类模板之间也可以通过上述方式建立对应关系,即基于上述对应方式的建立方式,可以建立起各个注解类与各个注解类各自所对应的实现类模板之间的对应关系。
可以理解的是,一个注解类和对应的实现类模板之间可以对应一个对应关系,即注解类与对应的实现类模板之间是一对一的关系。
作为一个示例,创建一个注解类,可通过以下代码实现:
@Documented
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.CLASS)
public@interfaceCheckOnMainThread{
}
其中,该注解类的名称为“CheckOnMainThread”。
然后,定义实现类模板(下文可称之为注解模板),比如,注解模板可通过@AnnotationStencil标识;建立该注解模板与对应注解类之间的对应关系,该对应关系可以记为:、
@AnnotationStencil(annoClass=CheckMainThread.class)。
接着,通过该注解类标记函数,可通过以下代码表示:
Figure BDA0002410986850000071
其中,needRunOnMainThread()是待编译函数,这个函数是被CheckOnMainThread这个注解类进行标记的函数,通过@CheckOnMainThread实现对该函数的标记。
本公开的实施例中,该方法还包括:
获取原始实现类模板的字节码,其中,该原始实现类模板对应的字节码指的是未经过任何改动的字节码。
遍历原始实现类模板的字节码,收集原始实现类模板中的模板函数的字节码,此处,模板函数对应的字节码是写死的;
将原始实现类模板中模板函数的字节码修改为特定字节码,得到实现类模板。此时,具有特定字节码的实现类模板是具有动态调用能力的。
其中,在建立上述对应关系的过程中,由于模板函数通常是固定不变的,如果想通过一个实现类模板对应实现多个函数的功能,在对函数进行编译时,需要该实现类模板有一些动态调整的能力,在本方案中,将原始实现类模板中模板函数的字节码修改为特定字节码,比如,getName()。修改后的实现类模板具有该动态调整的能力,即在编译时,对应实现的是多个可实现该模板对应功能的函数中的哪个函数的功能。
基于上述特定字节码的设置,进一步地,基于待编译函数对实现类模板中的模板函数进行修改,包括:
基于待编译函数的字节码对实现类模板中的特定字节码进行替换。
其中,通过特定字节码,在对待编译函数进行编译时,可以基于待编译函数的字节码将实现类模板中的特定字节码的替换,以使得可以实现待编译函数对应的功能。
本公开的实施例中,若目标注解类为包含注解变量的注解类,该方法还包括:
获取在目标注解类中注解变量的当前值;
若当前值不等于目标实现类模板中注解变量的默认值,在确定待编译函数对应的目标实现类模板之后,该方法还包括:
在目标实现类模板中将注解变量的值修改为当前值。
其中,判断目标注解类的注解变量的当前值是否是默认值,在当前值不是默认值时,称该当前值为传值,即该注解变量的值不是默认值,则在建立对应关系的过程中,可收集各注解类的注解变量的变量类型和默认值,如果注解变量是传值,则可将注解变量的值进行修改。
在目标注解类的注解变量的当前值不等于默认值时,表示该目标注解类的注解变量是可以被修改的。则在调用目标注解类对应的目标实现类模板时,可以基于目标实现类模板中的注解变量的值,确定在编译待编译函数时,修改后的实现类模板中的注解变量是采用的默认值还是传值。
作为一个示例:注解变量String tag()default"LogMethod;
其中,注解标记为:@LogMethod("LogMethod$First");
fun fun1(){
//code
}
其中,上述待编译函数fun1()标记时的注解变量为LogMethod$First,不是LogMethod,则此时的注解变量为传值。
进而,若当前值不等于注解类的默认值,在确定待编译函数对应的实现类模板之后,可将实现类模板中注解变量的值修改为当前值,即该实现类模板中的注解变量为当前值(传值),基于该当前值编译该待编译函数。如果当前值等于默认值,在确定待编译函数对应的实现类模板之后,实现类模板中注解变量的值即为默认值,基于该默认值编译该待编译函数。
作为一个可选方案,变量类型可以为int型,long型。
通过上述功能实现了可传参的注解标记,在基于实现类模板的模板函数获取的都是一些固定的信息,比如,函数名/类名,这些都是开发者无法做出差异化的,但是,在需要对实现类模板做一些差异化的事时,举个例子,一个可实现打印函数日志的注解模板,在基于该模板打印日志的时候,如果希望打印两个不相同的日志,并且是由开发者来定义,可在该注解模板中增加一个注解变量(传值),在调用该实现类模板时,可以基于该传值打印出与默认值有差异的日志。
本公开的实施例中,目标注解类为对应于指定作用域的注解类。
其中,指定作用域指的是注解类对应的作用范围,在建立对应关系的过程中,可基于实际需求,设置目标注解类的作用域,被设置过作用域的注解类,其对应的函数可以在该作用域对应的范围内进行安全访问。
在一个可选方案中,可通过设定标记设置注解类的作用域。则在识别到该设定标记时,可以确定该标记对应的注解类为指定作用域的注解类。
作为一个示例,一个函数Enter,该函数对应的实现类模板的代码为:
Figure BDA0002410986850000091
Figure BDA0002410986850000101
如果开发过程中需要将函数Enter修改成并发安全的函数,即设置该函数Enter对应注解类的作用域,可以该函数对应的实现类模板上增加一个注解(设定标记)@SynchronizedMethod,代码如下:
Figure BDA0002410986850000102
在增加设定标记后,在识别到该设定标记@SynchronizedMethod时,可以确定该标记对应的注解类为指定作用域的注解类。
本公开的实施例中,该方法还包括:
在实现类模板中标记模板的织入位置,则在目标实现类模板中标记有织入位置。
将修改后的目标实现类模板的字节码织入到待编译函数中,包括:
根据目标实现类模板中所标记的织入位置,将修改后的目标实现类模板的字节码织入到待编译函数中。
其中,在实现类模板中可以标记出模板的织入位置,即在函数编译时,实现类模板的代码所织入的位置,织入位置可以基于实际需求配置,比如,可以是一个设定的字符串。
作为一个示例,有两个函数供模板字节码织入,一个是函数Enter,一个是函数Exit,在编辑是实现类模板时,可以通过上述两个函数在模板中标记出模板的织入位置,如以下代码所示:
Figure BDA0002410986850000103
Figure BDA0002410986850000111
其中,在onMethodEnter对应的位置处,可以织入模板字节码,在onMethodExit对应的位置处,也可以织入模板字节码。则通过上述的设置,可以在将修改后的实现类模板的字节码织入到待编译函数中时,将该实现类模板的字节码织入到待编译函数对应的织入位置。
本公开的实施例中,该方法还包括:
确定目标实现类模板中的模板函数的字节码对应的特定字节码;
建立目标实现类模板中的模板函数的字节码与对应的特定字节码的映射关系;
基于待编译函数的字节码对目标实现类模板中的特定字节码进行替换,包括:
基于目标实现类模板中模板函数的字节码,以及映射关系,确定目标实现类模板对应的特定字节码;
基于待编译函数的字节码对目标实现类模板对应的特定字节码进行替换。
其中,为了不直接替换目标实现类中的模板函数的字节码,可以基于模板函数的字节码与对应的特定字节码,建立两者之间的映射关系,特定字节码可以作为模板函数的伪名字。则在基于待编译函数的字节码对实现类模板中的特定字节码进行替换时,可以先基于目标实现类模板中模板函数的字节码,以及映射关系,确定目标实现类模板对应的特定字节码,然后基于待编译函数的字节码对目标实现类模板对应的特定字节码进行替换。
另一方面,特定字节码可以作为模板函数的字节码的占位符,在编译待编译函数之前,还不知道具体是要对哪个待编译函数进行编译,可先将该待编译函数对应的字节码通过该占位符进行标识,然后在对该待编译函数进行编译时,可将该待编译函数对应的字节码替换该模板函数的特定字节码。
基于与图1中所示的函数编译方法相同的原理,本公开的实施例中还提供了一种函数编译装置20,如图2所示,该装置20可以包括:函数获取模块210、实现类模板确定模块220、模板处理模块230以及函数编译模块240,其中,
函数获取模块210,用于获取待编译函数,待编译函数标记有目标注解类;
实现类模板确定模块220,用于基于目标注解类,以及预先建立的对应关系,确定待编译函数对应的目标实现类模板,对应关系包括目标注解类与目标实现类模板之间的对应关系;
模板处理模块230,用于基于待编译函数对目标实现类模板中的模板函数进行修改,得到修改后的目标实现类模板;
函数编译模块240,用于将修改后的目标实现类模板的字节码织入到待编译函数中,以实现对待编译函数的编译。
本公开实施例的函数编译装置,在开发一个基于注解类的新功能时,可预先建立该注解类和该新功能对应的实现类模板之间的对应关系,该实现类模板对应有该新功能对应的代码;在想要对待编译函数进行编译时,可基于该待编译函数所标记的注解类,以及预先建立的对应关系,确定该待编译函数对应的目标实现类模板,并基于该待编译函数对目标实现类模板中的模板函数进行修改,在编译该待编译函数时,将修改后的目标实现类模板的字节码织入到待编译函数中,以实现对待编译函数的编译。通过该方案,在开发一个基于注解类的新功能时,程序人员可基于该新功能编写一个实现类模板,建立该实现类模板与对应的新的注解类之间的新的对应关系,不需要编写一个新的插件,在编译时,通过该建立的对应关系即可获取到待编译函数对应的实现类模板,从而提高编译效率,节省开发成本。
可选地,对应关系是通过以下方式建立的:
创建目标注解类;
获取目标实现类模板;
基于目标注解类对实现类模板进行注解标记,以建立起目标注解类和目标实现类模板之间的对应关系。
可选地,函数编译模块在基于待编译函数对目标实现类模板中的模板函数进行修改时,具体用于:
基于待编译函数的字节码对目标实现类模板中的特定字节码进行替换,其中,特定字节码用于表征模板函数。
可选地,若目标注解类为包含注解变量的注解类,该装置还包括:
当前值获取模块,用于获取在目标注解类中注解变量的当前值;
若当前值不等于目标实现类模板中注解变量的默认值,该装置还包括:
注解变量处理模块,用于在确定待编译函数对应的目标实现类模板之后,在目标实现类模板中将注解变量的值修改为当前值。
可选地,目标注解类为对应于指定作用域的注解类。
可选地,在目标实现类模板中标记有织入位置;
函数编译模块在将修改后的目标实现类模板的字节码织入到待编译函数中时,具体用于:
根据目标实现类模板中所标记的织入位置,将修改后的目标实现类模板的字节码织入到待编译函数中。
可选地,该装置还包括:
映射关系建立模块,用于确定目标实现类模板中的模板函数的字节码对应的特定字节码;建立目标实现类模板中的模板函数的字节码与对应的特定字节码的映射关系;
函数编译模块在基于待编译函数的字节码对目标实现类模板中的特定字节码进行替换时,具体用于:
基于目标实现类模板中模板函数的字节码,以及映射关系,确定实现类模板对应的特定字节码;
基于待编译函数的字节码对目标实现类模板对应的特定字节码进行替换。
可选地,目标实现类模板是通过高级编程语言编写的。
本公开实施例的装置可执行图1所示的一种函数编译方法,其实现原理相类似,本公开各实施例中的函数编译装置中的各模块所执行的动作是与本公开各实施例中的函数编译方法中的步骤相对应的,对于函数编译装置的各模块的详细功能描述具体可以参见前文中所示的对应的函数编译方法中的描述,此处不再赘述。
基于与本公开的实施例中的方法相同的原理,下面参考图3,其示出了适于用来实现本公开实施例的电子设备(例如图1中的终端设备)600的结构示意图。本公开实施例中的终端设备可以包括但不限于诸如移动电话、笔记本电脑、数字广播接收器、PDA(个人数字助理)、PAD(平板电脑)、PMP(便携式多媒体播放器)、车载终端(例如车载导航终端)等等的移动终端以及诸如数字TV、台式计算机等等的固定终端。图3示出的电子设备仅仅是一个示例,不应对本公开实施例的功能和使用范围带来任何限制。
电子设备包括:存储器以及处理器,其中,这里的处理器可以称为下文的处理装置601,存储器可以包括下文中的只读存储器(ROM)602、随机访问存储器(RAM)603以及存储装置608中的至少一项,具体如下所示:
如图3所示,电子设备600可以包括处理装置(例如中央处理器、图形处理器等)601,其可以根据存储在只读存储器(ROM)602中的程序或者从存储装置608加载到随机访问存储器(RAM)603中的程序而执行各种适当的动作和处理。在RAM 603中,还存储有电子设备600操作所需的各种程序和数据。处理装置601、ROM 602以及RAM 603通过总线604彼此相连。输入/输出(I/O)接口605也连接至总线604。
通常,以下装置可以连接至I/O接口605:包括例如触摸屏、触摸板、键盘、鼠标、摄像头、麦克风、加速度计、陀螺仪等的输入装置606;包括例如液晶显示器(LCD)、扬声器、振动器等的输出装置607;包括例如磁带、硬盘等的存储装置608;以及通信装置609。通信装置609可以允许电子设备600与其他设备进行无线或有线通信以交换数据。虽然图3示出了具有各种装置的电子设备600,但是应理解的是,并不要求实施或具备所有示出的装置。可以替代地实施或具备更多或更少的装置。
特别地,根据本公开的实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本公开的实施例包括一种计算机程序产品,其包括承载在非暂态计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信装置609从网络上被下载和安装,或者从存储装置608被安装,或者从ROM 602被安装。在该计算机程序被处理装置601执行时,执行本公开实施例的方法中限定的上述功能。
需要说明的是,本公开上述的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本公开中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。而在本公开中,计算机可读信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读信号介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:电线、光缆、RF(射频)等等,或者上述的任意合适的组合。
在一些实施方式中,客户端、服务器可以利用诸如HTTP(Hyper Text TransferProtocol,超文本传输协议)之类的任何当前已知或未来研发的网络协议进行通信,并且可以与任意形式或介质的数字数据通信(例如,通信网络)互连。通信网络的示例包括局域网(“LAN”),广域网(“WAN”),网际网(例如,互联网)以及端对端网络(例如,ad hoc端对端网络),以及任何当前已知或未来研发的网络。
上述计算机可读介质可以是上述电子设备中所包含的;也可以是单独存在,而未装配入该电子设备中。
上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被该电子设备执行时,使得该电子设备:通过视频播放界面,接收用户针对当前所播放视频的视频帧图像中的图像区域的触发操作;若视频帧图像中包含指定对象,且图像区域为指定对象所对应的指定区域,则生成针对指定对象的对象信息获取请求;基于对象信息获取请求,获取指定对象的链接信息并显示。
可以以一种或多种程序设计语言或其组合来编写用于执行本公开的操作的计算机程序代码,上述程序设计语言包括但不限于面向对象的程序设计语言—诸如Java、Smalltalk、C++,还包括常规的过程式程序设计语言—诸如“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络——包括局域网(LAN)或广域网(WAN)—连接到用户计算机,或者,可以连接到外部计算机(例如利用因特网服务提供商来通过因特网连接)。
附图中的流程图和框图,图示了按照本公开各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,该模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
描述于本公开实施例中所涉及到的模块或单元可以通过软件的方式实现,也可以通过硬件的方式来实现。其中,模块或单元的名称在某种情况下并不构成对该单元本身的限定。
本文中以上描述的功能可以至少部分地由一个或多个硬件逻辑部件来执行。例如,非限制性地,可以使用的示范类型的硬件逻辑部件包括:现场可编程门阵列(FPGA)、专用集成电路(ASIC)、专用标准产品(ASSP)、片上系统(SOC)、复杂可编程逻辑设备(CPLD)等等。
在本公开的上下文中,机器可读介质可以是有形的介质,其可以包含或存储以供指令执行系统、装置或设备使用或与指令执行系统、装置或设备结合地使用的程序。机器可读介质可以是机器可读信号介质或机器可读储存介质。机器可读介质可以包括但不限于电子的、磁性的、光学的、电磁的、红外的、或半导体系统、装置或设备,或者上述内容的任何合适组合。机器可读存储介质的更具体示例会包括基于一个或多个线的电气连接、便携式计算机盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦除可编程只读存储器(EPROM或快闪存储器)、光纤、便捷式紧凑盘只读存储器(CD-ROM)、光学储存设备、磁储存设备、或上述内容的任何合适组合。
根据本公开的一个或多个实施例,【示例一】提供了一种函数编译方法,包括:
获取待编译函数,所述待编译函数标记有目标注解类;
基于所述目标注解类,以及预先建立的对应关系,确定所述待编译函数对应的目标实现类模板,所述对应关系包括所述目标注解类与所述目标实现类模板之间的对应关系;
基于所述待编译函数对所述目标实现类模板中的模板函数进行修改,得到修改后的目标实现类模板;
将所述修改后的目标实现类模板的字节码织入到所述待编译函数中,以实现对所述待编译函数的编译。
根据本公开的一个或多个实施例,所述对应关系是通过以下方式建立的:
创建所述目标注解类;
获取所述目标实现类模板;
基于所述目标注解类对所述目标实现类模板进行注解标记,以建立起所述目标注解类和所述目标实现类模板之间的对应关系。
根据本公开的一个或多个实施例,所述基于所述待编译函数对所述目标实现类模板中的模板函数进行修改,包括:
基于所述待编译函数的字节码对所述目标实现类模板中的特定字节码进行替换,其中,所述特定字节码用于表征模板函数。
根据本公开的一个或多个实施例,若所述目标注解类为包含注解变量的注解类,所述方法还包括:
获取在所述目标注解类中所述注解变量的当前值;
若所述当前值不等于所述目标实现类模板中所述注解变量的默认值,在确定所述待编译函数对应的目标实现类模板之后,还包括:
在所述目标实现类模板中将所述注解变量的值修改为当前值。
根据本公开的一个或多个实施例,所述目标注解类为对应于指定作用域的注解类。
根据本公开的一个或多个实施例,在所述目标实现类模板中标记有织入位置;
所述将所述修改后的目标实现类模板的字节码织入到所述待编译函数中,包括:
根据所述目标实现类模板中所标记的织入位置,将所述修改后的目标实现类模板的字节码织入到所述待编译函数中。
根据本公开的一个或多个实施例,所述方法还包括:
确定所述目标实现类模板中的模板函数的字节码对应的特定字节码;
建立所述目标实现类模板中的模板函数的字节码与对应的特定字节码的映射关系;
所述基于所述待编译函数的字节码对所述目标实现类模板中的特定字节码进行替换,包括:
基于所述目标实现类模板中模板函数的字节码,以及所述映射关系,确定所述目标实现类模板对应的特定字节码;
基于所述待编译函数的字节码对所述目标实现类模板对应的目标特定字节码进行替换。
根据本公开的一个或多个实施例,所述目标实现类模板是通过高级编程语言编写的。
根据本公开的一个或多个实施例,【示例二】提供了一种函数编译装置,该装置包括:
函数获取模块,用于获取待编译函数,所述待编译函数标记有目标注解类;
实现类模板确定模块,用于基于所述目标注解类,以及预先建立的对应关系,确定所述待编译函数对应的目标实现类模板,所述对应关系包括所述目标注解类与所述目标实现类模板之间的对应关系;
模板处理模块,用于基于所述待编译函数对所述目标实现类模板中的模板函数进行修改,得到修改后的目标实现类模板;
函数编译模块,用于将所述修改后的目标实现类模板的字节码织入到所述待编译函数中,以实现对所述待编译函数的编译。
根据本公开的一个或多个实施例,所述对应关系是通过以下方式建立的:
创建所述目标注解类;
获取所述目标实现类模板;
基于所述目标注解类对所述目标实现类模板进行注解标记,以建立起所述目标注解类和所述目标实现类模板之间的对应关系。
根据本公开的一个或多个实施例,所述函数编译模块在基于所述待编译函数对所述目标实现类模板中的模板函数进行修改时,具体用于:
基于所述待编译函数的字节码对所述目标实现类模板中的特定字节码进行替换,其中,所述特定字节码用于表征模板函数。
根据本公开的一个或多个实施例,若所述目标注解类为包含注解变量的注解类,所述装置还包括:
当前值获取模块,用于获取在所述目标注解类中所述注解变量的当前值;
若所述当前值不等于所述目标实现类模板中所述注解变量的默认值,所述装置还包括:
注解变量处理模块,用于在确定所述待编译函数对应的目标实现类模板之后,在所述目标实现类模板中将所述注解变量的值修改为当前值。
根据本公开的一个或多个实施例,所述目标注解类为对应于指定作用域的注解类。
根据本公开的一个或多个实施例,在所述目标实现类模板中标记有入位置;
所述函数编译模块在将所述修改后的目标实现类模板的字节码织入到所述待编译函数中时,具体用于:
根据所述目标实现类模板中所标记的织入位置,将所述修改后的目标实现类模板的字节码织入到所述待编译函数中。
根据本公开的一个或多个实施例,所述装置还包括:
映射关系建立模块,用于确定所述目标实现类模板中的模板函数的字节码对应的特定字节码;建立所述目标实现类模板中的模板函数的字节码与对应的特定字节码的映射关系;
所述函数编译模块在基于所述待编译函数的字节码对所述目标实现类模板中的特定字节码进行替换时,具体用于:
基于所述目标实现类模板中模板函数的字节码,以及所述映射关系,确定所述目标实现类模板对应的特定字节码;
基于所述待编译函数的字节码对所述目标实现类模板对应的目标特定字节码进行替换。
根据本公开的一个或多个实施例,所述目标实现类模板是通过高级编程语言编写的。
以上描述仅为本公开的较佳实施例以及对所运用技术原理的说明。本领域技术人员应当理解,本公开中所涉及的公开范围,并不限于上述技术特征的特定组合而成的技术方案,同时也应涵盖在不脱离上述公开构思的情况下,由上述技术特征或其等同特征进行任意组合而形成的其它技术方案。例如上述特征与本公开中公开的(但不限于)具有类似功能的技术特征进行互相替换而形成的技术方案。
此外,虽然采用特定次序描绘了各操作,但是这不应当理解为要求这些操作以所示出的特定次序或以顺序次序执行来执行。在一定环境下,多任务和并行处理可能是有利的。同样地,虽然在上面论述中包含了若干具体实现细节,但是这些不应当被解释为对本公开的范围的限制。在单独的实施例的上下文中描述的某些特征还可以组合地实现在单个实施例中。相反地,在单个实施例的上下文中描述的各种特征也可以单独地或以任何合适的子组合的方式实现在多个实施例中。
尽管已经采用特定于结构特征和/或方法逻辑动作的语言描述了本主题,但是应当理解所附权利要求书中所限定的主题未必局限于上面描述的特定特征或动作。相反,上面所描述的特定特征和动作仅仅是实现权利要求书的示例形式。

Claims (11)

1.一种函数编译方法,其特征在于,包括:
获取待编译函数,所述待编译函数标记有目标注解类;
基于所述目标注解类,以及预先建立的对应关系,确定所述待编译函数对应的目标实现类模板,所述对应关系为所述目标注解类与所述目标实现类模板之间的对应关系;
基于所述待编译函数对所述目标实现类模板中的模板函数进行修改,得到修改后的目标实现类模板;
将所述修改后的目标实现类模板的字节码织入到所述待编译函数中,以实现对所述待编译函数的编译。
2.根据权利要求1所述的方法,其特征在于,所述对应关系是通过以下方式建立的:
创建所述目标注解类;
获取所述目标实现类模板;
基于所述目标注解类对所述目标实现类模板进行注解标记,以建立起所述目标注解类和所述目标实现类模板之间的对应关系。
3.根据权利要求1所述的方法,其特征在于,所述基于所述待编译函数对所述目标实现类模板中的模板函数进行修改,包括:
基于所述待编译函数的字节码对所述目标实现类模板中的特定字节码进行替换,其中,所述特定字节码用于表征模板函数。
4.根据权利要求1所述的方法,其特征在于,若所述目标注解类为包含注解变量的注解类,所述方法还包括:
获取在所述目标注解类中所述注解变量的当前值;
若所述当前值不等于所述目标实现类模板中所述注解变量的默认值,在确定所述待编译函数对应的目标实现类模板之后,还包括:
在所述目标实现类模板中将所述注解变量的值修改为当前值。
5.根据权利要求1所述的方法,其特征在于,所述目标注解类为对应于指定作用域的注解类。
6.根据权利要求1所述的方法,其特征在于,在所述目标实现类模板中标记有织入位置;
所述将所述修改后的目标实现类模板的字节码织入到所述待编译函数中,包括:
根据所述目标实现类模板中所标记的织入位置,将所述修改后的目标实现类模板的字节码织入到所述待编译函数中。
7.根据权利要求3所述的方法,其特征在于,所述方法还包括:
确定所述目标实现类模板中的模板函数的字节码对应的特定字节码;
建立所述目标实现类模板中的模板函数的字节码与对应的特定字节码的映射关系;
所述基于所述待编译函数的字节码对所述目标实现类模板中的特定字节码进行替换,包括:
基于所述目标实现类模板中模板函数的字节码,以及所述映射关系,确定所述目标实现类模板对应的特定字节码;
基于所述待编译函数的字节码对所述目标实现类模板对应的目标特定字节码进行替换。
8.根据权利要求1至6中任一项所述的方法,其特征在于,所述目标实现类模板是通过高级编程语言编写的。
9.一种函数编译装置,其特征在于,包括:
函数获取模块,用于获取待编译函数,所述待编译函数标记有目标注解类;
实现类模板确定模块,用于基于所述目标注解类,以及预先建立的对应关系,确定所述待编译函数对应的目标实现类模板,所述对应关系包括所述目标注解类与所述目标实现类模板之间的对应关系;
模板处理模块,用于基于所述待编译函数对所述目标实现类模板中的模板函数进行修改,得到修改后的目标实现类模板;
函数编译模块,用于将所述修改后的目标实现类模板的字节码织入到所述待编译函数中,以实现对所述待编译函数的编译。
10.一种电子设备,其特征在于,包括:
处理器和存储器;
所述存储器,用于存储计算机操作指令;
所述处理器,用于通过调用所述计算机操作指令,执行权利要求1至8中任一项所述的方法。
11.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质存储有至少一条指令、至少一段程序、代码集或指令集,所述至少一条指令、所述至少一段程序、所述代码集或指令集由所述处理器加载并执行以实现权利要求1至8中任一项所述的方法。
CN202010176438.0A 2020-03-13 2020-03-13 函数编译方法、装置、电子设备及计算机可读存储介质 Active CN113391811B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202010176438.0A CN113391811B (zh) 2020-03-13 2020-03-13 函数编译方法、装置、电子设备及计算机可读存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202010176438.0A CN113391811B (zh) 2020-03-13 2020-03-13 函数编译方法、装置、电子设备及计算机可读存储介质

Publications (2)

Publication Number Publication Date
CN113391811A true CN113391811A (zh) 2021-09-14
CN113391811B CN113391811B (zh) 2023-11-03

Family

ID=77616119

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202010176438.0A Active CN113391811B (zh) 2020-03-13 2020-03-13 函数编译方法、装置、电子设备及计算机可读存储介质

Country Status (1)

Country Link
CN (1) CN113391811B (zh)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114895959A (zh) * 2022-05-06 2022-08-12 建信金融科技有限责任公司 数据处理方法、装置、设备及计算机存储介质
CN115543342A (zh) * 2022-11-28 2022-12-30 天津华来科技股份有限公司 在编译时替换启动页面的方法、电子设备、存储介质

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106648690A (zh) * 2016-12-29 2017-05-10 北京恒华伟业科技股份有限公司 一种代码自动生成方法及装置
US20190004774A1 (en) * 2017-06-28 2019-01-03 Google Inc. Automated source code adaption to inject features between platform versions
CN110716715A (zh) * 2019-10-18 2020-01-21 恒生电子股份有限公司 一种应用程序开发方法、装置、设备及介质
CN110737589A (zh) * 2019-09-10 2020-01-31 北京字节跳动网络技术有限公司 一种自动埋点的方法、装置、介质和电子设备
CN110764748A (zh) * 2019-10-23 2020-02-07 北京字节跳动网络技术有限公司 代码调用方法、装置、终端及存储介质
CN110795091A (zh) * 2018-08-01 2020-02-14 武汉斗鱼网络科技有限公司 一种模块化路由解耦方法、存储介质、电子设备及系统

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106648690A (zh) * 2016-12-29 2017-05-10 北京恒华伟业科技股份有限公司 一种代码自动生成方法及装置
US20190004774A1 (en) * 2017-06-28 2019-01-03 Google Inc. Automated source code adaption to inject features between platform versions
CN110795091A (zh) * 2018-08-01 2020-02-14 武汉斗鱼网络科技有限公司 一种模块化路由解耦方法、存储介质、电子设备及系统
CN110737589A (zh) * 2019-09-10 2020-01-31 北京字节跳动网络技术有限公司 一种自动埋点的方法、装置、介质和电子设备
CN110716715A (zh) * 2019-10-18 2020-01-21 恒生电子股份有限公司 一种应用程序开发方法、装置、设备及介质
CN110764748A (zh) * 2019-10-23 2020-02-07 北京字节跳动网络技术有限公司 代码调用方法、装置、终端及存储介质

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114895959A (zh) * 2022-05-06 2022-08-12 建信金融科技有限责任公司 数据处理方法、装置、设备及计算机存储介质
CN115543342A (zh) * 2022-11-28 2022-12-30 天津华来科技股份有限公司 在编译时替换启动页面的方法、电子设备、存储介质
CN115543342B (zh) * 2022-11-28 2023-03-24 天津华来科技股份有限公司 在编译时替换启动页面的方法、电子设备、存储介质

Also Published As

Publication number Publication date
CN113391811B (zh) 2023-11-03

Similar Documents

Publication Publication Date Title
CN112395253B (zh) 索引文件生成方法、终端设备、电子设备及介质
CN111290760A (zh) 应用程序编译方法、装置、电子设备及存储介质
CN111581555A (zh) 一种文档加载方法、装置、设备及存储介质
US11818491B2 (en) Image special effect configuration method, image recognition method, apparatus and electronic device
CN113391811B (zh) 函数编译方法、装置、电子设备及计算机可读存储介质
CN111309304B (zh) 一种生成idl文件的方法、装置、介质和电子设备
CN112416303B (zh) 软件开发工具包热修复方法、装置及电子设备
CN110704050B (zh) 模块初始化方法、装置、电子设备及计算机可读存储介质
CN111666218B (zh) 代码审计方法、装置、电子设备及介质
CN113220281A (zh) 一种信息生成方法、装置、终端设备及存储介质
CN111752644A (zh) 接口模拟方法、装置、设备及存储介质
CN111669476A (zh) 水印处理方法、装置、电子设备和介质
CN111124541A (zh) 一种配置文件的生成方法、装置、设备及介质
CN115878115A (zh) 页面渲染方法、装置、介质和电子设备
CN112162755B (zh) 一种数据处理方法、装置、介质和电子设备
CN112965713A (zh) 可视化编辑器的开发方法、装置、设备及存储介质
CN114035804A (zh) 代码转换方法、装置、介质和电子设备
CN111199519B (zh) 特效包的生成方法和装置
CN113391860A (zh) 服务请求处理方法、装置、电子设备及计算机存储介质
CN111240801A (zh) 生成堆内存快照文件的方法、装置、介质和电子设备
CN111309323A (zh) 参数初始化方法、装置和电子设备
CN116931934A (zh) 着色器代码的转换方法、装置、设备及存储介质
CN114493517A (zh) 项目调试方法、装置、可读介质及电子设备
CN113934639A (zh) 数据处理方法、装置、可读介质和电子设备
CN115878091A (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
CB02 Change of applicant information
CB02 Change of applicant information

Address after: 100041 B-0035, 2 floor, 3 building, 30 Shixing street, Shijingshan District, Beijing.

Applicant after: Douyin Vision Co.,Ltd.

Address before: 100041 B-0035, 2 floor, 3 building, 30 Shixing street, Shijingshan District, Beijing.

Applicant before: Tiktok vision (Beijing) Co.,Ltd.

Address after: 100041 B-0035, 2 floor, 3 building, 30 Shixing street, Shijingshan District, Beijing.

Applicant after: Tiktok vision (Beijing) Co.,Ltd.

Address before: 100041 B-0035, 2 floor, 3 building, 30 Shixing street, Shijingshan District, Beijing.

Applicant before: BEIJING BYTEDANCE NETWORK TECHNOLOGY Co.,Ltd.

GR01 Patent grant
GR01 Patent grant