基于live555单线程实现异步通信的方式,live555提供了两种异步通信的方式:一种是事件触发机制,可参考MAX_NUM_EVENT_TRIGGERS的定义或相关调用;另一种是递归。
事件触发的方式比较简单,不过live555里面触发的事件最多只能32个,当然,你也可以自己扩展,这里就不多讲了;今天要说的是递归,这个方式效率不高,很多公司的代码中甚至明文禁止使用递归,我估计这个也是live555经常被评估为不适合做服务器的原因吧!
使用递归来进行异步通信在live555中的一些例程中可以找到,不过可能很多同学还不会,所以这里简单讲一下;接着上一篇文章,如果我需要动态的异步查询rtsp代理服务器的前向url,怎么写代码?首先,不能阻塞,一阻塞live555就不工作了;基本流程就是:
1、在rtsp代理服务器收到 option或者describe消息后,通过解析的streamId,到第三方服务器上查询这个streamId的前向rtsp url,通常需要发送消息查询;
2、由于live555单线程不能被阻塞,但是又需要同步的等待查询响应消息,或者定时器超时回调或者消息,此时可以使用live555的递归调用,来等待异步响应。代码如下:
//支持代理实时流,这里通过本地服务器私有接口查询实时流url:共有四个超时定时器分别时长:2s->2.5s->3s->4s
/**播放代理实时流: rtsp://192.168.18.65/streamid_index/real?**/
sendGetUrlReq((char *)urlPreSuffix, token, beginTime, endTime, this);
times = 30;//最多等待3s时间获取设备URL
while(true) {
watchFlag = 0;
envir().taskScheduler().scheduleDelayedTask(usecsToDelay, (TaskFunc *)fOurRTSPServer.checkWatchFunc, (void *)&watchFlag);
envir().taskScheduler().doEventLoop(&watchFlag);
if(!times || fClientUrl || !fIsActive) {
break;