CN109960595A - 一种队列引用方法及装置 - Google Patents

一种队列引用方法及装置 Download PDF

Info

Publication number
CN109960595A
CN109960595A CN201711415068.6A CN201711415068A CN109960595A CN 109960595 A CN109960595 A CN 109960595A CN 201711415068 A CN201711415068 A CN 201711415068A CN 109960595 A CN109960595 A CN 109960595A
Authority
CN
China
Prior art keywords
queue
quoted
current
type identification
preset
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
Application number
CN201711415068.6A
Other languages
English (en)
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 Gridsum Technology Co Ltd
Original Assignee
Beijing Gridsum 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 Gridsum Technology Co Ltd filed Critical Beijing Gridsum Technology Co Ltd
Priority to CN201711415068.6A priority Critical patent/CN109960595A/zh
Publication of CN109960595A publication Critical patent/CN109960595A/zh
Pending legal-status Critical Current

Links

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/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • G06F9/546Message passing systems or structures, e.g. queues

Abstract

本发明公开了一种队列引用方法及装置,涉及数据处理技术领域,为解决现有的引用队列通过标注后硬编码目标队列,导致的当目标队列名更改时,需要进行手动替换全部应用场合造成的操作繁琐、队列引用效率低的问题。本发明的方法包括:获取待引用队列的类型标识;根据所述待引用队列的类型标识,提取所述待引用队列;在当前队列中引用所述待引用队列。本发明适合应用在对队列的引用中。

Description

