CN107220033A - 用于控制线程池中线程数量的方法和装置 - Google Patents

用于控制线程池中线程数量的方法和装置 Download PDF

Info

Publication number
CN107220033A
CN107220033A CN201710542258.8A CN201710542258A CN107220033A CN 107220033 A CN107220033 A CN 107220033A CN 201710542258 A CN201710542258 A CN 201710542258A CN 107220033 A CN107220033 A CN 107220033A
Authority
CN
China
Prior art keywords
thread
thread pool
pool
maximum concurrent
task
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
CN201710542258.8A
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 Baidu Netcom Science and Technology Co Ltd
Shanghai Xiaodu Technology Co Ltd
Original Assignee
Beijing Baidu Netcom Science and 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 Baidu Netcom Science and Technology Co Ltd filed Critical Beijing Baidu Netcom Science and Technology Co Ltd
Priority to CN201710542258.8A priority Critical patent/CN107220033A/zh
Publication of CN107220033A publication Critical patent/CN107220033A/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/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/38Concurrent instruction execution, e.g. pipeline or look ahead
    • G06F9/3836Instruction issuing, e.g. dynamic instruction scheduling or out of order instruction execution
    • G06F9/3851Instruction issuing, e.g. dynamic instruction scheduling or out of order instruction execution from multiple instruction streams, e.g. multistreaming
    • 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/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30003Arrangements for executing specific machine instructions
    • G06F9/30076Arrangements for executing specific machine instructions to perform miscellaneous control operations, e.g. NOP
    • G06F9/3009Thread control instructions

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Multimedia (AREA)
  • User Interface Of Digital Computer (AREA)

Abstract

本申请公开了用于控制线程池中线程数量的方法和装置。该方法的一具体实施方式包括:获取线程池的任务队列中待处理任务的数量;响应于待处理任务的数量大于第一预定数量且线程池所在系统的CPU使用率小于预定阈值,根据预定规则增大线程池的最大并发线程数;根据增大后的最大并发线程数创建线程。该实施方式提高了线程池的运行效率。

Description

