WebRTC之每创建一个PeerConnection,都会创建两个线程

本文深入解析了RtpTransportControllerSend与Call类的构造过程,详细阐述了在构造函数中如何创建并调用ProcessThread,以及Call的创建过程中RtpTransportControllerSend的实例化方式。通过Call::Create函数,展示了如何在配置参数下生成Call对象,并初始化RtpTransportControllerSend。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  • 在RtpTransportControllerSend的构造函数中
process_thread_(ProcessThread::Create("SendControllerThread")),
  • 在Call的构造函数中,
module_process_thread_(ProcessThread::Create("ModuleProcessThread")),
  • 在这里调用
    • 分别调用了RtpTransportControllerSend的构造和Call的构造
Call* Call::Create(const Call::Config& config) {
  return new internal::Call(
      config, absl::make_unique<RtpTransportControllerSend>(
                  Clock::GetRealTimeClock(), config.event_log,
                  config.network_controller_factory, config.bitrate_config));
}
  • 其实是这个函数
    CreateCall_w

在这里插入图片描述

  • 调用过程是这里
rtc::scoped_refptr<PeerConnectionInterface>
PeerConnectionFactory::CreatePeerConnection(
    const PeerConnectionInterface::RTCConfiguration& configuration,
    PeerConnectionDependencies dependencies) {
    
  std::unique_ptr<Call> call = worker_thread_->Invoke<std::unique_ptr<Call>>(
      RTC_FROM_HERE,
      rtc::Bind(&PeerConnectionFactory::CreateCall_w, this, event_log.get()));
      
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值