一种队列引用方法及装置
技术领域
本发明涉及数据处理技术领域,尤其涉及一种队列引用方法及装置。
背景技术
随着计算机技术的不断发展,各行各业产生的数据均大大增加,对不同的数据按照不同数据结构进行存储可以带来更高的运行或者存储效率。其中,队列是一种常用的数据结构。队列是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,在表的后端(rear)进行插入操作,但队列和队列之间可以通过引用操作进行队列消息传递。
在实际项目开发过程中,会将当前项目中的各Job任务信息存储在队列中,开发人员针对各个队列写对应的队列消息处理器JobRunner,而当在某个队列消息处理器JobRunner中需要引用目标队列时,需要硬编码目标队列名,这种情况下,若目标队列名称发生更改时,需要在所有有可能引用更改后的目标队列的场合手动进行名称的搜索、替换,使得操作异常繁琐,并造成队列引用效率较低的问题。
发明内容
鉴于上述问题,本发明提供一种队列引用方法及装置,主要目的在通过待引用队列的类型标识获取待引用队列并进行引用。
为解决上述技术问题,第一方面,本发明提供了一种队列引用方法,该方法包括:
获取待引用队列的类型标识,所述待引用队列的类型标识用于标识所述待引用队列所在的队列消息处理器;
根据所述待引用队列的类型标识,提取所述待引用队列;
在当前队列中引用所述待引用队列,所述当前队列为当前运行的任务消息所在的队列。
可选的,所述获取待引用队列对应的类型标识之前,所述方法还包括:
检测在所述当前队列中是否存在预置队列引用标识符,所述预置队列引用标识符用于标识所述当前队列为需要进行队列引用的队列,且所述预置队列引用标识符为一个或多个;
所述获取待引用队列对应的类型标识包括:
若是,则依次提取与各个所述预置队列引用标识符分别对应的所述带引用队列的类型标识。
可选的,所述根据所述待引用队列的类型标识,提取所述待引用队列包括:
根据所述待引用队列对应的类型标识,从预置存储区域中提取与所述类型标识对应的队列消息处理器,所述预置存储区域中保存有全部待引用队列对应的队列消息处理器;
从所述队列消息处理器中提取所述待引用队列。
可选的,所述方法还包括:
设置与所述当前队列对应的数据类型,所述与所述当前队列对应的数据类型为标识所述当前队列包含的全部元素需要匹配的数据类型。
可选的,在当前队列中引用所述待引用队列之前,所述方法还包括:
获取与所述待引用队列对应的数据类型;
检测所述待引用队列对应的数据类型与所述当前队列对应的数据类型是否匹配;
若匹配,则进入在当前队列中引用所述待引用队列的步骤。
可选的,所述方法还包括:
若所述待引用队列对应的数据类型与所述当前队列对应的数据类型不匹配,则输出提示信息。
第二方面,本发明还提供了一种队列引用装置,该装置包括:
获取单元,用于获取待引用队列的类型标识,所述待引用队列的类型标识用于标识所述待引用队列所在的队列消息处理器;
提取单元,用于根据所述待引用队列的类型标识,提取所述待引用队列;
引用单元,用于在当前队列中引用所述待引用队列,所述当前队列为当前运行的任务消息所在的队列。
可选的,所述装置还包括:检测单元,
所述检测单元,用于检测在所述当前队列中是否存在预置队列引用标识符,所述预置队列引用标识符用于标识所述当前队列为需要进行队列引用的队列,且所述预置队列引用标识符为一个或多个;
所述提取单元,具体用于若在所述当前队列中存在预置队列引用标识符,则依次提取与各个所述预置队列引用标识符分别对应的所述带引用队列的类型标识。
可选的,所述提取单元包括:
第一提取模块,用于根据所述待引用队列对应的类型标识,从预置存储区域中提取与所述类型标识对应的队列消息处理器,所述预置存储区域中保存有全部待引用队列对应的队列消息处理器;
第二提取模块,用于从所述队列消息处理器中提取所述待引用队列。
可选的,装置还包括:
设置单元,用于设置与所述当前队列对应的数据类型,所述与所述当前队列对应的数据类型为标识所述当前队列包含的全部元素需要匹配的数据类型。
可选的,所述获取单元,还用于获取与所述待引用队列对应的数据类型;
所述检测单元,还用于检测所述待引用队列对应的数据类型与所述当前队列对应的数据类型是否匹配;
所述引用单元,具体用于若所述待引用队列对应的数据类型与所述当前队列对应的数据类型匹配,则在当前队列中引用所述待引用队列。
可选的,所述装置还包括:
输出单元,用于若所述待引用队列对应的数据类型与所述当前队列对应的数据类型不匹配,则输出提示信息。
为了实现上述目的,根据本发明的第三方面,提供了一种存储介质,所述存储介质包括存储的程序,其中,在所述程序运行时控制所述存储介质所在设备执行上述所述的队列引用方法。
为了实现上述目的,根据本发明的第四方面,提供了一种处理器,所述处理器用于运行程序,其中,所述程序运行时执行上述所述的队列引用方法。
借由上述技术方案,本发明提供的队列引用方法及装置,对于现有技术在对队列进行引用时,将目标队列对应的名称等通过Queue进行标注并硬编码目标队列名,从而使得当目标队列名称修改时需要在有可能引用更改后的目标队列的场合,手动修改全部目标队列名称,操作异常繁琐且队列引用效率较低,本发明通过在当前队列中获取待引用队列的类型标识,从而根据该类型标识获得待引用队列所在的队列消息处理器,然后再提取待引用队列并在当前队列中进行引用,因此相比于现有技术,本发明在对队列进行引用时,通过待引用队列的类型标识获取待引用队列,而不是将与待引用队列的标识信息对应的字符串等配置在当前队列中,从而使得当待引用队列名称更改时,并不会影响其他引用了该待引用队列的队列的正常运行,大大简化了操作且提高了队列引用的效率;此外,根据本发明的方法在对队列引用之前即可检测待引用队列的元素数据类型与当前队列的元素数据类型是否匹配,从而能够在确保待引用队列与当前队列元素数据类型匹配的情况下,对队列进行引用,避免了在实际运行过程中才发现不匹配而造成的时间和资源浪费的问题,从而提高了队列引用的效率,且节约了资源。
上述说明仅是本发明技术方案的概述,为了能够更清楚了解本发明的技术手段,而可依照说明书的内容予以实施,并且为了让本发明的上述和其它目的、特征和优点能够更明显易懂,以下特举本发明的具体实施方式。
附图说明
通过阅读下文优选实施方式的详细描述,各种其他的优点和益处对于本领域普通技术人员将变得清楚明了。附图仅用于示出优选实施方式的目的,而并不认为是对本发明的限制。而且在整个附图中,用相同的参考符号表示相同的部件。在附图中:
图1示出了本发明实施例提供的一种队列引用方法流程图;
图2示出了本发明实施例提供的另一种队列引用方法流程图;
图3示出了本发明实施例提供的一种队列引用装置的组成框图;
图4示出了本发明实施例提供的另一种队列引用装置的组成框图。
具体实施方式
下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。
为了简化队列引用的操作,提高队列引用的效率,本发明实施例提供了一种队列引用方法,如图1所示,该方法包括:
101、获取待引用队列的类型标识。
其中,所述待引用队列的类型标识用于标识所述待引用队列所在的队列消息处理器。例如,待引用队列的类型标识可以为JobRunnerl,表明该待引用队列在队列消息处理器JobRunnerl中。具体地,可以预先设定用以标识队列引用的标识符,如通过Queue、QueueTrigger等进行标注,从而当检测到预设队列里引用标识符时,说明此时需要对当前队列以外的其他队列进行引用,触发生成引用指令,以使得相应装置在接收到引用请求后采取相应的措施以完成对队列的引用。
需要说明的是,对于本发明实施例的执行主体可以为配置在队列Job消息数据处理装置(如JobRunner队列消息数据处理程序)中用于引用队列的装置,通过在JobRunner利用预置队列引用标识符进行标注,从而在处理过程中当执行到队列引用标识符对应的任务时,触发对队列进行引用,进而通过引用队列实现队列之间消息的传递。
102、根据所述待引用队列的类型标识,提取所述待引用队列。
对于本发明实施例,可以预先将各个队列消息处理器存储在预置存储区域内,从而在当前队列中获取到当前队列需要引用的待引用队列的类型标识之后,从预置存储区域内根据该类型标识提取到对应的待引用队列。
103、在当前队列中引用所述待引用队列。
其中,所述当前队列为当前运行的任务消息所在的队列。
对于本发明实施例,可以在当前队列中进行配置IOutputQueue<a,b>,其中a为待引用队列中元素的数据类型,b为待引用队列对应的类型标识,从而当当前队列消息运行到IOutputQueue<a,b>时,触发实现队列引用。
例如,当在JobRunner2的当前队列2引用JobRunnerl中的队列1时,可以在JobRunner2中进行如下配置,实现对队列1的引用:
其中,IOutputQueue<int,JobRunnerl>用来作为队列引用标识,而int为队列1中元素的数据类型,JobRunnerl为队列1对应的类型标识。从而当在执行JobRunner2的队列任务时,在运行到IOutputQueue<int,JobRunner1>时,会对JobRunner1中的队列1进行引用,并最终实现将队列2中的长度发送至队列1中,完成队列1和队列2之间消息的传递。
本发明实施例提供的队列引用方法,对于现有技术在对队列进行引用时,将目标队列对应的名称等通过Queue进行标注并硬编码目标队列名,从而使得当目标队列名称修改时需要在有可能引用更改后的目标队列的场合,手动修改全部目标队列名称,操作异常繁琐且队列引用效率较低,本发明通过在当前队列中获取待引用队列的类型标识,从而根据该类型标识获得待引用队列所在的队列消息处理器,然后再提取待引用队列并在当前队列中进行引用,因此相比于现有技术,本发明在对队列进行引用时,通过待引用队列的类型标识获取待引用队列,而不是将与待引用队列的标识信息对应的字符串等配置在当前队列中,从而使得当待引用队列名称更改时,并不会影响其他引用了该待引用队列的队列的正常运行,大大简化了操作且提高了队列引用的效率。
进一步的,作为对图1所示实施例的细化及扩展,本发明实施例还提供了另一种队列引用方法,如图2所示。
201、设置与所述当前队列对应的数据类型。
其中,所述与所述当前队列对应的数据类型为标识所述当前队列包含的全部元素需要匹配的数据类型。而所述数据类型为文本类型、数字类型、日期/时间类型等,本发明实施例不做具体限定。具体地,例如可以在当前队列中设置JobRunner<int>,此时则表明在当前队列中使用的数据类型为int。
对于本发明实施例,通过预先在当前队列中设置相应的数据类型,可以实现对当前队列中正常运行的元素数据类型进行预先声明,以使得当获取到数据类型不匹配的元素时能够及时发现并避免进行引用,从而能够及时的发现错误,避免了在运行过程中才发现错误而无法继续运行时造成的资源浪费的问题,进而提高了队列引用的准确性,且节约了资源。
202、检测在所述当前队列中是否存在预置队列引用标识符。
其中,所述预置队列引用标识符用于标识所述当前队列为需要进行队列引用的队列,且所述预置队列引用标识符为一个或多个。而预置队列引用标识符可以为IOutputQueue,从而在队列运行前,可以通过携带有预置队列引用标识符的查询函数等进行检测,但不限于此。
对于本发明实施例,通过在队列运行之前对队列中是否存在预置队列引用标识符进行检测,可以判断该队列中是否需要引用其他队列,以便于根据检测结果采取相应的措施,避免了当队列运行时进行实时检测造成的浪费时间的问题,从而提高了队列引用的效率。
203、依次提取与各个所述预置队列引用标识符分别对应的所述待引用队列的类型标识。
其中,所述待引用队列的类型标识用于标识所述待引用队列所在的队列消息处理器。具体地,本步骤所述的类型标识的概念解释可以参考所述步骤101中相应描述,在此不再赘述。
需要说明的是,当在队列中存在预置队列引用标识符时,表明在出现队列引用标识符处需要进行队列引用,而通常情况下在预置队列引用标识符后会同时存在该处对应的待引用队列的类型标识。例如,在上述步骤中检测得到在当前队列A中存在两个预置队列引用标识符IOutputQueue,并且与两个队列引用标识符同时存在的信息分别为IOutputQueue<int,JobRunner12>和IOutputQueue<int,JobRunner4>,则在本步骤中可以分别提取与这两个预置队列引用标识符分别对应的待引用队列的类型标识,也就是第一处预置队列引用标识符对应的待引用队列的类型标识为JobRunnerl2,第二处预置队列引用标识符对应的待引用队列的类型标识为JobRunner4。
204、根据所述待引用队列的类型标识,提取所述待引用队列。
如所述步骤102中相应描述,在本发明实施例中,可以预先将队列消息处理器存储在预置存储区域,从而在上述步骤203中提取到各个待引用队列的类型标识之后,根据类型标识在预置存储区域中进行查找提取相应的待引用队列。
进一步地,所述步骤204可以包括:根据所述待引用队列对应的类型标识,从预置存储区域中提取与所述类型标识对应的队列消息处理器;从所述队列消息处理器中提取所述待引用队列。其中,所述预置存储区域中保存有全部待引用队列对应的队列消息处理器。例如,在预置存储区域内保存有三个队列消息处理器,分别为JobRunner4、JobRunner7和JobRunner22,在当前队列中获取到待引用队列的类型标识为JobRunner7,此时可以根据该JobRunner7类型标识在预置存储区域中查找,并提取JobRunner7中的队列。
对于本发明实施例,通过预先将队列消息处理器进行统一保存,从而在各个队列需要引用其他队列时可以从同一存储区域进行查找提取,避免了在队列引用时在大量无序的数据中进行查找提取造成的浪费时间和资源的问题,从而提高了队列提取的效率,进而提高了队列引用的效率,且节约了资源。
205、获取与所述待引用队列对应的数据类型。
同样的,本步骤所述的待引用队列的数据类型也可以为文本类型、数字类型、日期/时间类型等,本发明实施例不做具体限定。
在实际应用中,开发人员会针对每个队列开发相对应的队列消息处理器JobRunner,对于本发明实施例,可以创建一个数据库并将全部队列对应的队列消息处理器JobRunner、以及每个队列包含的数据信息均保存在该数据库内,从而使得对于任意一个队列接收到队列引用请求时,可以根据待引用队列的标识信息在数据库中进行查找,并从查询结果中获取待引用队列的数据类型等。
206、检测所述待引用队列对应的数据类型与所述当前队列对应的数据类型是否匹配。
如步骤201中所述,已经预先设定了在执行当前队列任务时匹配的数据类型,从而在获取到待引用队列的元素数据类型之后首先进行检测,以便于根据检测结果采取相应措施,避免了直接进行队列引用而在运行中出现故障造成的浪费时间的问题,从而提高了队列引用的效率。
207a、若所述待引用队列对应的数据类型与所述当前队列对应的数据类型匹配,则在当前队列中引用所述待引用队列。
对于本发明实施例,只有在确保当前队列元素数据类型与待引用队列元素数据类型相匹配时,才在当前队列中对待引用队列进行配置相对应的变量函数,以确保在执行当前队列任务时可以无障碍的引用待引用队列,提高了队列引用的准确性和效率。
与所述步骤207a并列的步骤207b、若所述待引用队列对应的数据类型与所述当前队列对应的数据类型不匹配,则输出提示信息。
其中,所述提示信息可以为文字提示信息、图片提示信息、音频提示信息等,本发明实施例不做具体限定。
对于本发明实施例,通过在当前队列中预先设置匹配的元素数据类型,使得当一旦出现元素数据类型不匹配的待引用队列时,便可及时输出提示消息以提醒开发人员当前编译存在错误,实现了及时提供报错功能以供开发人员根据提示信息进行修正等,进而提高了队列引用的效率。
进一步的,所述方法还可以包括:当所述当前队列生成时,将所述当前队列对应的数据发送至与所述当前队列对应的宿主环境。其中,所述宿主环境中包含有多个不同队列分别对应的数据。需要说明的是,当各个队列消息处理器JobRunner分别构建生成对应的队列后再发送给相应的宿主环境,可以实现在每个JobRunner构建过程中对各自包含的数据进行扫描、修正等,并在确保可顺利执行队列任务后发送给宿主环境,进而使得宿主环境根据接收到的多个JobRunner发送的队列数据进一步处理,避免了由宿主环境进行构建造成的存在错误却无法及时发现,导致的后续纠错浪费时间的问题,从而提高了队列引用的效率。
通过本步骤所述的方法,可以将待引用队列所在的队列消息处理器的类型标识配置在当前队列对应的运行程序中,而不再是一个与待引用队列的字符串等数据,从而当待引用队列名称更改时,并不会影响其他队列对该待引用队列的引用,无需对全部引用场合进行一一修改,提高了队列引用的效率。
进一步的,根据步骤201-207b所述的方法,本发明实施例还可以提供一结合具体的应用场景下引用队列的实施方式,所述实施过程分为四个执行步骤,具体的,如下所述:
第一步、在当前队列M中设置与队列M匹配的元素数据类型为int,且接收在当前队列M中的队列应用请求,根据应用请求中携带的标识信息得知待引用队列为队列N。
第二步、根据待引用队列N的类型标识,在保存有全部队列消息处理器JobRunner、以及每个队列包含的数据信息的数据库中查找,得到待引用队列N的数据类型也就int,并且在数据库中配置数据表,当数据库中的队列名称修改时,将修改情况保存在该数据表中。
第三步、检测得到待引用队列N和当前队列M的数据类型匹配,从而在当前队列中配置与待引用队列N对应的变量函数IOutputQueue<int,JobRunnerN>。
第四步、执行当前队列M对应的任务,在此过程中当运行到配置的与待引用队列N对应的IOutputQueue<int,JobRunnerN>时,触发对待引用队列进行引用,实现当前队列M与待引用队列N之间的消息传递。
但需要说明的是,上述应用场景所述的具体实施方式仅仅是示例性的,并非本发明实施例的唯一具体实施方式,在此仅为符合本发明所述的方法的优化实施方式之一。
进一步的,作为对上述图1所示方法的实现,本发明实施例还提供了一种队列引用装置,用于对上述图1所示的方法进行实现。该装置实施例与前述方法实施例对应,为便于阅读,本装置实施例不再对前述方法实施例中的细节内容进行逐一赘述,但应当明确,本实施例中的装置能够对应实现前述方法实施例中的全部内容。如图3所示,该装置包括:获取单元31、提取单元32、引用单元33,其中
获取单元31,可以用于获取待引用队列的类型标识,所述待引用队列的类型标识用于标识所述待引用队列所在的队列消息处理器。
提取单元32,可以用于根据所述获取单元31获取到的待引用队列的类型标识,提取所述待引用队列。
引用单元33,可以用于在当前队列中引用所述提取单元32提取到的待引用队列,所述当前队列为当前运行的任务消息所在的队列。
进一步的,作为对上述图2所示方法的实现,本发明实施例还提供了另一种队列引用装置,用于对上述图2所示的方法进行实现。该装置实施例与前述方法实施例对应,为便于阅读,本装置实施例不再对前述方法实施例中的细节内容进行逐一赘述,但应当明确,本实施例中的装置能够对应实现前述方法实施例中的全部内容。如图4所示,该装置包括:获取单元41、提取单元42、引用单元43,其中
获取单元41,可以用于获取待引用队列的类型标识,所述待引用队列的类型标识用于标识所述待引用队列所在的队列消息处理器。
提取单元42,可以用于根据所述获取单元41获取到的待引用队列的类型标识,提取所述待引用队列。
引用单元43,可以用于在当前队列中引用所述提取单元42提取到的待引用队列,所述当前队列为当前运行的任务消息所在的队列。
进一步的,所述装置还包括:
设置单元44,可以用于设置与所述当前队列对应的数据类型。
检测单元45,可以用于检测在所述当前队列中是否存在预置队列引用标识符,所述预置队列引用标识符用于标识所述当前队列为需要进行队列引用的队列,且所述预置队列引用标识符为一个或多个。
进一步的,
所述提取单元42,具体可以用于依次提取与各个所述预置队列引用标识符分别对应的所述带引用队列的类型标识。
所述提取单元42,还可以用于根据所述待引用队列的类型标识,提取所述待引用队列。
进一步的,所述提取单元42包括:
第一提取模块4201,可以用于根据所述待引用队列对应的类型标识,从预置存储区域中提取与所述类型标识对应的队列消息处理器。
第二提取模块4202,可以用于从所述队列消息处理器中提取所述待引用队列。
进一步的,所述装置还包括:输出单元46。
所述获取单元41,还可以用于获取与所述待引用队列对应的数据类型。
所述检测单元45,还可以用于检测所述待引用队列对应的数据类型与所述当前队列对应的数据类型是否匹配。
所述引用单元43,具体可以用于若所述待引用队列对应的数据类型与所述当前队列对应的数据类型匹配,则在当前队列中引用所述待引用队列。
所述输出单元46,可以用于若所述待引用队列对应的数据类型与所述当前队列对应的数据类型不匹配,则输出提示信息。
本发明实施例提供的另一种队列引用装置。所述装置包括:获取单元、提取单元及引用单元。对于现有技术在对队列进行引用时,将目标队列对应的名称等通过Queue进行标注并硬编码目标队列名,从而使得当目标队列名称修改时需要在有可能引用更改后的目标队列的场合,手动修改全部目标队列名称,操作异常繁琐且队列引用效率较低,本发明通过在当前队列中获取待引用队列的类型标识,从而根据该类型标识获得待引用队列所在的队列消息处理器,然后再提取待引用队列并在当前队列中进行引用,因此相比于现有技术,本发明在对队列进行引用时,通过待引用队列的类型标识获取待引用队列,而不是将与待引用队列的标识信息对应的字符串等配置在当前队列中,从而使得当待引用队列名称更改时,并不会影响其他引用了该待引用队列的队列的正常运行,大大简化了操作且提高了队列引用的效率;此外,根据本发明的方法在对队列引用之前即可检测待引用队列的元素数据类型与当前队列的元素数据类型是否匹配,从而能够在确保待引用队列与当前队列元素数据类型匹配的情况下,对队列进行引用,避免了在实际运行过程中才发现不匹配而造成的时间和资源浪费的问题,从而提高了队列引用的效率,且节约了资源。
所述文本处理装置包括处理器和存储器,上述获取单元31、提取单元32、引用单元33等均作为程序单元存储在存储器中,由处理器执行存储在存储器中的上述程序单元来实现相应的功能。
处理器中包含内核,由内核去存储器中调取相应的程序单元。内核可以设置一个或以上,通过调整内核参数来提高队列引用的效率。
存储器可能包括计算机可读介质中的非永久性存储器,随机存取存储器(RAM)和/或非易失性内存等形式,如只读存储器(ROM)或闪存(flash RAM),存储器包括至少一个存储芯片。
本发明实施例提供了一种存储介质,其上存储有程序,该程序被处理器执行时实现所述队列引用方法。
本发明实施例提供了一种处理器,所述处理器用于运行程序,其中,所述程序运行时执行所述队列引用方法。
本发明实施例提供了一种设备,设备包括处理器、存储器及存储在存储器上并可在处理器上运行的程序,处理器执行程序时实现以下步骤:获取待引用队列的类型标识;根据所述待引用队列的类型标识,提取所述待引用队列;在当前队列中引用所述待引用队列。
进一步的,所述获取待引用队列对应的类型标识之前,所述方法还包括:
检测在所述当前队列中是否存在预置队列引用标识符,所述预置队列引用标识符用于标识所述当前队列为需要进行队列引用的队列,且所述预置队列引用标识符为一个或多个;
所述获取待引用队列对应的类型标识包括:
若是,则依次提取与各个所述预置队列引用标识符分别对应的所述带引用队列的类型标识。
进一步的,所述根据所述待引用队列的类型标识,提取所述待引用队列包括:
根据所述待引用队列对应的类型标识,从预置存储区域中提取与所述类型标识对应的队列消息处理器,所述预置存储区域中保存有全部待引用队列对应的队列消息处理器;
从所述队列消息处理器中提取所述待引用队列。
进一步的,所述方法还包括:
设置与所述当前队列对应的数据类型,所述与所述当前队列对应的数据类型为标识所述当前队列包含的全部元素需要匹配的数据类型。
进一步的,在当前队列中引用所述待引用队列之前,所述方法还包括:
获取与所述待引用队列对应的数据类型;
检测所述待引用队列对应的数据类型与所述当前队列对应的数据类型是否匹配;
若匹配,则进入在当前队列中引用所述待引用队列的步骤。
进一步的,所述方法还包括:
若所述待引用队列对应的数据类型与所述当前队列对应的数据类型不匹配,则输出提示信息。
本发明实施例中的设备可以是服务器、PC、PAD、手机等。
本发明实施例还提供了一种计算机程序产品,当在数据处理设备上执行时,适于执行初始化有如下方法步骤的程序:获取待引用队列的类型标识;根据所述待引用队列的类型标识,提取所述待引用队列;在当前队列中引用所述待引用队列。
进一步的,所述获取待引用队列对应的类型标识之前,所述方法还包括:
检测在所述当前队列中是否存在预置队列引用标识符,所述预置队列引用标识符用于标识所述当前队列为需要进行队列引用的队列,且所述预置队列引用标识符为一个或多个;
所述获取待引用队列对应的类型标识包括:
若是,则依次提取与各个所述预置队列引用标识符分别对应的所述带引用队列的类型标识。
进一步的,所述根据所述待引用队列的类型标识,提取所述待引用队列包括:
根据所述待引用队列对应的类型标识,从预置存储区域中提取与所述类型标识对应的队列消息处理器,所述预置存储区域中保存有全部待引用队列对应的队列消息处理器;
从所述队列消息处理器中提取所述待引用队列。
进一步的,所述方法还包括:
设置与所述当前队列对应的数据类型,所述与所述当前队列对应的数据类型为标识所述当前队列包含的全部元素需要匹配的数据类型。
进一步的,在当前队列中引用所述待引用队列之前,所述方法还包括:
获取与所述待引用队列对应的数据类型;
检测所述待引用队列对应的数据类型与所述当前队列对应的数据类型是否匹配;
若匹配,则进入在当前队列中引用所述待引用队列的步骤。
进一步的,所述方法还包括:
若所述待引用队列对应的数据类型与所述当前队列对应的数据类型不匹配,则输出提示信息。
本领域内的技术人员应明白,本申请的实施例可提供为方法、系统、或计算机程序产品。因此,本申请可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本申请可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本申请是参照根据本申请实施例的方法、设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
在一个典型的配置中,计算设备包括一个或多个处理器(CPU)、输入/输出接口、网络接口和内存。
存储器可能包括计算机可读介质中的非永久性存储器,随机存取存储器(RAM)和/或非易失性内存等形式,如只读存储器(ROM)或闪存(flashRAM)。存储器是计算机可读介质的示例。
计算机可读介质包括永久性和非永久性、可移动和非可移动媒体可以由任何方法或技术来实现信息存储。信息可以是计算机可读指令、数据结构、程序的模块或其他数据。计算机的存储介质的例子包括,但不限于相变内存(PRAM)、静态随机存取存储器(SRAM)、动态随机存取存储器(DRAM)、其他类型的随机存取存储器(RAM)、只读存储器(ROM)、电可擦除可编程只读存储器(EEPROM)、快闪记忆体或其他内存技术、只读光盘只读存储器(CD-ROM)、数字多功能光盘(DVD)或其他光学存储、磁盒式磁带,磁带磁磁盘存储或其他磁性存储设备或任何其他非传输介质,可用于存储可以被计算设备访问的信息。按照本文中的界定,计算机可读介质不包括暂存电脑可读媒体(transitory media),如调制的数据信号和载波。
还需要说明的是,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、商品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、商品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个......”限定的要素,并不排除在包括要素的过程、方法、商品或者设备中还存在另外的相同要素。
本领域技术人员应明白,本申请的实施例可提供为方法、系统或计算机程序产品。因此,本申请可采用完全硬件实施例、完全软件实施例或结合软件和硬件方面的实施例的形式。而且,本申请可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
以上仅为本申请的实施例而已,并不用于限制本申请。对于本领域技术人员来说,本申请可以有各种更改和变化。凡在本申请的精神和原理之内所作的任何修改、等同替换、改进等,均应包含在本申请的权利要求范围之内。