用于控制线程池中线程数量的方法和装置
技术领域
本申请涉及计算机技术领域,尤其涉及用于控制线程池中线程数量的方法和装置。
背景技术
在多进程/多线程的操作系统中,一般将耗时的操作交由一个单独的线程去处理,一方面是为了避免阻塞主线程,不影响用户的正常交互操作,另一方面是为了提高CPU的利用率,提高任务执行的速度。但如果有多个需要处理的耗时任务,同时创建了多个线程,系统CPU的占用率就会很高,这样会导致每个线程处理都很慢,此外,还可能导致设备/系统耗电量增加,因此,需要创建一个线程池(ThreadPool)去控制这些线程,即对创建的线程的数量有所控制。
线程池是一种多线程处理形式,处理过程中可以通过线程池分配器(ThreadPoolDispatcher)将待处理任务添加到任务队列,然后在创建线程后自动启动任务队列中的待处理任务。线程池创建后,可以通过最大并发线程数的设置来控制线程的数量,比如设置一个线程池的最大并发线程数是3,那么这个线程池中最多可以创建3个线程去处理任务。
现有技术中,线程池创建后,设定的最大并发线程数固定不变。然而,由于任务队列中待处理任务的数量是变化的,所以最大并发线程数固定,可能导致任务队列中待处理任务的数量过多,待处理任务不能及时被执行。
发明内容
本申请的目的在于提出一种改进的用于控制线程池中线程数量的方法和装置,来解决以上背景技术部分提到的技术问题。
第一方面,本申请提供了一种用于控制线程池中线程数量的方法,该方法包括:获取线程池的任务队列中待处理任务的数量;响应于待处理任务的数量大于第一预定数量且线程池所在系统的CPU使用率小于预定阈值,根据预定规则增大线程池的最大并发线程数;根据增大后的最大并发线程数创建线程。
在一些实施例中,方法还包括:响应于待处理任务的数量小于第二预定数量或线程池中存在空闲时长超过预定时长的线程,根据预设规则减少线程池的最大并发线程数,其中,第二预定数量小于第一预定数量;根据减少后的最大并发线程数销毁线程。
在一些实施例中,根据预定规则增大线程池的最大并发线程数,包括以下任意一项:将线程池的最大并发线程数增大至线程池的初始最大并发线程数与线程池当前最大并发线程数之和;根据预定时间段内待处理任务增加的数量,确定线程池的最大并发线程数的增加量,将线程池的最大并发线程数增大至增加量与线程池当前最大并发线程数之和。
在一些实施例中,根据预设规则减少线程池的最大并发线程数,包括以下任意一项:确定线程池中空闲时长超过预定时长的线程的数量,将线程池的最大并发线程数减少至线程池当前最大并发线程数与确定的数量之差;根据预定时间段内待处理任务减少的数量,确定线程池的最大并发线程数的减少量,将线程池的最大并发线程数减少至线程池当前最大并发线程数与减少量之差。
在一些实施例中,获取线程池的任务队列中待处理任务的数量,包括以下任意一项:每隔预设时间段获取线程池的任务队列中待处理任务的数量;响应于预设时长内没有待处理任务加入任务队列,获取任务队列中待处理任务的数量;响应于预置时长内加入任务队列中的待处理任务的数量超过预定数量阈值,获取任务队列中待处理任务的数量。
第二方面,本申请提供了一种用于控制线程池中线程数量的装置,该装置包括:获取单元,用于获取线程池的任务队列中待处理任务的数量;增大单元,用于响应于待处理任务的数量大于第一预定数量且线程池所在系统的CPU使用率小于预定阈值,根据预定规则增大线程池的最大并发线程数;创建单元,用于根据增大后的最大并发线程数创建线程。
在一些实施例中,装置还包括:减少单元,用于响应于待处理任务的数量小于第二预定数量或线程池中存在空闲时长超过预定时长的线程,根据预设规则减少线程池的最大并发线程数,其中,第二预定数量小于第一预定数量;销毁单元,用于根据减少后的最大并发线程数销毁线程。
在一些实施例中,增大单元,进一步配置用于:将线程池的最大并发线程数增大至线程池的初始最大并发线程数与线程池当前最大并发线程数之和;或根据预定时间段内待处理任务增加的数量,确定线程池的最大并发线程数的增加量,将线程池的最大并发线程数增大至增加量与线程池当前最大并发线程数之和。
在一些实施例中,减少单元,进一步配置用于:确定线程池中空闲时长超过预定时长的线程的数量,将线程池的最大并发线程数减少至线程池当前最大并发线程数与确定的数量之差;或根据预定时间段内待处理任务减少的数量,确定线程池的最大并发线程数的减少量,将线程池的最大并发线程数减少至线程池当前最大并发线程数与减少量之差。
在一些实施例中,获取单元,进一步配置用于:每隔预设时间段获取线程池的任务队列中待处理任务的数量;或响应于预设时长内没有待处理任务加入任务队列,获取任务队列中待处理任务的数量;或响应于预置时长内加入任务队列中的待处理任务的数量超过预定数量阈值,获取任务队列中待处理任务的数量。
第三方面,本申请提供了一种设备,包括:一个或多个处理器;存储装置,用于存储一个或多个程序,当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如第一方面所述的方法。
第四方面,本申请提供了一种计算机可读存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现如第一方面所述的方法。
本申请提供的用于控制线程池中线程数量的方法和装置,通过获取线程池的任务队列中待处理任务的数量,而后响应于待处理任务的数量大于第一预定数量且线程池所在系统的CPU使用率小于预定阈值,根据预定规则增大线程池的最大并发线程数,最后根据增大后的最大并发线程数创建线程,在同一时间可以处理更多的任务,因此提高了线程池的运行效率。
附图说明
通过阅读参照以下附图所作的对非限制性实施例所作的详细描述,本申请的其它特征、目的和优点将会变得更明显:
图1是本申请可以应用于其中的示例性系统架构图;
图2是根据本申请的用于控制线程池中线程数量的方法的一个实施例的示意性流程图;
图3是根据本申请的用于控制线程池中线程数量的方法的应用场景的示意图;
图4是根据本申请的用于控制线程池中线程数量的方法的又一个实施例的示意性流程图;
图5是根据本申请的用于控制线程池中线程数量的装置的一个实施例的示例性结构图;
图6是适于用来实现本申请实施例的终端设备或服务器的计算机系统的结构示意图。
具体实施方式
下面结合附图和实施例对本申请作进一步的详细说明。可以理解的是,此处所描述的具体实施例仅仅用于解释相关发明,而非对该发明的限定。另外还需要说明的是,为了便于描述,附图中仅示出了与有关发明相关的部分。
需要说明的是,在不冲突的情况下,本申请中的实施例及实施例中的特征可以相互组合。下面将参考附图并结合实施例来详细说明本申请。
图1示出了可以应用本申请的用于控制线程池中线程数量的方法或用于控制线程池中线程数量的装置的实施例的示例性系统架构100。
如图1所示,系统架构100可以包括终端设备101、102、103,网络104和服务器105、106。网络104用以在终端设备101、102、103和服务器105、106之间提供通信链路的介质。网络104可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
用户110可以使用终端设备101、102、103通过网络104与服务器105、106交互,以接收或发送数据等。终端设备101、102、103上可以安装有各种应用,例如社交类应用、网页浏览器应用、搜索引擎类应用、购物类应用、即时通信工具、手机助手类应用等。
终端设备101、102、103可以是各种电子设备,包括但不限于智能手机、平板电脑、电子书阅读器、MP3播放器(Moving Picture Experts Group Audio Layer III,动态影像专家压缩标准音频层面3)、MP4(Moving Picture Experts Group Audio Layer IV,动态影像专家压缩标准音频层面4)播放器、膝上型便携计算机和台式计算机等等。
服务器105、106可以是提供各种服务的服务器,例如对终端设备101、102、103上所安装的应用提供支持的后台服务器。后台服务器可以接收终端设备的请求并根据请求进行数据处理,并将处理结果反馈给终端设备。
本申请实施例所提供的用于控制线程池中线程数量的方法可以由服务器105、106执行,也可以由终端设备101、102、103执行,相应地,用于控制线程池中线程数量的装置可以设置于服务器105、106中,也可以设置于终端设备101、102、103中。
当用于控制线程池中线程数量的方法由服务器105、106在使用线程池时,可以由服务器105、106获取线程池的任务队列中待处理任务的数量,而后响应于待处理任务的数量大于第一预定数量且线程池所在系统的CPU使用率小于预定阈值,根据预定规则增大线程池的最大并发线程数,最后根据增大后的最大并发线程数创建线程。
当用于控制线程池中线程数量的方法由终端设备101、102、103执行时,可以由终端设备101、102、103获取线程池的任务队列中待处理任务的数量,而后响应于待处理任务的数量大于第一预定数量且线程池所在系统的CPU使用率小于预定阈值,根据预定规则增大线程池的最大并发线程数,最后根据增大后的最大并发线程数创建线程。
应该理解,图1中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。
继续参考图2,示出了根据本申请的用于控制线程池中线程数量的方法的一个实施例的流程200。该用于控制线程池中线程数量的方法,包括以下步骤:
步骤201,获取线程池的任务队列中待处理任务的数量。
在本实施例中,用于控制线程池中线程数量的方法运行于其上的电子设备(例如图1所示的终端或服务器),首先可以获取线程池的任务队列中待处理任务的数量。在线程池中,操作会被抽象封装成任务(Task),新生成的任务会被分发到任务队列,而后由任务队列交给工作线程进行处理。线程池根据情况,最多创建最大并发数个子线程去处理这些待处理任务。如果任务队列中的待处理任务的数量大于线程最大并发数,那么队列中一部分待处理任务就会长时间处于等待状态。当有任务被处理完成时,等待状态的待处理任务才会交由线程池中的工作线程执行。此外,任务队列中待处理任务可以关联有优先级信息,可以根据优先级信息,优先执行高优先级的待处理任务。
在本实施例的一些可选实现方式中,获取线程池的任务队列中待处理任务的数量,包括:每隔预设时间段获取线程池的任务队列中待处理任务的数量。
在本实现方式中,预设时间段可以根据实际需要设置,例如,对于接受到的数据处理请求的数量较为稳定的服务器,预设时间段可以较长,对于接受到的数据处理请求的数量波动较大的服务器,预设时间段可以较短。对于不同时间段也可以设置不同的预设时间段,例如,对于终端设备,用户开启应用后的一段时间内,线程池的任务队列中待处理任务的数量会增加的较快,此时预设时间段可以较短,应用平稳运行时,预设时间段可以较长。每隔预设时间段获取线程池的任务队列中待处理任务的数量,可以根据实时的获取的数量控制线程池中的线程的数量,进一步提高了线程池的运行效率。
在本实施例的一些可选实现方式中,获取线程池的任务队列中待处理任务的数量,包括:响应于预设时长内没有待处理任务加入任务队列,或预置时长内加入任务队列中的待处理任务的数量超过预定数量阈值,获取任务队列中待处理任务的数量。
在本实现方式中,可以监控线程池分配器的任务分配情况,以此仅在待处理任务的数量波动较大的情况下,获取任务队列中待处理任务的数量,避免了不必要的操作,进一步提高了线程池的运行效率。
步骤202,响应于待处理任务的数量大于第一预定数量且线程池所在系统的CPU使用率小于预定阈值,根据预定规则增大线程池的最大并发线程数。
在本实施例中,上述电子设备可以响应于步骤201中获取的待处理任务的数量大于第一预定数量且线程池所在系统的CPU使用率小于预定阈值,根据预定规则增大线程池的最大并发线程数。最大并发线程数是指线程池中并发线程数量的上限值。第一预定数量可以是一个固定的数值,也可以根据当前的最大并发数确定,例如,可以是预定倍数的当前最大并发线程数。预定倍数可以是一个固定的数值,也可以根据线程池创建时设置的初始的最大并发线程数确定。作为示例,第一预定数量可以是3倍的初始的最大并发线程数与当前的最大并发数之积。
在本实施例中,如果任务队列中的待处理任务的数量过多,大量的待处理任务就会处于等待状态。影响了线程池的运行效率,所以需要增大线程池的最大并发线程数。但是,考虑到当前系统的CPU占用情况,所以不能无限制地增大最大并发线程数。增大线程池的最大并发线程数的预定规则可以根据实际需要设置,例如,增大的个数可以是待处理任务数量的1/20~1/5,对于任务量可能存在激增的情况,且性能较好的设备,可以成倍的增加最大并发数,对于任务量不存在激增的情况的设备,可以按照固定梯度增加最大并发线程数,例如,线程池的最大并发线程数一次可以增大1~5个。
在本实施例的一些可选实现方式中,根据预定规则增大线程池的最大并发线程数,包括:将线程池的最大并发线程数增大至线程池的初始最大并发线程数与线程池当前最大并发线程数之和。
在本实现方式中,将线程池的最大并发线程数增大至线程池的初始最大并发线程数与线程池当前最大并发线程数之和,可以是将最大并发线程数增大至线程池的初始最大并发线程数的n倍,例如,线程池当前最大并发线程数是初始最大并发线程数的2倍,可以将最大并发线程数增大至线程池的初始最大并发线程数的3倍。由于初始最大并发线程数是根据系统任务量的情况设置的,所以依据初始最大并发线程数增大最大并发线程数更加合理。
在本实施例的一些可选实现方式中,根据预定规则增大线程池的最大并发线程数,包括:根据预定时间段内待处理任务增加的数量,确定线程池的最大并发线程数的增加量;将线程池的最大并发线程数增大至增加量与线程池当前最大并发线程数之和。
在本实现方式中,预定时间段可以根据实际情况设置,例如,可以是单个任务的平均处理时间。可以根据机器学习方法确定出预定时间段内待处理任务增加的数量,与增加量之间最优的比例关系,例如,确定出的线程池的最大并发线程数的增加量,为预定时间段内待处理任务增加的数量的0.5~1倍。根据预定时间段内待处理任务增加的数量,确定出的线程池的最大并发线程数的增加量更加合理,进一步提高了线程池的运行效率。
步骤203,根据增大后的最大并发线程数创建线程。
在本实施例中,上述电子设备可以根据步骤202中增大后的最大并发线程数创建线程,创建的线程的数量可以为增大后的最大并发线程数与线程池当前的最大并发线程数之差,在线程池中线程的总数不超过增大后的最大并发线程数的情况下,可以由线程池根据实际情况进行线程的创建。
继续参考图3,其示出了根据本申请的用于控制线程池中线程数量的方法的应用场景的示意图。在图3的应用场景中,线程池初始的最大并发线程数为4,线程池分发管理器301可以将待处理任务分发到任务队列302中,工作线程集合303中的4个工作线程可以处理任务队列302中的待处理任务。首先获取到线程池的任务队列302中待处理任务的数量304为49个,而后响应于其大于第一预定数量48,且线程池所在系统的CPU使用率为30%,小于预定阈值70%,根据预定规则,将线程池的最大并发线程数305增大至初始的最大并发线程数的两倍,即将线程池的最大并发线程数305增大至8个,最后根据最大并发线程数305创建线程,工作线程集合303中创建的工作线程的数量不能超过8个。
本申请的上述实施例提供的方法通过获取线程池的任务队列中待处理任务的数量;响应于待处理任务的数量大于第一预定数量且线程池所在系统的CPU使用率小于预定阈值,根据预定规则增大线程池的最大并发线程数;根据增大后的最大并发线程数创建线程,较于现有线程池的设计,实现了对于线程池中线程最大并发数的自适应的控制,提高了线程池的运行效率。
请参考图4,图4是根据本实施例的用于控制线程池中线程数量的方法的又一个实施例的流程示意图。
在图4中,该用于控制线程池中线程数量的方法400,包括以下步骤:
步骤401,获取线程池的任务队列中待处理任务的数量。
在本实施例中,上述电子设备首先可以获取线程池的任务队列中待处理任务的数量。
步骤402,响应于待处理任务的数量大于第一预定数量且线程池所在系统的CPU使用率小于预定阈值,根据预定规则增大线程池的最大并发线程数。
在本实施例中,上述电子设备可以响应于步骤401中获取的待处理任务的数量大于第一预定数量且线程池所在系统的CPU使用率小于预定阈值,根据预定规则增大线程池的最大并发线程数。
步骤403,根据增大后的最大并发线程数创建线程。
在本实施例中,上述电子设备可以在步骤402增大线程池的最大并发线程数后,创建线程,创建的线程的数量为步骤402中增大后的最大并发线程数与线程池当前的最大并发线程数之差。
步骤404,响应于待处理任务的数量小于第二预定数量或线程池中存在空闲时长超过预定时长的线程,根据预设规则减少线程池的最大并发线程数。
在本实施例中,上述电子设备可以响应于步骤401中获取的待处理任务的数量小于第二预定数量或线程池中存在空闲时长超过预定时长的线程,根据预设规则减少线程池的最大并发线程数。第二预定数量小于第一预定数量。第二预定数量与第一预定数量构成了一个合理的待处理任务的数量的范围,在此范围内线程池的运行效率较高。任务队列中开始可能有大量待处理任务,导致线程池增大了最大并发线程数,创建了较多的线程。后期当待处理任务变少,如果之前创建的线程不能适时的销毁,就会导致线程处于空闲状态,浪费CPU资源,因此需要减少最大并发线程数。
在本实施例的一些可选实现方式中,根据预设规则减少线程池的最大并发线程数,包括:确定线程池中空闲时长超过预定时长的线程的数量;将线程池的最大并发线程数减少至线程池当前最大并发线程数与确定的数量之差。
在本实现方式中,空闲时长是指线程持续处于空闲状态的时长。预定时长可以根据实际需要设置,例如,可以是600秒。上述电子设备可以主动通知线程池销毁空闲时长超过600秒的线程,而后确定销毁的线程的数量,并将最大并发线程数减少该数量,也可以先确定待销毁的线程的数量,将最大并发线程数减少该数量,使得线程池自动根据减少后的最大并发线程数销毁线程。通过线程的空闲时长可以快速确定出线程池中任务是否饱和,以此进行最大并发线程数的调节,进一步提高了线程池的运行效率。
在本实施例的一些可选实现方式中,根据预设规则减少线程池的最大并发线程数,包括:根据预定时间段内待处理任务减少的数量,确定线程池的最大并发线程数的减少量;将线程池的最大并发线程数减少至线程池当前最大并发线程数与减少量之差。
在本实现方式中,通过预定时间段内待处理任务减少的数量,即待处理任务减少的速度,可以预估未来一段时间线程池待处理任务的数量,据此确定最大并发线程数的减少量具有前瞻性,进一步提高了线程池的运行效率。
步骤405,根据减少后的最大并发线程数销毁线程。
在本实施例中,上述电子设备可以根据步骤404中减少后的最大并发线程数销毁线程,销毁的线程的数量可以是减少后的最大并发线程数与线程池当前的最大并发线程数之差,线程池根据实际情况销毁的线程的数量也可能大于减少后的最大并发线程数与线程池当前的最大并发线程数之差。任务队列中任务的数量远小于最大并发线程数时,由于线程不会自动销毁,仍在占用系统CPU资源,会造成资源浪费,所以需要销毁线程。
步骤401、步骤402、步骤403的实现细节和技术效果可以参考步骤201、步骤202、步骤203中的说明,在此不再赘述。
从图4中可以看出,与图2对应的实施例相比,本申请的上述实施例提供的方法通过在待处理任务的数量小于第二预定数量或线程池中存在空闲时长超过预定时长的线程时,根据预设规则减少线程池的最大并发线程数,并销毁线程,避免了空闲线程占用系统CPU资源,进一步提高了线程池的运行效率。
进一步参考图5,作为对上述方法的实现,本申请提供了一种用于控制线程池中线程数量的装置的一个实施例,该装置实施例与图2所示的方法实施例相对应,该装置具体可以应用于各种电子设备中。
如图5所示,本实施例的用于控制线程池中线程数量的装置500包括:获取单元501,增大单元502,创建单元503,其中,获取单元501,用于获取线程池的任务队列中待处理任务的数量;增大单元502,用于响应于待处理任务的数量大于第一预定数量且线程池所在系统的CPU使用率小于预定阈值,根据预定规则增大线程池的最大并发线程数;创建单元503,用于根据增大后的最大并发线程数创建线程。
在本实施例中,获取单元501,增大单元502,创建单元503的具体处理可以参考图2对应实施例步骤201、步骤202、步骤203的详细描述,在此不再赘述。
在本实施例的一些可选实现方式中,增大单元502,进一步配置用于:将线程池的最大并发线程数增大至线程池的初始最大并发线程数与线程池当前最大并发线程数之和;或根据预定时间段内待处理任务增加的数量,确定线程池的最大并发线程数的增加量,将线程池的最大并发线程数增大至增加量与线程池当前最大并发线程数之和。
在本实施例的一些可选实现方式中,减少单元504,进一步配置用于:确定线程池中空闲时长超过预定时长的线程的数量,将线程池的最大并发线程数减少至线程池当前最大并发线程数与确定的数量之差;或根据预定时间段内待处理任务减少的数量,确定线程池的最大并发线程数的减少量,将线程池的最大并发线程数减少至线程池当前最大并发线程数与减少量之差。
在本实施例的一些可选实现方式中,获取单元501,进一步配置用于:每隔预设时间段获取线程池的任务队列中待处理任务的数量;或响应于预设时长内没有待处理任务加入任务队列,获取任务队列中待处理任务的数量;或响应于预置时长内加入任务队列中的待处理任务的数量超过预定数量阈值,获取任务队列中待处理任务的数量。
从图5中可以看出,本实施例中用于控制线程池中线程数量的装置500通过获取线程池的任务队列中待处理任务的数量,而后响应于待处理任务的数量大于第一预定数量且线程池所在系统的CPU使用率小于预定阈值,根据预定规则增大线程池的最大并发线程数,最后根据增大后的最大并发线程数创建线程,提高了线程池的运行效率。
下面参考图6,其示出了适于用来实现本申请实施例的终端设备或服务器的计算机系统600的结构示意图。图6示出的终端设备/服务器仅仅是一个示例,不应对本申请实施例的功能和使用范围带来任何限制。
如图6所示,计算机系统600包括中央处理单元(CPU)601,其可以根据存储在只读存储器(ROM)602中的程序或者从存储部分608加载到随机访问存储器(RAM)603中的程序而执行各种适当的动作和处理。在RAM 603中,还存储有系统600操作所需的各种程序和数据。CPU 601、ROM 602以及RAM 603通过总线604彼此相连。输入/输出(I/O)接口605也连接至总线604。
以下部件连接至I/O接口605:包括键盘、鼠标等的输入部分606;包括诸如阴极射线管(CRT)、液晶显示器(LCD)等以及扬声器等的输出部分607;包括硬盘等的存储部分608;以及包括诸如LAN卡、调制解调器等的网络接口卡的通信部分609。通信部分609经由诸如因特网的网络执行通信处理。驱动器610也根据需要连接至I/O接口606。可拆卸介质611,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器610上,以便于从其上读出的计算机程序根据需要被安装入存储部分608。
特别地,根据本公开的实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本公开的实施例包括一种计算机程序产品,其包括承载在计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信部分609从网络上被下载和安装,和/或从可拆卸介质611被安装。在该计算机程序被中央处理单元(CPU)601执行时,执行本申请的方法中限定的上述功能。
需要说明的是,本申请所述的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本申请中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。而在本申请中,计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:无线、电线、光缆、RF等等,或者上述的任意合适的组合。
附图中的流程图和框图,图示了按照本申请各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个单元、程序段、或代码的一部分,该单元、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
描述于本申请实施例中所涉及到的单元可以通过软件的方式实现,也可以通过硬件的方式来实现。所描述的单元也可以设置在处理器中,例如,可以描述为:一种处理器包括获取单元,增大单元,创建单元。其中,这些单元的名称在某种情况下并不构成对该单元本身的限定,例如,获取单元还可以被描述为“获取线程池的任务队列中待处理任务的数量的单元”。
作为另一方面,本申请还提供了一种计算机可读介质,该计算机可读介质可以是上述实施例中描述的装置中所包含的;也可以是单独存在,而未装配入该装置中。上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被该装置执行时,使得该装置:获取线程池的任务队列中待处理任务的数量;响应于待处理任务的数量大于第一预定数量且线程池所在系统的CPU使用率小于预定阈值,根据预定规则增大线程池的最大并发线程数;根据增大后的最大并发线程数创建线程。
以上描述仅为本申请的较佳实施例以及对所运用技术原理的说明。本领域技术人员应当理解,本申请中所涉及的发明范围,并不限于上述技术特征的特定组合而成的技术方案,同时也应涵盖在不脱离上述发明构思的情况下,由上述技术特征或其等同特征进行任意组合而形成的其它技术方案。例如上述特征与本申请中公开的(但不限于)具有类似功能的技术特征进行互相替换而形成的技术方案。

