CN114531602A - 基于动态资源释放的视频直播性能优化方法及装置 - Google Patents
基于动态资源释放的视频直播性能优化方法及装置 Download PDFInfo
- Publication number
- CN114531602A CN114531602A CN202011323108.6A CN202011323108A CN114531602A CN 114531602 A CN114531602 A CN 114531602A CN 202011323108 A CN202011323108 A CN 202011323108A CN 114531602 A CN114531602 A CN 114531602A
- Authority
- CN
- China
- Prior art keywords
- resource object
- resource
- intelligent
- video
- smart
- 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
- 238000000034 method Methods 0.000 title claims abstract description 58
- 238000005457 optimization Methods 0.000 title claims abstract description 21
- 238000009826 distribution Methods 0.000 claims abstract description 100
- 238000012545 processing Methods 0.000 claims abstract description 23
- 230000006870 function Effects 0.000 claims description 23
- 238000010276 construction Methods 0.000 claims description 16
- 238000004891 communication Methods 0.000 claims description 15
- 230000002159 abnormal effect Effects 0.000 claims description 10
- 238000010586 diagram Methods 0.000 description 7
- 238000004590 computer program Methods 0.000 description 4
- 230000005540 biological transmission Effects 0.000 description 3
- 238000005315 distribution function Methods 0.000 description 2
- 238000012546 transfer Methods 0.000 description 2
- 230000005856 abnormality Effects 0.000 description 1
- 238000013459 approach Methods 0.000 description 1
- 230000003247 decreasing effect Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 238000011161 development Methods 0.000 description 1
- 238000011022 operating instruction Methods 0.000 description 1
- 238000012360 testing method Methods 0.000 description 1
- 238000012800 visualization Methods 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/20—Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
- H04N21/21—Server components or server architectures
- H04N21/218—Source of audio or video content, e.g. local disk arrays
- H04N21/2187—Live feed
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/40—Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
- H04N21/43—Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
- H04N21/433—Content storage operation, e.g. storage operation in response to a pause request, caching operations
- H04N21/4335—Housekeeping operations, e.g. prioritizing content for deletion because of storage space restrictions
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/40—Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
- H04N21/43—Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
- H04N21/442—Monitoring of processes or resources, e.g. detecting the failure of a recording device, monitoring the downstream bandwidth, the number of times a movie has been viewed, the storage space available from the internal hard disk
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Databases & Information Systems (AREA)
- Computer Networks & Wireless Communication (AREA)
- Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)
Abstract
本发明实施例涉及业务支撑技术领域,公开了一种基于动态资源释放的视频直播性能优化方法及装置,该方法包括:获取音视频数据,并为所述音视频数据构造第一智能资源对象;将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象以进行视频播放,并在完成视频播放后,对所述第二智能资源对象进行析构;接收所述分发线程返回的处理成功消息,并对所述第一智能资源对象进行析构;所有所述分发线程结束时,释放所述第一智能资源对象。通过上述方式,本发明实施例能够实现程序开发中各类资源的自动释放,从而减少程序开发时资源管理工作,防止误释放或忘记释放资源,提高视频播放的稳定可靠性。
Description
技术领域
本发明实施例涉及业务支撑技术领域,具体涉及一种基于动态资源释放的视频直播性能优化方法及装置。
背景技术
随着移动互联网的发展,越来越多的业务应用采用了视频直播来实现业务办理的可视化及提高业务办理的速度。视频直播主要分为视频采集端、视频分发端、视频播放端。视频采集端采集原始音视频数据,经过编码压缩后上传到视频分发端。视频分发端缓存上传的音视频数据并下发给视频播放端进行解码解压播放。在三端的处理当中均涉及到各类资源的申请释放,同时还涉及到在多个线程当中进行各资源的传递,在资源的使用当中还可能存在各异常分支,从而导致谁来释放资源、什么时候释放该资源等问题的存在。采用传统的资源手工申请释放会导致资源忘记释放、资源错误释放等,会导致程序不稳定、测试工作量大等困难。
发明内容
鉴于上述问题,本发明实施例提供了一种基于动态资源释放的视频直播性能优化方法及装置,克服了上述问题或者至少部分地解决了上述问题。
根据本发明实施例的一个方面,提供了一种基于动态资源释放的视频直播性能优化方法,所述方法包括:获取音视频数据,并为所述音视频数据构造第一智能资源对象;将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象以进行视频播放,并在完成视频播放后,对所述第二智能资源对象进行析构;接收所述分发线程返回的处理成功消息,并对所述第一智能资源对象进行析构;所有所述分发线程结束时,释放所述第一智能资源对象。
在一种可选的方式中,所述为所述音视频数据构造第一智能资源对象,包括:根据所述音视频数据的大小申请内存空间,并构造第一智能资源对象,其中,所述第一智能资源对象为对象内存、数组内存、文件、网络、COM对象及程序自定义对象的其中之一;将所述音视频数据存储到新申请的所述第一智能资源对象所管理的内存空间当中,将引用计数设为1,返回所述第一智能资源对象。
在一种可选的方式中,所述将所述音视频数据存储到新申请的所述第一智能资源对象所管理的内存空间当中,包括:如果网络出现异常,函数异常返回,则对所述第一智能资源对象进行自动析构。
在一种可选的方式中,所述将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象以进行视频播放,包括:将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象,同时将所述第二智能资源对象的引用计数加1;通过所述分发线程将存储所述音视频数据的所述第二智能资源对象存储到待发送队列;通过所述分发线程将所述音视频数据发送至视频播放端进行视频播放。
在一种可选的方式中,假设所述第一智能资源对象持有第一资源,所述第二智能资源对象持有第二资源,所述将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象,包括:如果所述第二资源的引用计数不为0,则将所述第二资源的引用计数减1,将所述第二智能资源对象指向所述第一资源;将所述第一资源的引用计数加1。
在一种可选的方式中,所述对所述第一智能资源对象进行析构,包括:将所述第一智能资源对象的引用计数减1;所述对所述第二智能资源对象进行析构,包括:将所述第二智能资源对象的引用计数减1。
在一种可选的方式中,所述所有所述分发线程结束时,释放所述第一智能资源对象,包括:如果所述第一智能资源对象的引用计数为0,则确定所有所述分发线程结束;释放所述第一智能资源对象。
根据本发明实施例的另一个方面,提供了一种基于动态资源释放的视频直播性能优化装置,所述装置包括:构造单元,用于获取音视频数据,并为所述音视频数据构造第一智能资源对象;赋值单元,用于将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象以进行视频播放,并在完成视频播放后,对所述第二智能资源对象进行析构;析构单元,用于接收所述分发线程返回的处理成功消息,并对所述第一智能资源对象进行析构;释放单元,用于所有所述分发线程结束时,释放所述第一智能资源对象。
根据本发明实施例的另一方面,提供了一种计算设备,包括:处理器、存储器、通信接口和通信总线,所述处理器、所述存储器和所述通信接口通过所述通信总线完成相互间的通信;
所述存储器用于存放至少一可执行指令,所述可执行指令使所述处理器执行上述基于动态资源释放的视频直播性能优化方法的步骤。
根据本发明实施例的又一方面,提供了一种计算机存储介质,所述存储介质中存储有至少一可执行指令,所述可执行指令使所述处理器执行上述基于动态资源释放的视频直播性能优化方法的步骤。
本发明实施例通过获取音视频数据,并为所述音视频数据构造第一智能资源对象;将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象以进行视频播放,并在完成视频播放后,对所述第二智能资源对象进行析构;接收所述分发线程返回的处理成功消息,并对所述第一智能资源对象进行析构;所有所述分发线程结束时,释放所述第一智能资源对象,能够程序开发中各类资源的自动释放,从而减少程序开发时资源管理工作,防止误释放或忘记释放资源,提高视频播放的稳定可靠性。
上述说明仅是本发明实施例技术方案的概述,为了能够更清楚了解本发明实施例的技术手段,而可依照说明书的内容予以实施,并且为了让本发明实施例的上述和其它目的、特征和优点能够更明显易懂,以下特举本发明的具体实施方式。
附图说明
通过阅读下文优选实施方式的详细描述,各种其他的优点和益处对于本领域普通技术人员将变得清楚明了。附图仅用于示出优选实施方式的目的,而并不认为是对本发明的限制。而且在整个附图中,用相同的参考符号表示相同的部件。在附图中:
图1示出了本发明实施例提供的基于动态资源释放的视频直播性能优化装置的结构示意图;
图2示出了基于动态资源释放的视频直播性能优化装置的应用示意图;
图3示出了本发明实施例提供的基于动态资源释放的视频直播性能优化方法的赋值示意图;
图4示出了本发明实施例提供的基于动态资源释放的视频直播性能优化方法的流程示意图;
图5示出了本发明实施例提供的又一基于动态资源释放的视频直播性能优化方法的流程示意图;
图6示出了本发明实施例提供的计算设备的结构示意图。
具体实施方式
下面将参照附图更详细地描述本发明的示例性实施例。虽然附图中显示了本发明的示例性实施例,然而应当理解,可以以各种形式实现本发明而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本发明,并且能够将本发明的范围完整的传达给本领域的技术人员。
图1示出了本发明实施例提供的基于动态资源释放的视频直播性能优化装置的结构示意图。如图1所示,基于动态资源释放的视频直播性能优化装置包括智能资源对象的构造单元101、赋值单元102、析构单元103、释放单元104以及计数单元105。其中:
构造单元101用于获取音视频数据,并为所述音视频数据构造第一智能资源对象;赋值单元102用于将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象以进行视频播放,并在完成视频播放后,对所述第二智能资源对象进行析构;析构单元103用于接收所述分发线程返回的处理成功消息,并对所述第一智能资源对象进行析构;释放单元104用于所有所述分发线程结束时,释放所述第一智能资源对象。
图2为本发明实施例的基于动态资源释放的视频直播性能优化装置的应用示意图,如图2所示,智能资源对象的使用端包括视频采集端、视频分发端、视频播放端,此三端通过调用智能资源对象的构造单元101、赋值单元102、析构单元103实现资源的构造、使用、不同线程间分发、自动释放等功能。
在本发明实施例中,构造单元101用于接收各类资源,如对象内存、数组内存、文件、网络、COM对象及程序自定义对象的指针,将指针缓存到智能对象里,生成计数单元105,将引用计数设为1,返回智能资源对象。使用端通过使用智能资源对象即可安全的使用资源指针完成资源的各类操作。构造单元101支持构造一个不包括任何资源的空对象,此时计数单元105的引用计数为0。
可选地,构造单元101用于根据所述音视频数据的大小申请内存空间,并构造第一智能资源对象,其中,所述第一智能资源对象为对象内存、数组内存、文件、网络、COM对象及程序自定义对象的其中之一;将所述音视频数据存储到新申请的所述第一智能资源对象所管理的内存空间当中,将引用计数设为1,即调用计数单元105使第一智能资源对象的引用计数为1,返回所述第一智能资源对象。在此过程中,如果网络出现异常,函数异常返回,则对第一智能资源对象进行自动析构,由于此时无其他智能资源对象对此资源的引用,资源的引用计数将减到0,从而释放单元104将自动释放资源。
赋值单元102用于同一个资源在不同函数、不同线程之间的传递。赋值涉及到两个智能资源对象,分别为源对象和目的对象,功能是将源对象的资源赋值到目的对象,从而使用端可通过目的对象操作相应的资源。假设第一智能资源对象持有第一资源,第二智能资源对象持有第二资源,如图3所示,其中,图3中的目的对象为第二智能资源对象,源对象为第一智能资源对象,如果第二资源的引用计数不为0,则需先释放第二资源的引用计数,将第二资源的引用计数减1,即调用第二资源的计数单元105使第二资源的引用计数减1,再将第二智能资源对象指向第一资源;同时将第一资源的引用计数加1,即引用第一资源的计数单元105使第一资源的引用计数加1。
可选地,赋值单元102将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象,同时将所述第二智能资源对象的引用计数加1,即调用计数单元使第二智能资源对象的引用计数加1;通过所述分发线程将存储所述音视频数据的所述第二智能资源对象存储到待发送队列;通过所述分发线程将所述音视频数据发送至视频播放端进行视频播放。
析构单元103利用栈对象在超出作用域时自动调用智能资源对象的析构函数原理来实现调用计数单元引用计数自动减1。如在函数里面定义智能资源对象,当函数正常返回或异常结束时,均会自动调用对象的析构函数,所以智能资源对象的赋值传递必须传递对象的值,不能传递对象的指针,但资源对象里面存储的资源及计数必须为指针。
可选地,在完成视频播放后,析构单元103对所述第二智能资源对象进行析构,即将所述第二智能资源对象的引用计数减1;接收到所述分发线程返回的处理成功消息,析构单元103对所述第一智能资源对象进行析构,即将所述第一智能资源对象的引用计数减1。
计数单元105实现资源引用计数的管理,为防止多线程出现资源的竞争引用,引用计数的增加及减少需实现原子性操作,即一个线程在对计数进行加或减时,其他线程不可以访问计数值及修改计数值。当引用计数减为0,计数单元自动调用释放单元进行资源的释放操作,同时将当前资源及引用计数置空。同一个资源对应的多个智能资源对象共享同一个资源指针及计数单元,不同的资源对应的多个智能资源对象对应的计数单元也不一样。
释放单元104内置了各类标准资源的释放方法,对于这些资源的释放可以自动调用内置的释放方法进行资源释放。各类标准资源的释放方法清单如下表1所示,
表1标准单元释放方法清单
标准资源名称 | 释放方法 |
new申请的对象内存指针ptr | delete ptr |
malloc申请的内存指针ptr | free(ptr) |
new申请的数组内存指针ptr | delete[]ptr |
C文件指针file | close(file) |
网络socket | closesocket(socket) |
COM对象pCOM | pCom->Relase() |
除各类标准资源外,释放单元104还提供自定义对象释放方法注册功能,注册时需提供资源标识及资源释放方法,在构造时传入资源标识即可,释放单元104在释放资源时根据资源标识自动调用资源释放方法。
释放单元104根据资源名称自动调用如表1中的内置的与标准资源名称对应的释放方法进行资源释放,在本发明实施例中,如果所述第一智能资源对象的引用计数为0,则确定所有所述分发线程结束;释放单元104释放所述第一智能资源对象。本发明实施例建立了程序里各类标准资源自动释放方法的清单列表,自动释放的资源包括对象内存、数组内存、文件、网络、COM对象等,同时通过资源标识建立释放单元与构造单元的关联,实现自定义对象的自动释放。
本发明实施例通过由计数单元、释放单元、构造单元、赋值单元、析构单元等构成的智能资源对象,实现程序开发中各类资源的自动释放,从而减少程序开发时资源管理工作、防止误释放或忘记释放资源、提高视频播放的稳定可靠性。计数单元负责资源的引用计数,当引用计数到0时自动释放资源。释放单元内置标准对象的释放方法,程序直接使用即可,该单元同时为程序提供自定义对象释放方法的注册功能。构造单元用于构造一个新的包含资源的自动释放对象,构造时自动生成计数单元。赋值单元自动调用计数单元使已引用的资源引用数减1并使待引用的资源引用数加1。析构单元自动调用计数单元使引用的资源引用数减1。
图4示出了本发明实施例提供的基于动态资源释放的视频直播性能优化方法的流程示意图。如图4所示,基于动态资源释放的视频直播性能优化方法包括:
步骤S11:获取音视频数据,并为所述音视频数据构造第一智能资源对象。
在本发明实施例中,通过视频采集端采集到音频和视频数据后,进行编码压缩后通过网络套接字(Socket)将数据传输到视频分发端的数据接收端。
在本发明实施例中,为所述音视频数据构造第一智能资源对象时,根据所述音视频数据的大小申请内存空间,并构造第一智能资源对象,其中,所述第一智能资源对象为对象内存、数组内存、文件、网络、COM对象及程序自定义对象的其中之一;再将所述音视频数据存储到新申请的所述第一智能资源对象所管理的内存空间当中,将引用计数设为1,返回所述第一智能资源对象。在此过程中,如果网络出现异常,则函数异常返回,对所述第一智能资源对象进行自动析构,由于无其他智能对象对此资源的引用,资源的引用计数将减到0,从而自动释放资源。
步骤S12:将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象以进行视频播放,并在完成视频播放后,对所述第二智能资源对象进行析构。
在本发明实施例中,将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象,同时将所述第二智能资源对象的引用计数加1,实现同一个资源在不同函数、不同线程之间的传递。假设所述第一智能资源对象持有第一资源,所述第二智能资源对象持有第二资源,在将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象的过程中,如果所述第二资源的引用计数不为0,则将所述第二资源的引用计数减1,将所述第二智能资源对象指向所述第一资源;将所述第一资源的引用计数加1。分发线程的个数可能存在多个,因此该赋值过程将会进行多次。分发线程也可能不存在,此时函数直接结束,与步骤11中的异常情况一样,会自动释放资源。
完成赋值后,再通过所述分发线程将存储所述音视频数据的所述第二智能资源对象存储到待发送队列,同时向数据接收端返回处理成功消息。通过所述分发线程将所述音视频数据发送至视频播放端进行视频播放。并在完成视频播放后,即分发函数线程结束,对所述第二智能资源对象进行析构,即对被赋值的第二智能资源对象进行自动析构,将所述第二智能资源对象的引用计数减1。
步骤S13:接收所述分发线程返回的处理成功消息,并对所述第一智能资源对象进行析构。
接收到分发线程返回的处理成功消息后,对所述第一智能资源对象进行析构,具体地,将所述第一智能资源对象的引用计数减1。由于此时存在其他分发线程中的智能资源对象对当前资源的引用,所以引用计数不为0,资源不会释放。
步骤S14:所有所述分发线程结束时,释放所述第一智能资源对象。
在本发明实施例中,如果所述第一智能资源对象的引用计数为0,则确定所有所述分发线程结束,释放所述第一智能资源对象,从而实现资源的自动释放。
下面以视频分发端接收到音视频数据并将此数据分发到各视频播放端,并连接到视频分发端的分发线程内存为例说明智能资源对象的构造、分发、析构、释放过程。由于多线程存在不同的调度时序,以下的说明只针对其中一种时序进行说明,其他时序并无太大差别。完整的基于动态资源释放的视频直播性能优化方法如图5所示,包括:
步骤1:视频采集端向数据接收端发送音视频数据。
具体地,视频采集端采集到音频和视频数据后,进行编码压缩后通过网络Socket将音视频数据传输到视频分发端的数据接收端。
步骤2:数据接收端构造第一智能资源对象。
具体地,数据接收端根据传输数据的大小,申请内存空间并通过智能资源对象的构造单元构造一个新的第一智能资源对象。
步骤3:数据接收端接收音视频数据。
具体地,数据接收端通过网络Socket将接收到的音视频数据存储到新申请的第一智能资源对象所管理的内存空间当中,此步骤如果网络出现各种异常,则函数异常返回,对第一智能资源对象进行自动析构,由于无其他智能对象对此资源的引用,资源的引用计数将减到0,从而实现自动释放资源。
步骤4:数据接收端向分发线程赋值生成第二智能资源对象。
具体地,数据接收端通过赋值单元将前面申请的第一智能资源对象赋值给分发线程里的空的第二智能资源对象。分发的个数可能存在多个,例如N个,因此这里赋值将会进行多次;分发的线程也可能不存在,此时函数直接结束,和步骤3的异常情况一样,会自动释放资源。
步骤5:分发线程将第二智能资源对象加入待发送队列。
具体地,各分发线程将存储音视频数据的第二智能资源对象存储到待发送队列。
步骤6:分发线程向数据接收端返回处理成功消息。
各分发线程返回处理成功消息给数据接收端。
步骤7:函数结束,自动析构第一智能资源对象。
数据接收端收到各分发线程返回处理成功的消息后,函数自动结束,当前函数的第一智能资源对象将进行析构,由于存在其他分发线程中的智能资源对象对当前资源的引用,所以引用计数不为0,资源不会释放。
步骤8:分发线程发送音视频数据给视频播放端。
具体地,分发线程通过网络Socket将音视频数据下发各视频播放端进行视频的播放。
步骤9:函数结束,自动析构第二智能资源对象。
分发函数线程结束,对被赋值的第二智能资源对象进行自动析构。当所有分发线程函数都结束时,资源的计数为0,从而实现资源的自动释放。
本发明实施例通过获取音视频数据,并为所述音视频数据构造第一智能资源对象;将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象以进行视频播放,并在完成视频播放后,对所述第二智能资源对象进行析构;接收所述分发线程返回的处理成功消息,并对所述第一智能资源对象进行析构;所有所述分发线程结束时,释放所述第一智能资源对象,能够实现程序开发中各类资源的自动释放,从而减少程序开发时资源管理工作,防止误释放或忘记释放资源,提高视频播放的稳定可靠性。
本发明实施例提供了一种非易失性计算机存储介质,所述计算机存储介质存储有至少一可执行指令,该计算机可执行指令可执行上述任意方法实施例中的基于动态资源释放的视频直播性能优化方法。
可执行指令具体可以用于使得处理器执行以下操作:
获取音视频数据,并为所述音视频数据构造第一智能资源对象;
将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象以进行视频播放,并在完成视频播放后,对所述第二智能资源对象进行析构;
接收所述分发线程返回的处理成功消息,并对所述第一智能资源对象进行析构;
所有所述分发线程结束时,释放所述第一智能资源对象。
在一种可选的方式中,所述可执行指令使所述处理器执行以下操作:
根据所述音视频数据的大小申请内存空间,并构造第一智能资源对象,其中,所述第一智能资源对象为对象内存、数组内存、文件、网络、COM对象及程序自定义对象的其中之一;
将所述音视频数据存储到新申请的所述第一智能资源对象所管理的内存空间当中,将引用计数设为1,返回所述第一智能资源对象。
在一种可选的方式中,所述可执行指令使所述处理器执行以下操作:
如果网络出现异常,函数异常返回,则对所述第一智能资源对象进行自动析构。
在一种可选的方式中,所述可执行指令使所述处理器执行以下操作:
将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象,同时将所述第二智能资源对象的引用计数加1;
通过所述分发线程将存储所述音视频数据的所述第二智能资源对象存储到待发送队列;
通过所述分发线程将所述音视频数据发送至视频播放端进行视频播放。
在一种可选的方式中,假设所述第一智能资源对象持有第一资源,所述第二智能资源对象持有第二资源,所述可执行指令使所述处理器执行以下操作:
如果所述第二资源的引用计数不为0,则将所述第二资源的引用计数减1,将所述第二智能资源对象指向所述第一资源;
将所述第一资源的引用计数加1。
在一种可选的方式中,所述可执行指令使所述处理器执行以下操作:
所述对所述第一智能资源对象进行析构,包括:将所述第一智能资源对象的引用计数减1;
所述对所述第二智能资源对象进行析构,包括:将所述第二智能资源对象的引用计数减1。
在一种可选的方式中,所述可执行指令使所述处理器执行以下操作:
如果所述第一智能资源对象的引用计数为0,则确定所有所述分发线程结束;
释放所述第一智能资源对象。
本发明实施例通过获取音视频数据,并为所述音视频数据构造第一智能资源对象;将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象以进行视频播放,并在完成视频播放后,对所述第二智能资源对象进行析构;接收所述分发线程返回的处理成功消息,并对所述第一智能资源对象进行析构;所有所述分发线程结束时,释放所述第一智能资源对象,能够实现程序开发中各类资源的自动释放,从而减少程序开发时资源管理工作,防止误释放或忘记释放资源,提高视频播放的稳定可靠性。
本发明实施例提供了一种计算机程序产品,所述计算机程序产品包括存储在计算机存储介质上的计算机程序,所述计算机程序包括程序指令,当所述程序指令被计算机执行时,使所述计算机执行上述任意方法实施例中的基于动态资源释放的视频直播性能优化方法。
可执行指令具体可以用于使得处理器执行以下操作:
获取音视频数据,并为所述音视频数据构造第一智能资源对象;
将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象以进行视频播放,并在完成视频播放后,对所述第二智能资源对象进行析构;
接收所述分发线程返回的处理成功消息,并对所述第一智能资源对象进行析构;
所有所述分发线程结束时,释放所述第一智能资源对象。
在一种可选的方式中,所述可执行指令使所述处理器执行以下操作:
根据所述音视频数据的大小申请内存空间,并构造第一智能资源对象,其中,所述第一智能资源对象为对象内存、数组内存、文件、网络、COM对象及程序自定义对象的其中之一;
将所述音视频数据存储到新申请的所述第一智能资源对象所管理的内存空间当中,将引用计数设为1,返回所述第一智能资源对象。
在一种可选的方式中,所述可执行指令使所述处理器执行以下操作:
如果网络出现异常,函数异常返回,则对所述第一智能资源对象进行自动析构。
在一种可选的方式中,所述可执行指令使所述处理器执行以下操作:
将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象,同时将所述第二智能资源对象的引用计数加1;
通过所述分发线程将存储所述音视频数据的所述第二智能资源对象存储到待发送队列;
通过所述分发线程将所述音视频数据发送至视频播放端进行视频播放。
在一种可选的方式中,假设所述第一智能资源对象持有第一资源,所述第二智能资源对象持有第二资源,所述可执行指令使所述处理器执行以下操作:
如果所述第二资源的引用计数不为0,则将所述第二资源的引用计数减1,将所述第二智能资源对象指向所述第一资源;
将所述第一资源的引用计数加1。
在一种可选的方式中,所述可执行指令使所述处理器执行以下操作:
所述对所述第一智能资源对象进行析构,包括:将所述第一智能资源对象的引用计数减1;
所述对所述第二智能资源对象进行析构,包括:将所述第二智能资源对象的引用计数减1。
在一种可选的方式中,所述可执行指令使所述处理器执行以下操作:
如果所述第一智能资源对象的引用计数为0,则确定所有所述分发线程结束;
释放所述第一智能资源对象。
本发明实施例通过获取音视频数据,并为所述音视频数据构造第一智能资源对象;将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象以进行视频播放,并在完成视频播放后,对所述第二智能资源对象进行析构;接收所述分发线程返回的处理成功消息,并对所述第一智能资源对象进行析构;所有所述分发线程结束时,释放所述第一智能资源对象,能够实现程序开发中各类资源的自动释放,从而减少程序开发时资源管理工作,防止误释放或忘记释放资源,提高视频播放的稳定可靠性。
图6示出了本发明实施例提供的计算设备的结构示意图,本发明具体实施例并不对设备的具体实现做限定。
如图6所示,该计算设备可以包括:处理器(processor)602、通信接口(Communications Interface)604、存储器(memory)606、以及通信总线608。
其中:处理器602、通信接口604、以及存储器606通过通信总线608完成相互间的通信。通信接口604,用于与其它设备比如客户端或其它服务器等的网元通信。处理器602,用于执行程序610,具体可以执行上述基于动态资源释放的视频直播性能优化方法实施例中的相关步骤。
具体地,程序610可以包括程序代码,该程序代码包括计算机操作指令。
处理器602可能是中央处理器CPU,或者是特定集成电路ASIC(ApplicationSpecific Integrated Circuit),或者是被配置成实施本发明实施例的一个或各个集成电路。设备包括的一个或各个处理器,可以是同一类型的处理器,如一个或各个CPU;也可以是不同类型的处理器,如一个或各个CPU以及一个或各个ASIC。
存储器606,用于存放程序610。存储器606可能包含高速RAM存储器,也可能还包括非易失性存储器(non-volatile memory),例如至少一个磁盘存储器。
程序610具体可以用于使得处理器602执行以下操作:
获取音视频数据,并为所述音视频数据构造第一智能资源对象;
将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象以进行视频播放,并在完成视频播放后,对所述第二智能资源对象进行析构;
接收所述分发线程返回的处理成功消息,并对所述第一智能资源对象进行析构;
所有所述分发线程结束时,释放所述第一智能资源对象。
在一种可选的方式中,所述程序610使所述处理器执行以下操作:
根据所述音视频数据的大小申请内存空间,并构造第一智能资源对象,其中,所述第一智能资源对象为对象内存、数组内存、文件、网络、COM对象及程序自定义对象的其中之一;
将所述音视频数据存储到新申请的所述第一智能资源对象所管理的内存空间当中,将引用计数设为1,返回所述第一智能资源对象。
在一种可选的方式中,所述程序610使所述处理器执行以下操作:
如果网络出现异常,函数异常返回,则对所述第一智能资源对象进行自动析构。
在一种可选的方式中,所述程序610使所述处理器执行以下操作:
将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象,同时将所述第二智能资源对象的引用计数加1;
通过所述分发线程将存储所述音视频数据的所述第二智能资源对象存储到待发送队列;
通过所述分发线程将所述音视频数据发送至视频播放端进行视频播放。
在一种可选的方式中,假设所述第一智能资源对象持有第一资源,所述第二智能资源对象持有第二资源,所述程序610使所述处理器执行以下操作:
如果所述第二资源的引用计数不为0,则将所述第二资源的引用计数减1,将所述第二智能资源对象指向所述第一资源;
将所述第一资源的引用计数加1。
在一种可选的方式中,所述程序610使所述处理器执行以下操作:
所述对所述第一智能资源对象进行析构,包括:将所述第一智能资源对象的引用计数减1;
所述对所述第二智能资源对象进行析构,包括:将所述第二智能资源对象的引用计数减1。
在一种可选的方式中,所述程序610使所述处理器执行以下操作:
如果所述第一智能资源对象的引用计数为0,则确定所有所述分发线程结束;
释放所述第一智能资源对象。
本发明实施例通过获取音视频数据,并为所述音视频数据构造第一智能资源对象;将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象以进行视频播放,并在完成视频播放后,对所述第二智能资源对象进行析构;接收所述分发线程返回的处理成功消息,并对所述第一智能资源对象进行析构;所有所述分发线程结束时,释放所述第一智能资源对象,能够实现程序开发中各类资源的自动释放,从而减少程序开发时资源管理工作,防止误释放或忘记释放资源,提高视频播放的稳定可靠性。
在此提供的算法或显示不与任何特定计算机、虚拟系统或者其它设备固有相关。各种通用系统也可以与基于在此的示教一起使用。根据上面的描述,构造这类系统所要求的结构是显而易见的。此外,本发明实施例也不针对任何特定编程语言。应当明白,可以利用各种编程语言实现在此描述的本发明的内容,并且上面对特定语言所做的描述是为了披露本发明的最佳实施方式。
在此处所提供的说明书中,说明了大量具体细节。然而,能够理解,本发明的实施例可以在没有这些具体细节的情况下实践。在一些实例中,并未详细示出公知的方法、结构和技术,以便不模糊对本说明书的理解。
类似地,应当理解,为了精简本发明并帮助理解各个发明方面中的一个或多个,在上面对本发明的示例性实施例的描述中,本发明实施例的各个特征有时被一起分组到单个实施例、图、或者对其的描述中。然而,并不应将该公开的方法解释成反映如下意图:即所要求保护的本发明要求比在每个权利要求中所明确记载的特征更多的特征。
本领域那些技术人员可以理解,可以对实施例中的设备中的模块进行自适应性地改变并且把它们设置在与该实施例不同的一个或多个设备中。可以把实施例中的模块或单元或组件组合成一个模块或单元或组件,以及此外可以把它们分成多个子模块或子单元或子组件。除了这样的特征和/或过程或者单元中的至少一些是相互排斥之外,可以采用任何组合对本说明书(包括伴随的权利要求、摘要和附图)中公开的所有特征以及如此公开的任何方法或者设备的所有过程或单元进行组合。除非另外明确陈述,本说明书(包括伴随的权利要求、摘要和附图)中公开的每个特征可以由提供相同、等同或相似目的的替代特征来代替。
应该注意的是上述实施例对本发明进行说明而不是对本发明进行限制,并且本领域技术人员在不脱离所附权利要求的范围的情况下可设计出替换实施例。在权利要求中,不应将位于括号之间的任何参考符号构造成对权利要求的限制。单词“包含”不排除存在未列在权利要求中的元件或步骤。位于元件之前的单词“一”或“一个”不排除存在多个这样的元件。本发明可以借助于包括有若干不同元件的硬件以及借助于适当编程的计算机来实现。在列举了若干装置的单元权利要求中,这些装置中的若干个可以是通过同一个硬件项来具体体现。单词第一、第二、以及第三等的使用不表示任何顺序。可将这些单词解释为名称。上述实施例中的步骤,除有特殊说明外,不应理解为对执行顺序的限定。
Claims (10)
1.一种基于动态资源释放的视频直播性能优化方法,其特征在于,所述方法包括:
获取音视频数据,并为所述音视频数据构造第一智能资源对象;
将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象以进行视频播放,并在完成视频播放后,对所述第二智能资源对象进行析构;
接收所述分发线程返回的处理成功消息,并对所述第一智能资源对象进行析构;
所有所述分发线程结束时,释放所述第一智能资源对象。
2.根据权利要求1所述的方法,其特征在于,所述为所述音视频数据构造第一智能资源对象,包括:
根据所述音视频数据的大小申请内存空间,并构造第一智能资源对象,其中,所述第一智能资源对象为对象内存、数组内存、文件、网络、COM对象及程序自定义对象的其中之一;
将所述音视频数据存储到新申请的所述第一智能资源对象所管理的所述内存空间当中,将引用计数设为1,返回所述第一智能资源对象。
3.根据权利要求2所述的方法,其特征在于,所述将所述音视频数据存储到新申请的所述第一智能资源对象所管理的所述内存空间当中,包括:
如果网络出现异常,函数异常返回,则对所述第一智能资源对象进行自动析构。
4.根据权利要求1所述的方法,其特征在于,所述将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象以进行视频播放,包括:
将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象,同时将所述第二智能资源对象的引用计数加1;
通过所述分发线程将存储所述音视频数据的所述第二智能资源对象存储到待发送队列;
通过所述分发线程将所述音视频数据发送至视频播放端进行视频播放。
5.根据权利要求4所述的方法,其特征在于,假设所述第一智能资源对象持有第一资源,所述第二智能资源对象持有第二资源,所述将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象,包括:
如果所述第二资源的引用计数不为0,则将所述第二资源的引用计数减1,将所述第二智能资源对象指向所述第一资源;
将所述第一资源的引用计数加1。
6.根据权利要求4所述的方法,其特征在于,
所述对所述第一智能资源对象进行析构,包括:将所述第一智能资源对象的引用计数减1;
所述对所述第二智能资源对象进行析构,包括:将所述第二智能资源对象的引用计数减1。
7.根据权利要求1所述的方法,其特征在于,所述所有所述分发线程结束时,释放所述第一智能资源对象,包括:
如果所述第一智能资源对象的引用计数为0,则确定所有所述分发线程结束;
释放所述第一智能资源对象。
8.一种基于动态资源释放的视频直播性能优化装置,其特征在于,所述装置包括:
构造单元,用于获取音视频数据,并为所述音视频数据构造第一智能资源对象;
赋值单元,用于将所述第一智能资源对象赋值给至少一个分发线程中的第二智能资源对象以进行视频播放,并在完成视频播放后,对所述第二智能资源对象进行析构;
析构单元,用于接收所述分发线程返回的处理成功消息,并对所述第一智能资源对象进行析构;
释放单元,用于所有所述分发线程结束时,释放所述第一智能资源对象。
9.一种计算设备,其特征在于,包括:处理器、存储器、通信接口和通信总线,所述处理器、所述存储器和所述通信接口通过所述通信总线完成相互间的通信;
所述存储器用于存放至少一可执行指令,所述可执行指令使所述处理器执行根据权利要求1-7任一项所述基于动态资源释放的视频直播性能优化方法的步骤。
10.一种计算机存储介质,其特征在于,所述存储介质中存储有至少一可执行指令,所述可执行指令使处理器执行根据权利要求1-7任一项所述基于动态资源释放的视频直播性能优化方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011323108.6A CN114531602B (zh) | 2020-11-23 | 2020-11-23 | 基于动态资源释放的视频直播性能优化方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011323108.6A CN114531602B (zh) | 2020-11-23 | 2020-11-23 | 基于动态资源释放的视频直播性能优化方法及装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN114531602A true CN114531602A (zh) | 2022-05-24 |
CN114531602B CN114531602B (zh) | 2024-02-23 |
Family
ID=81619741
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202011323108.6A Active CN114531602B (zh) | 2020-11-23 | 2020-11-23 | 基于动态资源释放的视频直播性能优化方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN114531602B (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN117979062A (zh) * | 2024-03-05 | 2024-05-03 | 北京瑞祺皓迪技术股份有限公司 | 一种基于编码流引用计数的实时视频流传输方法及装置 |
Citations (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
AUPR947701A0 (en) * | 2001-12-14 | 2002-01-24 | Activesky, Inc. | Digital multimedia publishing system for wireless devices |
US6366932B1 (en) * | 1999-06-24 | 2002-04-02 | International Business Machines Corporation | Apparatus and method for accessing an object oriented object using a smart passive reference |
CN101632070A (zh) * | 2005-05-16 | 2010-01-20 | 微软公司 | 在分离的地址空间内执行的各实体之间的协调引用计数 |
US20130279877A1 (en) * | 2012-04-19 | 2013-10-24 | Qnx Software Systems Limited | System and Method Of Video Decoder Resource Sharing |
CN103905783A (zh) * | 2012-12-25 | 2014-07-02 | 杭州海康威视数字技术股份有限公司 | 对视频流进行解码显示的方法及设备 |
CN104298507A (zh) * | 2014-09-26 | 2015-01-21 | 科大讯飞股份有限公司 | 资源的处理方法及装置 |
US20150339468A1 (en) * | 2014-05-23 | 2015-11-26 | Samsung Electronics Co., Ltd. | Method and apparatus for user authentication |
CN105373434A (zh) * | 2015-12-16 | 2016-03-02 | 上海携程商务有限公司 | 资源管理系统及方法 |
CN107484011A (zh) * | 2017-10-09 | 2017-12-15 | 武汉斗鱼网络科技有限公司 | 一种视频资源解码方法及装置 |
CN108228331A (zh) * | 2016-12-09 | 2018-06-29 | 武汉斗鱼网络科技有限公司 | 一种资源管理方法及系统 |
CN110300328A (zh) * | 2018-03-21 | 2019-10-01 | 腾讯科技(深圳)有限公司 | 一种视频播放控制方法、装置及可读存储介质 |
-
2020
- 2020-11-23 CN CN202011323108.6A patent/CN114531602B/zh active Active
Patent Citations (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6366932B1 (en) * | 1999-06-24 | 2002-04-02 | International Business Machines Corporation | Apparatus and method for accessing an object oriented object using a smart passive reference |
AUPR947701A0 (en) * | 2001-12-14 | 2002-01-24 | Activesky, Inc. | Digital multimedia publishing system for wireless devices |
CN101632070A (zh) * | 2005-05-16 | 2010-01-20 | 微软公司 | 在分离的地址空间内执行的各实体之间的协调引用计数 |
US20130279877A1 (en) * | 2012-04-19 | 2013-10-24 | Qnx Software Systems Limited | System and Method Of Video Decoder Resource Sharing |
CN103905783A (zh) * | 2012-12-25 | 2014-07-02 | 杭州海康威视数字技术股份有限公司 | 对视频流进行解码显示的方法及设备 |
US20150339468A1 (en) * | 2014-05-23 | 2015-11-26 | Samsung Electronics Co., Ltd. | Method and apparatus for user authentication |
CN104298507A (zh) * | 2014-09-26 | 2015-01-21 | 科大讯飞股份有限公司 | 资源的处理方法及装置 |
CN105373434A (zh) * | 2015-12-16 | 2016-03-02 | 上海携程商务有限公司 | 资源管理系统及方法 |
CN108228331A (zh) * | 2016-12-09 | 2018-06-29 | 武汉斗鱼网络科技有限公司 | 一种资源管理方法及系统 |
CN107484011A (zh) * | 2017-10-09 | 2017-12-15 | 武汉斗鱼网络科技有限公司 | 一种视频资源解码方法及装置 |
CN110300328A (zh) * | 2018-03-21 | 2019-10-01 | 腾讯科技(深圳)有限公司 | 一种视频播放控制方法、装置及可读存储介质 |
Non-Patent Citations (3)
Title |
---|
WEI SUN 等: "An Effective Real-Time Error Concealment Scheme for Video Codec", 《2009 SECOND INTERNATIONAL CONFERENCE ON INTELLIGENT COMPUTATION TECHNOLOGY AND AUTOMATION》 * |
张华平 等: "多传感器实时数据采集软件设计与实现", 《工业控制计算机》, vol. 28, no. 06 * |
李婕: "嵌入式多线程高速数据实时传输软件设计与实现", 《中国优秀硕士学位论文全文数据库(电子期刊)信息科技辑》 * |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN117979062A (zh) * | 2024-03-05 | 2024-05-03 | 北京瑞祺皓迪技术股份有限公司 | 一种基于编码流引用计数的实时视频流传输方法及装置 |
Also Published As
Publication number | Publication date |
---|---|
CN114531602B (zh) | 2024-02-23 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN107729139B (zh) | 一种并发获取资源的方法和装置 | |
CN109343963B (zh) | 一种容器集群的应用访问方法、装置及相关设备 | |
US20200364098A1 (en) | Event driving method and apparatus | |
CN107241281B (zh) | 一种数据处理方法及其装置 | |
US8302103B2 (en) | System and method for managing resources of applications and threads performed on java virtual machine | |
CN113641457B (zh) | 容器创建方法、装置、设备、介质及程序产品 | |
CN112214313B (zh) | 内存分配方法及相关设备 | |
CN109857723B (zh) | 基于可扩容数据库集群的动态数据迁移方法及相关设备 | |
CN113326155A (zh) | 一种信息处理方法、装置、系统和存储介质 | |
CN112685148B (zh) | 海量终端的异步通信方法、装置、计算机设备和存储介质 | |
CN106569892B (zh) | 资源调度方法与设备 | |
CN115794317B (zh) | 一种基于虚拟机的处理方法、装置、设备及介质 | |
CN110851276A (zh) | 一种业务请求处理方法、装置、服务器和存储介质 | |
CN114531602A (zh) | 基于动态资源释放的视频直播性能优化方法及装置 | |
WO2024156239A1 (zh) | 视频流传输方法、装置、电子设备及存储介质 | |
CN112306718B (zh) | 一种本地设备与异构设备之间的通信方法、系统及相关装置 | |
WO2021238259A1 (zh) | 一种数据传输方法、装置、设备及计算机可读存储介质 | |
CN102761545A (zh) | 服务处理方法、服务处理器及服务处理系统 | |
CN110515749B (zh) | 信息发送的队列调度的方法、装置、服务器和存储介质 | |
CN110245027B (zh) | 一种进程间通信的方法和设备 | |
CN111694670A (zh) | 资源分配方法、装置、设备和计算机可读介质 | |
CN112884382B (zh) | 云平台的资源配额管理方法、装置、设备以及存储介质 | |
CN111694672B (zh) | 资源分配方法、任务提交方法、装置、电子设备和介质 | |
JP2016505987A (ja) | アプリケーションプログラムの管理装置及び管理方法 | |
CN113722091A (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 |