Claims (10)

1.一种队列引用方法,其特征在于,所述方法包括:
获取待引用队列的类型标识,所述待引用队列的类型标识用于标识所述待引用队列所在的队列消息处理器;
根据所述待引用队列的类型标识,提取所述待引用队列;
在当前队列中引用所述待引用队列,所述当前队列为当前运行的任务消息所在的队列。
2.根据权利要求1所述的方法,其特征在于,所述获取待引用队列对应的类型标识之前,所述方法还包括:
检测在所述当前队列中是否存在预置队列引用标识符,所述预置队列引用标识符用于标识所述当前队列为需要进行队列引用的队列,且所述预置队列引用标识符为一个或多个;
所述获取待引用队列对应的类型标识包括:
若在所述当前队列中存在预置队列引用标识符,则依次提取与各个所述预置队列引用标识符分别对应的所述待引用队列的类型标识。
3.根据权利要求1所述的方法,其特征在于,所述根据所述待引用队列的类型标识,提取所述待引用队列包括:
根据所述待引用队列对应的类型标识,从预置存储区域中提取与所述类型标识对应的队列消息处理器,所述预置存储区域中保存有全部待引用队列对应的队列消息处理器;
从所述队列消息处理器中提取所述待引用队列。
4.根据权利要求1所述的方法,其特征在于,所述方法还包括:
设置与所述当前队列对应的数据类型,所述与所述当前队列对应的数据类型为标识所述当前队列包含的全部元素需要匹配的数据类型。
5.根据权利要求4所述的方法,其特征在于,在当前队列中引用所述待引用队列之前,所述方法还包括:
获取与所述待引用队列对应的数据类型;
检测所述待引用队列对应的数据类型与所述当前队列对应的数据类型是否匹配;
若匹配,则进入在当前队列中引用所述待引用队列的步骤。
6.根据权利要求5所述的方法,其特征在于,所述方法还包括:
若所述待引用队列对应的数据类型与所述当前队列对应的数据类型不匹配,则输出提示信息。
7.一种队列引用装置,其特征在于,所述装置包括:
获取单元,用于获取待引用队列的类型标识,所述待引用队列的类型标识用于标识所述待引用队列所在的队列消息处理器;
提取单元,用于根据所述待引用队列的类型标识,提取所述待引用队列:
引用单元,用于在当前队列中引用所述待引用队列,所述当前队列为当前运行的任务消息所在的队列。
8.根据权利要求7所述的装置,其特征在于,所述装置还包括:检测单元,
所述检测单元,用于检测在所述当前队列中是否存在预置队列引用标识符,所述预置队列引用标识符用于标识所述当前队列为需要进行队列引用的队列,且所述预置队列引用标识符为一个或多个:
所述提取单元,具体用于若在所述当前队列中存在预置队列引用标识符,则依次提取与各个所述预置队列引用标识符分别对应的所述带引用队列的类型标识。
9.一种存储介质,其特征在于,所述存储介质包括存储的程序,其中,在所述程序运行时控制所述存储介质所在设备执行权利要求1至权利要求6中任意一项所述的队列引用方法。
10.一种处理器,其特征在于,所述处理器用于运行程序,其中,所述程序运行时执行权利要求1至权利要求6中任意一项所述的队列引用方法。
CN201711415068.6A 2017-12-22 2017-12-22 一种队列引用方法及装置 Pending CN109960595A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201711415068.6A CN109960595A (zh) 2017-12-22 2017-12-22 一种队列引用方法及装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201711415068.6A CN109960595A (zh) 2017-12-22 2017-12-22 一种队列引用方法及装置