Claims (12)

1.一种用于控制线程池中线程数量的方法,其特征在于,所述方法包括:
获取线程池的任务队列中待处理任务的数量;
响应于所述待处理任务的数量大于第一预定数量且所述线程池所在系统的CPU使用率小于预定阈值,根据预定规则增大所述线程池的最大并发线程数;
根据增大后的最大并发线程数创建线程。
2.根据权利要求1所述的方法,其特征在于,所述方法还包括:
响应于所述待处理任务的数量小于第二预定数量或所述线程池中存在空闲时长超过预定时长的线程,根据预设规则减少所述线程池的最大并发线程数,其中,所述第二预定数量小于所述第一预定数量;
根据减少后的最大并发线程数销毁线程。
3.根据权利要求1所述的方法,其特征在于,所述根据预定规则增大所述线程池的最大并发线程数,包括以下任意一项:
将所述线程池的最大并发线程数增大至所述线程池的初始最大并发线程数与所述线程池当前最大并发线程数之和;
根据预定时间段内所述待处理任务增加的数量,确定所述线程池的最大并发线程数的增加量,将所述线程池的最大并发线程数增大至所述增加量与所述线程池当前最大并发线程数之和。
4.根据权利要求2所述的方法,其特征在于,所述根据预设规则减少所述线程池的最大并发线程数,包括以下任意一项:
确定所述线程池中空闲时长超过预定时长的线程的数量,将所述线程池的最大并发线程数减少至所述线程池当前最大并发线程数与确定的数量之差;
根据预定时间段内所述待处理任务减少的数量,确定所述线程池的最大并发线程数的减少量,将所述线程池的最大并发线程数减少至所述线程池当前最大并发线程数与所述减少量之差。
5.根据权利要求1-4中任一项所述的方法,其特征在于,所述获取线程池的任务队列中待处理任务的数量,包括以下任意一项:
每隔预设时间段获取线程池的任务队列中待处理任务的数量;
响应于预设时长内没有待处理任务加入所述任务队列,获取所述任务队列中待处理任务的数量;
响应于预置时长内加入所述任务队列中的待处理任务的数量超过预定数量阈值,获取所述任务队列中待处理任务的数量。
6.一种用于控制线程池中线程数量的装置,其特征在于,所述装置包括:
获取单元,用于获取线程池的任务队列中待处理任务的数量;
增大单元,用于响应于所述待处理任务的数量大于第一预定数量且所述线程池所在系统的CPU使用率小于预定阈值,根据预定规则增大所述线程池的最大并发线程数;
创建单元,用于根据增大后的最大并发线程数创建线程。
7.根据权利要求6所述的装置,其特征在于,所述装置还包括:
减少单元,用于响应于所述待处理任务的数量小于第二预定数量或所述线程池中存在空闲时长超过预定时长的线程,根据预设规则减少所述线程池的最大并发线程数,其中,所述第二预定数量小于所述第一预定数量;
销毁单元,用于根据减少后的最大并发线程数销毁线程。
8.根据权利要求6所述的装置,其特征在于,所述增大单元,进一步配置用于:
将所述线程池的最大并发线程数增大至所述线程池的初始最大并发线程数与所述线程池当前最大并发线程数之和;或
根据预定时间段内所述待处理任务增加的数量,确定所述线程池的最大并发线程数的增加量,将所述线程池的最大并发线程数增大至所述增加量与所述线程池当前最大并发线程数之和。
9.根据权利要求7所述的装置,其特征在于,所述减少单元,进一步配置用于:
确定所述线程池中空闲时长超过预定时长的线程的数量,将所述线程池的最大并发线程数减少至所述线程池当前最大并发线程数与确定的数量之差;或
根据预定时间段内所述待处理任务减少的数量,确定所述线程池的最大并发线程数的减少量,将所述线程池的最大并发线程数减少至所述线程池当前最大并发线程数与所述减少量之差。
10.根据权利要求6-9中任一项所述的装置,其特征在于,所述获取单元,进一步配置用于:
每隔预设时间段获取线程池的任务队列中待处理任务的数量;或
响应于预设时长内没有待处理任务加入所述任务队列,获取所述任务队列中待处理任务的数量;或
响应于预置时长内加入所述任务队列中的待处理任务的数量超过预定数量阈值,获取所述任务队列中待处理任务的数量。
11.一种设备,其特征在于,包括:
一个或多个处理器;
存储装置,用于存储一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如权利要求1-5中任一所述的方法。
12.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现如权利要求1-5中任一所述的方法。
CN201710542258.8A 2017-07-05 2017-07-05 用于控制线程池中线程数量的方法和装置 Pending CN107220033A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201710542258.8A CN107220033A (zh) 2017-07-05 2017-07-05 用于控制线程池中线程数量的方法和装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201710542258.8A CN107220033A (zh) 2017-07-05 2017-07-05 用于控制线程池中线程数量的方法和装置

