基于webrtc的资源释放问题(一)
——重复释放webrtc的相关资源
背景:
视频通讯大都只是作为一个功能存在于各种应用中,比如微信,qq 。既然只是应用的一部分,这样就涉及反复的开启和关闭视频通信的功能的问题了,那么对于基于webrtc的通信功能来说,就涉及到了反复的获取和释放webrtc相关的资源的问题了,本博文的目的就是说说这个过程中会遇到的问题。
最近一段时间在做基于webrtc的android应用在释放资源时遇到一些问题,现在记录下来用于备忘。
官方给出的AppRTCDemo太过于简单很多问题没涉及到。
1、释放peerconnection资源的问题。
场景:A和B进行通话(视频通话)
现在B中终止通话
错误:在B终止通话之后,A端的程序程序会意外退出。
分析:在A和B进行通话的时候会见了相应的PeerConnection类实例,这个实例保存的有stream的引用(localstream和remote stream等等)。
B在终止通话时就要释放和A进行通话时建立的PeerConnection类的实例.这时候就会出现问题,A在释放peerconnection实例的时候会把localstream给释放掉,而localstream自己还在使用,这时候程序就会意外终止。
解决办法:在是放peerconnection实例的时候不要释放本地的localstream只释放remote stream。单独定义事件来触发localstream的释放。
2、释放整个webrtc模块的问题。
场景:A和B进行通话,B终止通话,B再进行视频通话
错误:B再次进行视频通话的时候意外终止
分析:B再次进行视频通话的时候,由于上次退出视频通话的时候camera资源没有释放,但是再次进行视屏通话的时候无法获得camera资源。
这里看似是没有获得camera资源的问题,其实是我们在使用完webrtc资源之后没有及时释放的问题。
解决办法:真确的释放相应的资源,我的步骤如下:
1、挂断所有正在通信的视频通话(hangupall())(释放peerconnection实例)
2、释放localstream
3、释放camera资源(VideoSource.dispose() 方法)
4、释放PeerConnectionFactory资源
即使是这样在我频繁的打开和关闭视频通话的时候程序仍然会有一定的概率会出错。希望各位能够帮忙纠正我的错误。