Publications (1)

Publication Number Publication Date
CN109960595A true CN109960595A (zh) 2019-07-02

Family

ID=67020439

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201711415068.6A Pending CN109960595A (zh) 2017-12-22 2017-12-22 一种队列引用方法及装置

Country Status (1)

Country Link
CN (1) CN109960595A (zh)

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101470623A (zh) * 2007-12-26 2009-07-01 无锡江南计算技术研究所 队列管理方法和队列管理器、队列消息的处理方法和系统
US20120147021A1 (en) * 2010-12-13 2012-06-14 Advanced Micro Devices, Inc. Graphics compute process scheduling
CN106375835A (zh) * 2016-08-31 2017-02-01 北京奇艺世纪科技有限公司 一种流媒体播放方法及设备
CN106657284A (zh) * 2016-11-29 2017-05-10 成都华为技术有限公司 数据流处理的方法和装置
CN106933664A (zh) * 2017-03-09 2017-07-07 北京搜狐新媒体信息技术有限公司 一种Hadoop集群的资源调度方法及装置

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101470623A (zh) * 2007-12-26 2009-07-01 无锡江南计算技术研究所 队列管理方法和队列管理器、队列消息的处理方法和系统
US20120147021A1 (en) * 2010-12-13 2012-06-14 Advanced Micro Devices, Inc. Graphics compute process scheduling
CN106375835A (zh) * 2016-08-31 2017-02-01 北京奇艺世纪科技有限公司 一种流媒体播放方法及设备
CN106657284A (zh) * 2016-11-29 2017-05-10 成都华为技术有限公司 数据流处理的方法和装置
CN106933664A (zh) * 2017-03-09 2017-07-07 北京搜狐新媒体信息技术有限公司 一种Hadoop集群的资源调度方法及装置

