WebRTC线程的启动与运行

WebRTC线程运行的基本逻辑:

cpp 复制代码
while(true)
{
	...
	Get(&msg, ...);
	...
	Dispatch(&msg);
	...
}

Dispatch(Message *pmsg) {
	...
	pmsg->handler->OnMessage(pmsg);
	...
}

在执行函数内部,就是一个while死循环,只做两件事,从队列里Get取出消息,然后调用Dispatch处理消息。

在Dispatch函数中会调用入参*pmsg消息的handler的OnMessage处理消息,

具体如何处理消息,每一个pmsg内部有不同的逻辑,

就是把控制权交给的发送线程,发送线程在执行时它是知道需要做什么事的,但是这个事情需要交给其他的线程来做,

但是执行线程是不知道发送线程要执行怎样的逻辑,那么最好的方法就是发送线程将执行的逻辑写好,执行线程只要按照发送线程的要求去执行任务就OK了。

【编程思想】

因此,要弄明白正在处理的业务逻辑,必须要从发送线程着手,而不是工作线程,因为工作线程并不清楚它在做什么。

WebRTC中的具体代码实现:

cpp 复制代码
// src/rtc_base/thread.cc
Thread::Start() {
	pthread_ = pthread_create(PreRun);
}

Thread::PreRun() {
	Thread *thread = static_cast<>();
	ThreadManager::Instance()->SetCurrentThread(thread); // 将本线程设置到ThreadManager中,与Thread对象进行绑定,这也说明绑定的时机是在pthread创建成功之后
	thread->Run();
}

Thread::Run() {
	ProcessMessages(kForever);
}

Thread::ProcessMessages() {
	while(true) {
		Get(&msg);
		Dispatch(&msg);
	}
}

Thread::Dispatch(Message *pmsg) {
	pmsg->handler->OnMessage(pmsg);
}
相关推荐
每日出拳老爷子17 分钟前
【浏览器方案】只用浏览器访问的内网会议系统设计思路(无客户端)
运维·服务器·webrtc·实时音视频·流媒体
softshow10263 天前
Vue3 :封装 WebRTC 低延迟视频流与 WebSocket 实时状态驱动的大屏可视化
websocket·网络协议·webrtc
雨落秋垣5 天前
大屏可视化系统:WebRTC视频流与WebSocket实时数据集成方案
websocket·网络协议·webrtc
此颜差矣。6 天前
封装 WebRTC 低延迟视频流与 WebSocket 实时状态驱动的大屏可视化
websocket·webrtc·低延迟视频流
metaRTC6 天前
metaRTC 8.0 重磅发布:专为新一代 AI 终端而生的实时通信引擎
ai·webrtc
三十_A9 天前
WebRTC 入门:一分钟理解会议系统的三种架构(Mesh/SFU/MCU)
架构·webrtc
qq_3106585110 天前
webrtc源码走读(五)核心引擎层——传输模块
服务器·网络·音视频·webrtc
三十_10 天前
WebRTC 入门:一分钟理解会议系统的三种架构(Mesh/SFU/MCU)
前端·后端·webrtc
qq_3106585110 天前
webrtc源码走读(六)核心引擎层——安全模块
服务器·c++·音视频·webrtc