Publications (1)

Publication Number Publication Date
CN107220033A true CN107220033A (zh) 2017-09-29

Family

ID=59951916

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201710542258.8A Pending CN107220033A (zh) 2017-07-05 2017-07-05 用于控制线程池中线程数量的方法和装置

Country Status (1)

Country Link
CN (1) CN107220033A (zh)

Cited By (32)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN108829521A (zh) * 2018-06-13 2018-11-16 平安科技(深圳)有限公司 任务处理方法、装置、计算机设备及存储介质
CN108874550A (zh) * 2018-07-18 2018-11-23 郑州云海信息技术有限公司 一种调整线程池的方法、装置、存储介质和计算机设备
CN108984288A (zh) * 2018-06-11 2018-12-11 山东中创软件商用中间件股份有限公司 基于系统响应时间的线程池容量调整方法、装置及设备
CN109086132A (zh) * 2018-06-26 2018-12-25 深圳市买买提信息科技有限公司 一种人脸识别任务均衡调用方法、装置及终端设备
CN109144699A (zh) * 2018-08-31 2019-01-04 阿里巴巴集团控股有限公司 分布式任务调度方法、装置及系统
CN109189336A (zh) * 2018-08-17 2019-01-11 郑州云海信息技术有限公司 一种存储系统线程调整方法、系统及电子设备和存储介质
CN109271252A (zh) * 2018-08-29 2019-01-25 华为技术有限公司 一种调整线程数的方法及装置
CN109391680A (zh) * 2018-08-31 2019-02-26 阿里巴巴集团控股有限公司 一种定时任务数据处理方法、装置及系统
CN109451051A (zh) * 2018-12-18 2019-03-08 百度在线网络技术(北京)有限公司 服务请求处理方法、装置、电子设备及存储介质
CN109714407A (zh) * 2018-12-19 2019-05-03 网易(杭州)网络有限公司 服务器资源调节方法及装置、电子设备和存储介质
CN109766131A (zh) * 2017-11-06 2019-05-17 上海宝信软件股份有限公司 基于多线程技术实现软件智能化自动升级的系统及方法
CN109840141A (zh) * 2018-12-15 2019-06-04 平安科技(深圳)有限公司 基于云监控的线程控制方法、装置、电子设备及存储介质
CN109857547A (zh) * 2019-01-04 2019-06-07 平安科技(深圳)有限公司 一种线程分配方法、装置及终端设备
CN109885385A (zh) * 2018-12-21 2019-06-14 山东中创软件商用中间件股份有限公司 一种应用服务器线程池的自调优方法、装置及设备
CN109885470A (zh) * 2019-03-04 2019-06-14 上海拉扎斯信息科技有限公司 线程池的调整方法、装置、存储介质和电子设备
CN110032434A (zh) * 2019-03-12 2019-07-19 平安普惠企业管理有限公司 一种信号量许可的调整方法及装置
CN110865798A (zh) * 2018-08-28 2020-03-06 中国移动通信集团浙江有限公司 一种线程池优化方法及系统
CN111124643A (zh) * 2019-12-20 2020-05-08 浪潮电子信息产业股份有限公司 一种分布式存储中的删除任务调度方法、系统及相关装置
CN111142943A (zh) * 2019-12-27 2020-05-12 中国银行股份有限公司 自动控制并发方法及装置
CN111176806A (zh) * 2019-12-05 2020-05-19 中国银联股份有限公司 一种业务处理方法、装置及计算机可读存储介质
CN111782378A (zh) * 2020-07-29 2020-10-16 平安银行股份有限公司 自适应性的处理性能调整方法、服务器及可读存储介质
CN112035255A (zh) * 2020-08-28 2020-12-04 北京浪潮数据技术有限公司 线程池资源管理任务处理方法、装置、设备及存储介质
CN112698927A (zh) * 2019-10-23 2021-04-23 杭州海康威视数字技术股份有限公司 双向通信方法、装置、电子设备及机器可读存储介质
CN113064620A (zh) * 2021-04-02 2021-07-02 北京天空卫士网络安全技术有限公司 一种处理系统数据的方法和装置
CN113157410A (zh) * 2021-03-30 2021-07-23 北京大米科技有限公司 线程池调节方法、装置、存储介质及电子设备
CN113238861A (zh) * 2021-05-08 2021-08-10 北京天空卫士网络安全技术有限公司 一种任务执行方法和装置
CN113779949A (zh) * 2021-09-17 2021-12-10 北京天融信网络安全技术有限公司 一种报告生成方法、装置、电子设备、存储介质及系统
CN114020477A (zh) * 2022-01-04 2022-02-08 北京安华金和科技有限公司 一种脱敏集群环境并发任务调度方法和装置
CN114374657A (zh) * 2022-01-04 2022-04-19 京东科技控股股份有限公司 一种数据处理方法和装置
CN116755805A (zh) * 2023-08-18 2023-09-15 北京融为科技有限公司 应用于c++的资源优化方法及装置
CN117453363A (zh) * 2023-11-06 2024-01-26 北京明朝万达科技股份有限公司 一种附件处理方法及装置、电子设备、存储介质
CN111562973B (zh) * 2020-04-24 2024-02-06 蘑菇车联信息科技有限公司 一种地图数据任务执行方法及电子设备

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2009033248A1 (en) * 2007-09-10 2009-03-19 Novell, Inc. A method for efficient thread usage for hierarchically structured tasks
CN102360310A (zh) * 2011-09-28 2012-02-22 中国电子科技集团公司第二十八研究所 一种分布式系统环境下的多任务进程监视方法和监视系统
CN103902361A (zh) * 2014-04-04 2014-07-02 浪潮电子信息产业股份有限公司 一种可动态调节尺寸的线程池
CN105468297A (zh) * 2015-11-18 2016-04-06 临沂大学 一种云存储系统内主从设备数据快速同步的方法
CN106648872A (zh) * 2016-12-29 2017-05-10 深圳市优必选科技有限公司 用于多线程处理的方法及装置、服务器

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2009033248A1 (en) * 2007-09-10 2009-03-19 Novell, Inc. A method for efficient thread usage for hierarchically structured tasks
CN102360310A (zh) * 2011-09-28 2012-02-22 中国电子科技集团公司第二十八研究所 一种分布式系统环境下的多任务进程监视方法和监视系统
CN103902361A (zh) * 2014-04-04 2014-07-02 浪潮电子信息产业股份有限公司 一种可动态调节尺寸的线程池
CN105468297A (zh) * 2015-11-18 2016-04-06 临沂大学 一种云存储系统内主从设备数据快速同步的方法
CN106648872A (zh) * 2016-12-29 2017-05-10 深圳市优必选科技有限公司 用于多线程处理的方法及装置、服务器