Similar Documents

Publication Publication Date Title
KR102537275B1 (ko) 구조화된 사용자 데이터 파일에서의 사용자 콘텐츠의 난독화
CN112368691A (zh) 用于文件共享的技术
CN109002443B (zh) 一种文本信息的分类方法及装置
CN101414301B (zh) 处理内容管理系统内的储存库中的对象的装置和方法
US9703763B1 (en) Automatic document citations by utilizing copied content for candidate sources
CN108920656A (zh) 文档属性描述内容提取方法和装置
CN107357929A (zh) 文件读取方法、移动终端及可读存储介质
CN106649210B (zh) 一种数据转换方法及装置
CN112860777A (zh) 数据处理方法、装置及设备
CN106970758B (zh) 电子文档操作处理方法、装置和电子设备
CN110457182A (zh) 一种负载均衡集群实例运行指标监控系统
CN112839055B (zh) 面向tls加密流量的网络应用识别方法、装置及电子设备
CN108153731B (zh) 生僻字处理方法、计算设备及计算机存储介质
US20180019934A1 (en) Assuring Data Correctness in Non-Stable Network Environment
CN104268191B (zh) 单据显示方法和单据显示装置
CN108280355A (zh) 一种数据脱敏方法及装置
CN109960595A (zh) 一种队列引用方法及装置
Singh Impact of technology in library services
US20170249356A1 (en) Query response using mapping to parameterized report
CN109977317A (zh) 数据查询方法及装置
CN110232155A (zh) 浏览器界面的信息推荐方法及电子设备
CN110019295B (zh) 数据库检索方法、装置、系统以及存储介质
CN106658082B (zh) 一种动态更新数据的方法及装置
US20180278472A1 (en) System and method for performing mass renaming of list of items at run-time with variable differentiation factor
CN105786478A (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: 100083 No. 401, 4th Floor, Haitai Building, 229 North Fourth Ring Road, Haidian District, Beijing

Applicant after: Beijing Guoshuang Technology Co.,Ltd.

Address before: 100086 Beijing city Haidian District Shuangyushu Area No. 76 Zhichun Road cuigongfandian 8 layer A

Applicant before: Beijing Guoshuang Technology Co.,Ltd.

RJ01 Rejection of invention patent application after publication
RJ01 Rejection of invention patent application after publication

Application publication date: 20190702