基于webrtc的资源释放问题(二)

时间:2022-07-02 08:14:34

基于webrtc的资源释放问题(二)

    ——建立连接的过程中意外中断

应用背景:

  我们在打电话的时候会不会遇到这种情况?打电话的时候未接通之前挂掉了电话,或者在接通之后建立的连接的过程中挂掉电话?

  特别是视频电话的时候,由于需要启动摄像头,所以不像语音电话那样启动的速度很快,以我的经验来看,启动摄像头分为两步:1、检查摄像头是否可用,2启动。这个过程大概需要3s。时间不可忽略不计,因此我的描述的场景一定会发生。

问题:

  在建立基于webrtc的视频通信的连接过程中,有一方终止(挂断电话),会出现程序崩溃泵(crash)。

解决办法:

  我仔细的追查过这个问题,这个崩溃主要是来自于native C++层 libjingle_peerconnection.so,顺便也找到了问题所在有一个指针的空引用的问题。

  我们遇到bug不能采取“头疼医头,脚疼医脚”的办法,这样会带来很多潜在的问题,出了问题更难找。

  我的方法如下:

    在建立连接的过程中遇到有一方挂断电话的情况,并不终止连接的建立,等到连接建立成功之后再终端连接。(经过我的测试,发现微信和qq都是采用这种策略)

  如何判断双方是否建立了连接?

    我的方法是当PeerConnection.IceConnectionState 变成CONNECTED的时候 就表示双方已经建立连接了(或许实际上并没有建立连接),这样释放webrtc的相关资源就不会遇到程序崩溃的情况。

有问题:576487833