Cited By (40)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109766131A (zh) * 2017-11-06 2019-05-17 上海宝信软件股份有限公司 基于多线程技术实现软件智能化自动升级的系统及方法
CN108984288A (zh) * 2018-06-11 2018-12-11 山东中创软件商用中间件股份有限公司 基于系统响应时间的线程池容量调整方法、装置及设备
CN108829521A (zh) * 2018-06-13 2018-11-16 平安科技(深圳)有限公司 任务处理方法、装置、计算机设备及存储介质
CN109086132A (zh) * 2018-06-26 2018-12-25 深圳市买买提信息科技有限公司 一种人脸识别任务均衡调用方法、装置及终端设备
CN108874550A (zh) * 2018-07-18 2018-11-23 郑州云海信息技术有限公司 一种调整线程池的方法、装置、存储介质和计算机设备
CN109189336A (zh) * 2018-08-17 2019-01-11 郑州云海信息技术有限公司 一种存储系统线程调整方法、系统及电子设备和存储介质
CN110865798A (zh) * 2018-08-28 2020-03-06 中国移动通信集团浙江有限公司 一种线程池优化方法及系统
CN110865798B (zh) * 2018-08-28 2023-07-21 中国移动通信集团浙江有限公司 一种线程池优化方法及系统
CN109271252A (zh) * 2018-08-29 2019-01-25 华为技术有限公司 一种调整线程数的方法及装置
CN109391680A (zh) * 2018-08-31 2019-02-26 阿里巴巴集团控股有限公司 一种定时任务数据处理方法、装置及系统
CN109391680B (zh) * 2018-08-31 2021-07-09 创新先进技术有限公司 一种定时任务数据处理方法、装置及系统
CN109144699A (zh) * 2018-08-31 2019-01-04 阿里巴巴集团控股有限公司 分布式任务调度方法、装置及系统
CN109840141B (zh) * 2018-12-15 2024-05-03 平安科技(深圳)有限公司 基于云监控的线程控制方法、装置、电子设备及存储介质
CN109840141A (zh) * 2018-12-15 2019-06-04 平安科技(深圳)有限公司 基于云监控的线程控制方法、装置、电子设备及存储介质
CN109451051A (zh) * 2018-12-18 2019-03-08 百度在线网络技术(北京)有限公司 服务请求处理方法、装置、电子设备及存储介质
CN109451051B (zh) * 2018-12-18 2021-11-02 百度在线网络技术(北京)有限公司 服务请求处理方法、装置、电子设备及存储介质
CN109714407A (zh) * 2018-12-19 2019-05-03 网易(杭州)网络有限公司 服务器资源调节方法及装置、电子设备和存储介质
CN109885385A (zh) * 2018-12-21 2019-06-14 山东中创软件商用中间件股份有限公司 一种应用服务器线程池的自调优方法、装置及设备
CN109857547A (zh) * 2019-01-04 2019-06-07 平安科技(深圳)有限公司 一种线程分配方法、装置及终端设备
CN109885470A (zh) * 2019-03-04 2019-06-14 上海拉扎斯信息科技有限公司 线程池的调整方法、装置、存储介质和电子设备
CN110032434A (zh) * 2019-03-12 2019-07-19 平安普惠企业管理有限公司 一种信号量许可的调整方法及装置
CN112698927B (zh) * 2019-10-23 2024-05-28 杭州海康威视数字技术股份有限公司 双向通信方法、装置、电子设备及机器可读存储介质
CN112698927A (zh) * 2019-10-23 2021-04-23 杭州海康威视数字技术股份有限公司 双向通信方法、装置、电子设备及机器可读存储介质
CN111176806A (zh) * 2019-12-05 2020-05-19 中国银联股份有限公司 一种业务处理方法、装置及计算机可读存储介质
CN111176806B (zh) * 2019-12-05 2024-02-23 中国银联股份有限公司 一种业务处理方法、装置及计算机可读存储介质
CN111124643A (zh) * 2019-12-20 2020-05-08 浪潮电子信息产业股份有限公司 一种分布式存储中的删除任务调度方法、系统及相关装置
CN111142943A (zh) * 2019-12-27 2020-05-12 中国银行股份有限公司 自动控制并发方法及装置
CN111562973B (zh) * 2020-04-24 2024-02-06 蘑菇车联信息科技有限公司 一种地图数据任务执行方法及电子设备
CN111782378A (zh) * 2020-07-29 2020-10-16 平安银行股份有限公司 自适应性的处理性能调整方法、服务器及可读存储介质
CN111782378B (zh) * 2020-07-29 2024-04-16 平安银行股份有限公司 自适应性的处理性能调整方法、服务器及可读存储介质
CN112035255A (zh) * 2020-08-28 2020-12-04 北京浪潮数据技术有限公司 线程池资源管理任务处理方法、装置、设备及存储介质
CN113157410A (zh) * 2021-03-30 2021-07-23 北京大米科技有限公司 线程池调节方法、装置、存储介质及电子设备
CN113064620A (zh) * 2021-04-02 2021-07-02 北京天空卫士网络安全技术有限公司 一种处理系统数据的方法和装置
CN113238861A (zh) * 2021-05-08 2021-08-10 北京天空卫士网络安全技术有限公司 一种任务执行方法和装置
CN113779949A (zh) * 2021-09-17 2021-12-10 北京天融信网络安全技术有限公司 一种报告生成方法、装置、电子设备、存储介质及系统
CN114020477A (zh) * 2022-01-04 2022-02-08 北京安华金和科技有限公司 一种脱敏集群环境并发任务调度方法和装置
CN114374657A (zh) * 2022-01-04 2022-04-19 京东科技控股股份有限公司 一种数据处理方法和装置
CN116755805A (zh) * 2023-08-18 2023-09-15 北京融为科技有限公司 应用于c++的资源优化方法及装置
CN116755805B (zh) * 2023-08-18 2024-02-02 北京融为科技有限公司 应用于c++的资源优化方法及装置
CN117453363A (zh) * 2023-11-06 2024-01-26 北京明朝万达科技股份有限公司 一种附件处理方法及装置、电子设备、存储介质

Similar Documents

Publication Publication Date Title
CN107220033A (zh) 用于控制线程池中线程数量的方法和装置
CN105579959B (zh) 硬件加速器虚拟化
CN108062246A (zh) 用于深度学习框架的资源调度方法和装置
CN107343045A (zh) 云计算系统及用于控制服务器的云计算方法和装置
CN107729139A (zh) 一种并发获取资源的方法和装置
CN108038546A (zh) 用于压缩神经网络的方法和装置
CN114840352A (zh) 分批处理机器学习模型的输入
CN107247629A (zh) 云计算系统及用于控制服务器的云计算方法和装置
CN109063190A (zh) 用于处理数据序列的方法和装置
CN106020976A (zh) 将内存耗尽处理流程卸载到用户空间的方法和装置
CN111552550A (zh) 一种基于图形处理器gpu资源的任务调度方法、设备及介质
CN107832143A (zh) 一种物理机资源的处理方法和装置
CN107580374B (zh) 一种蓝牙通信资源的调度方法、设备及存储介质
CN114841315A (zh) 混合专家模型实现方法、系统、电子设备及存储介质
CN103150192A (zh) 一种基于网络游戏的副本加载方法和设备
CN114924851A (zh) 训练任务的调度方法、装置、电子设备和存储介质
CN112508768A (zh) 单算子多模型流水线推理方法、系统、电子设备及介质
CN109684059A (zh) 用于监控数据的方法及装置
CN107222618A (zh) 终端截屏方法及装置
CN109597912A (zh) 用于处理图片的方法
CN109683992A (zh) 用于管理对象的方法和装置
CN107766137A (zh) 一种任务处理方法和装置
CN116866661A (zh) 一种视频预渲染方法、装置、设备及存储介质
CN110309462A (zh) 数据展示方法及系统
CN109783236A (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
TA01 Transfer of patent application right

Effective date of registration: 20210507

Address after: 100085 Baidu Building, 10 Shangdi Tenth Street, Haidian District, Beijing

Applicant after: BEIJING BAIDU NETCOM SCIENCE AND TECHNOLOGY Co.,Ltd.

Applicant after: Shanghai Xiaodu Technology Co.,Ltd.

Address before: 100085 Baidu Building, 10 Shangdi Tenth Street, Haidian District, Beijing

Applicant before: BEIJING BAIDU NETCOM SCIENCE AND TECHNOLOGY Co.,Ltd.

TA01 Transfer of patent application right
RJ01 Rejection of invention patent application after publication

Application publication date: 20170929

RJ01 Rejection of invention patent application after publication