webrtc原生API,如何使peerconnection以pcc拥塞控制运行

如题,请教一下各位大神,如何在peerconnection中配置拥塞控制算法为pcc,使其用pcc算法进行拥塞控制? 十分感谢!

c++
sinat_34717044
lucky-L 在createPeerconnectionFactory函数中配置,enable InjectedCongestion就可以了
9 个月之前 回复

2个回答

在createPeerconnectionFactory函数中配置,enable InjectedCongestion就可以了

sinat_34717044
lucky-L 你好,这个是demo的运行方式。 它的默认拥塞控制算法是GCC,我是想把拥塞控制算法替换为pcc
9 个月之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
webrtc 原生的js怎么调用AEC 消除回音模块
//获取音视频. function getUserMedia() { try { navigator.getUserMedia({ 'audio' : true, 'video' : pVideo }, onUserMediaSuccess, onUserMediaError); } catch (e) { try { navigator.getUserMedia("video,audio", onUserMediaSuccess, onUserMediaError); } catch (e) { alert(e.message); console.log(e); } } } //加载本地 视频 function onUserMediaSuccess(stream) { console.log("User has granted access to local media."); var url = URL.createObjectURL(stream); localVideo.style.opacity = 1; localVideo.src = url; localStream = stream; if (initiator) maybeStart(); } //创建 PeerConnection function createPeerConnection() { try { pc = new RTCPeerConnection(pc_config); pc.onicecandidate = onIceCandidate; } catch (e) { try { var stun_server = ""; if (pc_config.iceServers.length !== 0) { stun_server = pc_config.iceServers[0].url.replace('stun:', 'STUN '); } pc = new RTCPeerConnection(stun_server, onIceCandidate); isRTCPeerConnection = false; console.log("Created webkitPeerConnnection00 with config \"" + stun_server + "\"."); } catch (e) { alert("Failed to create PeerConnection, exception: " + e.message); return; } } pc.onconnecting = onSessionConnecting; pc.onopen = onSessionOpened; pc.onaddstream = onRemoteStreamAdded; pc.onremovestream = onRemoteStreamRemoved; } ``` ```
webrtc编译Android版本编译参数is_clang=false时,编译报错,is_clang=true时,编译成功。
[2274/3376] LINK ./rgba_to_i420_converter FAILED: rgba_to_i420_converter exe.unstripped/rgba_to_i420_converter python "../../build/toolchain/gcc_link_wrapper.py" --output="./rgba_to_i420_converter" --strip="../../buildtools/third_party/eu-strip/bin/eu-strip" --unstripped-file="./exe.unstripped/rgba_to_i420_converter" -- ../../third_party/llvm-build/Release+Asserts/bin/clang++ -Wl,--fatal-warnings -fPIC -Wl,-z,noexecstack -Wl,-z,relro -Wl,-z,now -Wl,-z,defs -Wl,--as-needed -fuse-ld=gold -Wl,--icf=all -Wl,--exclude-libs=libgcc.a -Wl,--exclude-libs=libvpx_assembly_arm.a --target=aarch64-linux-android -Wl,-mllvm,-enable-machine-outliner=never -Wl,--warn-shared-textrel -Wl,-O2 -Wl,--gc-sections -nodefaultlibs --sysroot=../../third_party/android_ndk/platforms/android-21/arch-arm64 -nostdlib -Wl,--warn-shared-textrel -pie -Bdynamic -Wl,-z,nocopyreloc -Wl,--dynamic-linker,/system/bin/linker64 -L../../third_party/android_ndk/sources/cxx-stl/llvm-libc++/libs/arm64-v8a -o "./exe.unstripped/rgba_to_i420_converter" -Wl,--start-group @"./rgba_to_i420_converter.rsp" -Wl,--end-group ../../third_party/android_ndk/platforms/android-21/arch-arm64/usr/lib/crtbegin_dynamic.o -lc -lgcc_s -lm -lrt -landroid_support ../../third_party/android_ndk/toolchains/aarch64-linux-android-4.9/prebuilt/linux-x86_64/lib/gcc/aarch64-linux-android/4.9.x/libgcc.a -ldl -llog -lGLESv2 ../../third_party/android_ndk/platforms/android-21/arch-arm64/usr/lib/crtend_android.o /usr/bin/ld.gold: fatal error: obj/rtc_tools/rgba_to_i420_converter/converter.o: unsupported ELF machine number 183 clang: error: linker command failed with exit code 1 (use -v to see invocation)
Webrtc如何添加进去x265编码器。编译上面如何编译
Webrtc如何添加进去x265编码器。编译上面如何编译,webrtc源码支持的是ffmpeg的h265解码,但是编码的话,总感觉自己用ninja编译不进去
关于如何在java客户端通过webrtc实现音频通话
求大神指教! 现在服务是好的,PC客户端需要通过webrtc与服务通讯,实现音频通话,求支撑库和DEMO。 网上都是需要自己下载编译,有没有拿来主义。 不要浏览器的。 当然,如果你能让它在java客户端运行也可以。
webrtc框架下得isac语音译码问题
看了了webrtc源代码的isac编译码程序,自己写了一个控制台程序,读取一个pcm int16的话音文件,然后用isac编码,最后译码,译码后语音明显有破音和过载,与原语音比较差异很明显,始终找不到原因,忘高手指教。以下是我写的源代码。 #include "stdafx.h" #include "isac.h" #include "utility.h" #include "math.h" #include "windows.h"; int _tmain(int argc, _TCHAR* argv[]) { ISACStruct* ISAC_main_inst; WebRtc_Word16 stream_len = 0; IsacSamplingRate sampFreqKHz = kIsacWideband; WebRtc_Word16 declen; WebRtc_Word16 speechType[1]; *speechType = 1; WebRtc_UWord16 payload[600]; WebRtc_Word16 decoded[1920]; WebRtc_Word16 decodeout[1920]; WebRtc_UWord16 payloadRCU[600]; WebRtc_Word16 rcuStreamLen = 0; int samplesIn10Ms = 160, cur_framesmpls = 0; const char Infilename[] = "D:\\matlab code\\fileout.pcm"; const char Outfilename[] = "D:\\matlab code\\fileout_decode.pcm"; FILE *filein, *fileout; short shortdata[160]; memset(shortdata, 0, 160); memset(decoded, 0, 1920); filein = fopen(Infilename, "r"); fileout = fopen(Outfilename, "w"); fclose(fileout); fileout = fopen(Outfilename, "a+"); //++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ int err = WebRtcIsac_Create(&ISAC_main_inst); WebRtcIsac_SetEncSampRate(ISAC_main_inst, (sampFreqKHz == 16) ? kIsacWideband : kIsacSuperWideband); WebRtcIsac_SetDecSampRate(ISAC_main_inst, (sampFreqKHz == 16) ? kIsacWideband : kIsacSuperWideband); //+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ fseek(filein, 0, SEEK_END); int fsize = ftell(filein); int samplenum = floor((double)fsize / 2); int blocknum = floor((double)samplenum / samplesIn10Ms/3); fseek(filein, 0, SEEK_SET); if (WebRtcIsac_DecoderInit(ISAC_main_inst) < 0) { printf("cannot initialize decoder\n"); return -1; } if (WebRtcIsac_EncoderInit(ISAC_main_inst, 0) < 0) { printf("cannot initialize encoder\n"); return -1; } if (WebRtcIsac_ControlBwe(ISAC_main_inst, 36000, 30, 1) < 0) { printf("cannot configure BWE\n"); return -1; } BottleNeckModel packetData; packetData.arrival_time = 0; packetData.sample_count = 0; packetData.rtp_number = 0; stream_len = 0; for (int i = 0; i < blocknum; i++) { cur_framesmpls = 0; stream_len = 0; fseek(filein, i*samplesIn10Ms * 3 * 2, SEEK_SET); //+++++++++++read file and encode while (stream_len == 0) { int k = 0; int size = fread(shortdata, sizeof(short), samplesIn10Ms, filein); k++; fseek(filein, i*samplesIn10Ms * 3 * 2 + samplesIn10Ms*2*k, SEEK_SET); cur_framesmpls += samplesIn10Ms; //-------- iSAC encoding --------- stream_len = WebRtcIsac_Encode(ISAC_main_inst, shortdata, (WebRtc_Word16*)payload); if (stream_len < 0) { // exit if returned with error //errType=WebRtcIsac_GetErrorCode(ISAC_main_inst); fprintf(stderr, "\nError in encoder\n"); getchar(); exit(EXIT_FAILURE); } } rcuStreamLen = WebRtcIsac_GetRedPayload(ISAC_main_inst, (WebRtc_Word16*)payloadRCU); //++++++++++++++test parameters++++++++ //WebRtc_Word32 sendbottleneck; //WebRtcIsac_GetUplinkBw(ISAC_main_inst, &sendbottleneck); //WebRtcIsac_UpdateUplinkBw(ISAC_main_inst, 9); WebRtc_Word16 bweindex, framelen; WebRtcIsac_ReadBwIndex((WebRtc_Word16*)payload, &bweindex); WebRtcIsac_UpdateUplinkBw(ISAC_main_inst, bweindex); WebRtcIsac_ReadFrameLen(ISAC_main_inst, (WebRtc_Word16*)payload, &framelen); //=========================updata bw======================================== //get_arrival_time(cur_framesmpls, 10000, 16000, &packetData, //sampFreqKHz * 1000, sampFreqKHz * 1000); /* /* if (WebRtcIsac_UpdateBwEstimate(ISAC_main_inst, payload, stream_len, 1, 0, 480) < 0) { printf(" BWE Error at client\n"); return -1; }*/ //======================= iSAC decoding =========================== declen = WebRtcIsac_Decode(ISAC_main_inst, payload, stream_len, decoded, speechType); if (declen <= 0) { //errType=WebRtcIsac_GetErrorCode(ISAC_main_inst); fprintf(stderr, "\nError in decoder.\n"); getchar(); exit(1); } //+++++++++++++++++++++write file to the out file /*for (int i = 0; i < declen; i++) { WebRtc_Word16 bit1 = (int16_t)decoded[i] >> 15 & 0x0001; WebRtc_Word16 bit2 = (int16_t)decoded[i] >> 13 & 0x0002; WebRtc_Word16 bit3 = (int16_t)decoded[i] >> 11 & 0x0004; WebRtc_Word16 bit4 = (int16_t)decoded[i] >> 9 & 0x0008; WebRtc_Word16 bit5 = (int16_t)decoded[i] >> 7 & 0x0010; WebRtc_Word16 bit6 = (int16_t)decoded[i] >> 5 & 0x0020; WebRtc_Word16 bit7 = (int16_t)decoded[i] >> 3 & 0x0040; WebRtc_Word16 bit8 = (int16_t)decoded[i] >> 1 & 0x0080; WebRtc_Word16 bit9 = (int16_t)decoded[i] <<1 & 0x0100; WebRtc_Word16 bit10 = (int16_t)decoded[i] <<3 & 0x0200; WebRtc_Word16 bit11 = (int16_t)decoded[i] << 5 & 0x0400; WebRtc_Word16 bit12 = (int16_t)decoded[i] << 7 & 0x0800; WebRtc_Word16 bit13 = (int16_t)decoded[i] << 9 & 0x1000; WebRtc_Word16 bit14 = (int16_t)decoded[i] << 11 & 0x2000; WebRtc_Word16 bit15 = (int16_t)decoded[i] << 13 & 0x4000; WebRtc_Word16 bit16 = (int16_t)decoded[i] << 15 & 0x8000; decodeout[i] = bit1 | bit2 | bit3 | bit4 | bit5 | bit6| bit7 | bit8 | bit9 | bit10 | bit11 | bit12| bit13 | bit14 | bit15 | bit16; }*/ fwrite(decoded, sizeof(WebRtc_Word16), declen, fileout); } fclose(filein); fclose(fileout); return 0; }
webrtc音视频通话,除了在华为手机上正常,其他手机均是远程视频黑屏情况
情况和问题描述: 最近在开发webrtc的音视频通话功能,本使用org.webrtc:google-webrtc:1.0.28513/这个版本开发,但是却发现远程视频显示不出来,过程没有任何报错,信令交互一切正常,我很疑惑,就将版本调整至org.webrtc:google-webrtc:1.0.24465@aar;让我惊喜的是在华为手机上正常了,远程和本地视频一切正常;但在1+、小米和红米等手机上无法正常显示出远程视频;本以为是没有video的candidate造成,但是经过华为手机反复测试和看log后发现,即使没有video的candidate都能正常显示出远程视频,所以我将这点给排除了;然后经过反反复复的测试和调整,华为手机只要不要用太新的webrtc版本就能正常,但其他手机均不正常;我在这个问题上已经纠结了两个星期,希望有大能能够帮助我。 这个问题实在很奇怪,没有报错,信令正常,交互正常,最终流能通,但就是无法显示远程视频;是解析的问题呢,还是渲染的问题,还是其他问题。很疑惑了,希望业界大佬指教!!! 正常截图: ![图片说明](https://img-ask.csdn.net/upload/201909/17/1568702658_848334.jpg) 异常截图: ![图片说明](https://img-ask.csdn.net/upload/201909/17/1568702684_763667.jpg) 然后经过log的反复查看,发现了以下的一个log,怀疑也可能有关系,本人webrtc小白,贴出讨论,虚心请教 ![图片说明](https://img-ask.csdn.net/upload/201909/17/1568702792_787513.png)
webrtc理论上是看了个大概可是不知怎么着手?
我已经大概在webrtc中文网看了一下内容: 在webrtc中SDP是用于交互多媒体流信息的最小不接去除单位 _____________________________________________________________________________ webrtc是先定位两个人的位置,然后两个人都跳到同一个链接里面进行数据互通。信令结束以后,就不需要web服务器在中间传递数据。 编解编码器的功能是压缩和解压音频和视频数据。 还有实现设备间的信息互通,可能需要中继TURN服务器,因为可能因为对方的防火墙和NAT和限制了(隐藏了IP地址或者)用于通信的洞,所以只好在通话的时候进行ICE协商。就是发起者这边发了一个offer,有关怎么找到要准备进行通话的小伙伴的方法。然后,将这个数据给到服务器,然后服务器再给到那个小伙伴,然后那个小伙伴就可以通过设备找到发起人,然后就可以开始设备之间的互通,而不需要服务器在中间传递数据。 webrtc 三大API getUserMedia PeerConnection Data Channel getUserMedia 应用: #为用户文件档案拍照 #录制语音数据,并将数据发送到语音转文字引擎 #为用户录制语音或者视频,而且在掉包的情况下能保证语音及视频的质量不下滑 webrtc实例 https://www.jianshu.com/p/57fd3b5d2f80 Peer Connection #生成并传递SDP (不是通过网络本身传递,而是生成他们并处理输入的消息) #对音视频进行压缩和解压 #通过回声消除算法处理语音 #丢包隐藏,数据重传,抖动缓存区,估计宽带等功能 Data Channel #信息传输的通道,设置通道是否可靠,设置可靠则可以自动重传。 #通道设计类似于websocketAPI界别的通道,所以可以用websocket的想法去看待它。 #通道设计类似于在websocketAPI级别上工作,所以可以用websocket的思考法式对待它。 想要一个webrtc的应用的实现方法,有以下几点: 1.客户端 2.信道 3.NAT 4.媒体 1.客户端 浏览器端使用javasrcipt进行开发,或者用框架,或者很多人都是直接从github上开始的。 如果是软件的话,应该挑选合适的sdk。 如果是pc,则使用psdn或者嵌入式的方法进行开发。 如果是pc的话,则可以用Electron进行完成,说着用嵌入式的方式完成。 2.信道 你需要一个新到服务器,当然也可以不要。在用之前,你必须检查你的服务器是否有信道机制用于 非webrtc上。如果有,你可以在这些机制上搭载sdp消息和其他webrtc信令。 3.NAT 一下是你不应该做的: #不用trun服务器 #不用公共服务器 #不用stun公共服务器 #所有服务都在同一个服务器上实现 #不要一上来就想布置世界级的全球服务网络。 以下是你应该做的: #部署stun和turn在同一进程 #stun和turn应该在同一个服务器上部署,而且要部署到同一进程中。 #用coturn,几乎所有人都在使用。 #你也可以从其他公司获取NAT服务,例如XirSys和T willio也是不错的选择。 4.媒体 如果你使用pstn或者视频会议,音频或者更高级的功能,建议使用一个媒体服务器。 现在市面和商业服务器有很多,他们在很很多方面是有区别的。 现在开源和商业的服务器有很多,他们在很多方面都是有区别的。 webrtc使用领域前瞻 1.机器学习和人工智能 2.在线学习 3.在线医疗 4.社交媒体 webrtc打洞就是将交换数据双方ip,port和nat信息通过信令服务器进行交互,然后双方各自获得对方的信息后就进行穿透,stun对p2p依然后有问题,所以还需要用到ICE。然后libjingle就是ICE思想的具体实现。 _____________________________________________________________________________ 但是我不知道怎么着手去弄,信令服务器我查了,没有说买信令服务器的,都是说配置的。所以我不知怎么做了?希望有哪位老师指点一下。感激不尽!
做一个TURNSERVER穿透服务器
我想做一个NAT穿透,用COTURN搭建一个TURNSERVER,配合WEBRTC使用,我现在的方法搭建TURNSERVER的话,都会有一个问题,就是连接不稳定,隔段时间就会无法连接,必须重启本地才能连接。而且不支持移动网络。我基本是门外汉,所以付费求助。https://docs.unrealengine.com/zh-CN/Platforms/PixelStreaming/Hosting/index.html这个是具体需求,软件的文档,大家看一下,如果可以帮忙做,要积分或者RMB都可以商量。加微信15077118199或者直接回答都可以
webrtc做一个简单的视屏通话Demo用tomcat服务器
现在webrtc开发用什么工具,环境部署怎样的,用什么语言nodejs? 可以推荐学习webrtc好的网站 有源码demo的
webrtc的一些问题,有没有大佬帮忙提供下方法?
现在有个需求是:固话的模拟信号转换为数字信号,然后通过webrtc接入传输到网页,实现固话和网页的通讯。有没有大佬提供下思路啊,webrtc怎么接入转换后的数字信号呢?其中实现通讯还需要哪些技术呢?
WebRTC库在Android端声音问题
我使用webRTC库开发音视频聊天app,运行成功后图像能够联通,但是没有声音或者声音小 AudioSource audioSource = factory.createAudioSource(new MediaConstraints()); localMS.addTrack(factory.createAudioTrack("ARDAMSa0", audioSource));
Delphi 使用Dcef3开通Webrtc
请问Delphi 使用Dcef3的控件如何开通webrtc功能呢
Android使用Webrtc进行降噪增益,如何适配64位so
Android使用Webrtc进行降噪增益编译成32位so测试正常,但是编译64位so报错,arm64-v8a的so文件报错,是需要64位的源码编译吗还是需要改什么东西,附错误信息,急求大神解答。 *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** 2019-05-21 17:21:06.190 13887-13887/? A/DEBUG: Build fingerprint: 'Nokia/Panda_00CN/PDA:9/PPR1.180610.011/00CN_2_15B:user/release-keys' 2019-05-21 17:21:06.190 13887-13887/? A/DEBUG: Revision: '0' 2019-05-21 17:21:06.190 13887-13887/? A/DEBUG: ABI: 'arm64' 2019-05-21 17:21:06.190 13887-13887/? A/DEBUG: pid: 12202, tid: 13878, name: Thread-35 >>> com.xx.xx<<< 2019-05-21 17:21:06.190 13887-13887/? A/DEBUG: signal 11 (SIGSEGV), code 1 (SEGV_MAPERR), fault addr 0x5b5cb298 2019-05-21 17:21:06.190 13887-13887/? A/DEBUG: x0 000000005b5cb294 x1 0000000000000003 x2 00000000000000ff x3 0000000000000003 2019-05-21 17:21:06.191 13887-13887/? A/DEBUG: x4 0000000000001f40 x5 0000000000000003 x6 0000000000001f40 x7 0000000000000000 2019-05-21 17:21:06.191 13887-13887/? A/DEBUG: x8 0000000000000003 x9 0000000008000000 x10 0000000000430000 x11 0000007183dfc688 2019-05-21 17:21:06.191 13887-13887/? A/DEBUG: x12 0000007209bb8410 x13 dff7b546ac046781 x14 0000007206b68000 x15 0000007206b68000 2019-05-21 17:21:06.191 13887-13887/? A/DEBUG: x16 000000715ae2cc88 x17 000000715ae09e7c x18 0000000000000000 x19 000000005b5cb100 2019-05-21 17:21:06.191 13887-13887/? A/DEBUG: x20 0000000000000000 x21 00000000000000ff x22 0000000000001f40 x23 0000000000000003 2019-05-21 17:21:06.191 13887-13887/? A/DEBUG: x24 0000000000000018 x25 0000007159f2a588 x26 000000714082b4a0 x27 0000000000000001 2019-05-21 17:21:06.191 13887-13887/? A/DEBUG: x28 0000000000000000 x29 0000007159f28ee0 2019-05-21 17:21:06.191 13887-13887/? A/DEBUG: sp 0000007159f28eb0 lr 000000715ae08da0 pc 000000715ae09e84 2019-05-21 17:21:06.262 413-9844/? E/AudioALSAPlaybackHandlerBase: -getHardwareBufferInfo(), pcm_get_htimestamp fail, ret = -1, pcm_get_error = 2019-05-21 17:21:06.263 13887-13887/? A/DEBUG: backtrace: 2019-05-21 17:21:06.263 13887-13887/? A/DEBUG: #00 pc 0000000000006e84 /data/app/com.xx.xx-U5O1pzNUtbiwoTPGd6O-UA==/split_config.arm64_v8a.apk (offset 0x1c000) (WebRtcAgc_InitDigital+8) 2019-05-21 17:21:06.263 13887-13887/? A/DEBUG: #01 pc 0000000000005d9c /data/app/com.xx.xx-U5O1pzNUtbiwoTPGd6O-UA==/split_config.arm64_v8a.apk (offset 0x1c000) (WebRtcAgc_Init+48) 2019-05-21 17:21:06.263 13887-13887/? A/DEBUG: #02 pc 0000000000033534 /data/app/com.xx.xx-U5O1pzNUtbiwoTPGd6O-UA==/oat/arm64/base.odex (offset 0x33000) (com.xx.xx.util.AgcNsUtils.init+164) 2019-05-21 17:21:06.263 13887-13887/? A/DEBUG: #03 pc 000000000055cd88 /system/lib64/libart.so (art_quick_invoke_stub+584) 2019-05-21 17:21:06.263 13887-13887/? A/DEBUG: #04 pc 00000000000cf740 /system/lib64/libart.so (art::ArtMethod::Invoke(art::Thread*, unsigned int*, unsigned int, art::JValue*, char const*)+200) 2019-05-21 17:21:06.263 13887-13887/? A/DEBUG: #05 pc 00000000002823b8 /system/lib64/libart.so (art::interpreter::ArtInterpreterToCompiledCodeBridge(art::Thread*, art::ArtMethod*, art::ShadowFrame*, unsigned short, art::JValue*)+344) 2019-05-21 17:21:06.263 13887-13887/? A/DEBUG: #06 pc 000000000027d480 /system/lib64/libart.so (bool art::interpreter::DoCall<true, false>(art::ArtMethod*, art::Thread*, art::ShadowFrame&, art::Instruction const*, unsigned short, art::JValue*)+752) 2019-05-21 17:21:06.263 13887-13887/? A/DEBUG: #07 pc 000000000052fa0c /system/lib64/libart.so (MterpInvokeVirtualQuickRange+420) 2019-05-21 17:21:06.263 13887-13887/? A/DEBUG: #08 pc 0000000000553194 /system/lib64/libart.so (ExecuteMterpImpl+30100) 2019-05-21 17:21:06.263 13887-13887/? A/DEBUG: #09 pc 00000000002146b8 /data/app/com..xx.xx-U5O1pzNUtbiwoTPGd6O-UA==/oat/arm64/base.vdex (com.xx.xx.AgcNsUtils.prepare+44) 2019-05-21 17:21:06.263 13887-13887/? A/DEBUG: #10 pc 0000000000255e70 /system/lib64/libart.so (_ZN3art11interpreterL7ExecuteEPNS_6ThreadERKNS_20CodeItemDataAccessorERNS_11ShadowFrameENS_6JValueEb.llvm.1181525464+496) 2019-05-21 17:21:06.263 13887-13887/? A/DEBUG: #11 pc 000000000025b9f0 /system/lib64/libart.so (art::interpreter::ArtInterpreterToInterpreterBridge(art::Thread*, art::CodeItemDataAccessor const&, art::ShadowFrame*, art::JValue*)+216) 2019-05-21 17:21:06.263 13887-13887/? A/DEBUG: #12 pc 000000000027c358 /system/lib64/libart.so (bool art::interpreter::DoCall<false, false>(art::ArtMethod*, art::Thread*, art::ShadowFrame&, art::Instruction const*, unsigned short, art::JValue*)+920) 2019-05-21 17:21:06.263 13887-13887/? A/DEBUG: #13 pc 000000000052f6f0 /system/lib64/libart.so (MterpInvokeVirtualQuick+584) 2019-05-21 17:21:06.263 13887-13887/? A/DEBUG: #14 pc 0000000000553114 /system/lib64/libart.so (ExecuteMterpImpl+29972) 2019-05-21 17:21:06.263 13887-13887/? A/DEBUG: #15 pc 00000000002bc446 /data/app/.xx.xx-U5O1pzNUtbiwoTPGd6O-UA==/oat/arm64/base.vdex (com.xx.xx.AudioRecorder.a+26) 2019-05-21 17:21:06.263 13887-13887/? A/DEBUG: #16 pc 0000000000255e70 /system/lib64/libart.so (_ZN3art11interpreterL7ExecuteEPNS_6ThreadERKNS_20CodeItemDataAccessorERNS_11ShadowFrameENS_6JValueEb.llvm.1181525464+496) 2019-05-21 17:21:06.263 13887-13887/? A/DEBUG: #17 pc 000000000025b9f0 /system/lib64/libart.so (art::interpreter::ArtInterpreterToInterpreterBridge(art::Thread*, art::CodeItemDataAccessor const&, art::ShadowFrame*, art::JValue*)+216) 2019-05-21 17:21:06.264 13887-13887/? A/DEBUG: #18 pc 000000000027c358 /system/lib64/libart.so (bool art::interpreter::DoCall<false, false>(art::ArtMethod*, art::Thread*, art::ShadowFrame&, art::Instruction const*, unsigned short, art::JValue*)+920) 2019-05-21 17:21:06.264 13887-13887/? A/DEBUG: #19 pc 000000000052d9e0 /system/lib64/libart.so (MterpInvokeDirect+296) 2019-05-21 17:21:06.264 13887-13887/? A/DEBUG: #20 pc 000000000054f494 /system/lib64/libart.so (ExecuteMterpImpl+14484) 2019-05-21 17:21:06.264 13887-13887/? A/DEBUG: #21 pc 00000000002bc388 /data/app/com.allinone.callerid-U5O1pzNUtbiwoTPGd6O-UA==/oat/arm64/base.vdex (com.allinone.callerid.util.recorder.AudioRecorder.a) 2019-05-21 17:21:06.264 13887-13887/? A/DEBUG: #22 pc 0000000000255e70 /system/lib64/libart.so (_ZN3art11interpreterL7ExecuteEPNS_6ThreadERKNS_20CodeItemDataAccessorERNS_11ShadowFrameENS_6JValueEb.llvm.1181525464+496) 2019-05-21 17:21:06.264 13887-13887/? A/DEBUG: #23 pc 000000000025b9f0 /system/lib64/libart.so (art::interpreter::ArtInterpreterToInterpreterBridge(art::Thread*, art::CodeItemDataAccessor const&, art::ShadowFrame*, art::JValue*)+216) 2019-05-21 17:21:06.264 13887-13887/? A/DEBUG: #24 pc 000000000027c358 /system/lib64/libart.so (bool art::interpreter::DoCall<false, false>(art::ArtMethod*, art::Thread*, art::ShadowFrame&, art::Instruction const*, unsigned short, art::JValue*)+920) 2019-05-21 17:21:06.264 13887-13887/? A/DEBUG: #25 pc 000000000052dba4 /system/lib64/libart.so (MterpInvokeStatic+204) 2019-05-21 17:21:06.264 13887-13887/? A/DEBUG: #26 pc 000000000054f514 /system/lib64/libart.so (ExecuteMterpImpl+14612) 2019-05-21 17:21:06.264 13887-13887/? A/DEBUG: #27 pc 00000000002bbfe8 /data/app/com.allinone.callerid-U5O1pzNUtbiwoTPGd6O-UA==/oat/arm64/base.vdex (com.allinone.callerid.util.recorder.e.run+12) 2019-05-21 17:21:06.264 13887-13887/? A/DEBUG: #28 pc 0000000000255e70 /system/lib64/libart.so (_ZN3art11interpreterL7ExecuteEPNS_6ThreadERKNS_20CodeItemDataAccessorERNS_11ShadowFrameENS_6JValueEb.llvm.1181525464+496) 2019-05-21 17:21:06.264 13887-13887/? A/DEBUG: #29 pc 000000000051cde0 /system/lib64/libart.so (artQuickToInterpreterBridge+1032) 2019-05-21 17:21:06.264 13887-13887/? A/DEBUG: #30 pc 0000000000565efc /system/lib64/libart.so (art_quick_to_interpreter_bridge+92) 2019-05-21 17:21:06.264 13887-13887/? A/DEBUG: #31 pc 000000000025cfa8 /system/framework/arm64/boot.oat (offset 0x114000) (java.lang.Thread.run+72) 2019-05-21 17:21:06.264 13887-13887/? A/DEBUG: #32 pc 000000000055cd88 /system/lib64/libart.so (art_quick_invoke_stub+584) 2019-05-21 17:21:06.264 13887-13887/? A/DEBUG: #33 pc 00000000000cf740 /system/lib64/libart.so (art::ArtMethod::Invoke(art::Thread*, unsigned int*, unsigned int, art::JValue*, char const*)+200) 2019-05-21 17:21:06.264 13887-13887/? A/DEBUG: #34 pc 00000000004633d0 /system/lib64/libart.so (art::(anonymous namespace)::InvokeWithArgArray(art::ScopedObjectAccessAlreadyRunnable const&, art::ArtMethod*, art::(anonymous namespace)::ArgArray*, art::JValue*, char const*)+104) 2019-05-21 17:21:06.264 13887-13887/? A/DEBUG: #35 pc 0000000000464498 /system/lib64/libart.so (art::InvokeVirtualOrInterfaceWithJValues(art::ScopedObjectAccessAlreadyRunnable const&, _jobject*, _jmethodID*, jvalue*)+424) 2019-05-21 17:21:06.264 13887-13887/? A/DEBUG: #36 pc 000000000048f808 /system/lib64/libart.so (art::Thread::CreateCallback(void*)+1120) 2019-05-21 17:21:06.264 13887-13887/? A/DEBUG: #37 pc 0000000000083114 /system/lib64/libc.so (__pthread_start(void*)+36) 2019-05-21 17:21:06.264 13887-13887/? A/DEBUG: #38 pc 00000000000233bc /system/lib64/libc.so (__start_thread+68) 2019-05-21 17:21:06.455 413-9844/? E/AudioALSAPlaybackHandlerBase: -getHardwareBufferInfo(), pcm_get_htimestamp fail, ret = -1, pcm_get_error =
webRTC在本机部署后,无法看到本地画面
在本机部署了webRTC,刚开始在本地浏览器看到的是本地的画面,当另外一台电脑打开我发送的链接后,我们相互能看到对方的画面,但是看不到本地的,请教大神是为什么,该怎么解决??
webrtc音频采集传输问题
phonertc或者webrtc在安卓机顶盒上采集到的声音,传给对方,对方听不到或者声音断断续续
使用WebRTC的DataChannel代替WebSocket来做终端的数据传输的可行性如何?
使用WebRTC的DataChannel 代替 WebSocket 来做 终端的数据传输的可行性? 比如像聊天内容推送(或 那些实时更新率极高,并且需要保证传输可靠 的 数据),原来是通过 WebSocket 来实现的,就是客户端推到Socket服务器,Socket 服务器广播到 所有终端上。现在想换成直接用 WebRTC的DataChannel 来实现这类似的数据传输工作。但听说这个传输可靠性不高,求验证。
用JAVA、wevService、webRTC实现网页版的视频通话
如题:用JAVA、wevService、webRTC实现网页版的视频通话 有木有哪位大神有源码,小弟现在急需啊 有的话可以发我邮箱 15116285761@163.com
webRTC手机端视频保存到本地
目前我有一个需求,希望通过浏览器的方式录视频、音频并且保存在本地,需求的代码原型地址: https://www.webrtc-experiment.com/RecordRTC/,目前在PC端(FireFox)已经可以完全实现相关需求, 当我在手机端(FirxFox + 安卓)使用时只保存了音频,视频流丢失。各位大神,能指点一下方向,调了好久都没有找到问题所在。感谢!
sipml5 webrtc媒体流拒绝
sipml5发布到tomcat服务器上拨打不了电话,显示媒体流被拒绝,但是在本地各个功能都没问题,请问各位什么原因
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过...
前端 | 2. 正则
转载请注明以下: 本文转自清自以敬的博客:https://blog.csdn.net/qq_45791147 文章目录1.转义2.正则表达式初步2.1.匹配字符2.1.1.组成元素2.1.2.基础正则的设计 1.转义 转义的作用: 当某个字符在表达式中具有特殊含义,例如字符串引号中出现了引号,为了可以使用这些字符本身,而不是使用其在表达式中的特殊含义,则需要通过转义符“\”来构建该字符转义...
有哪些让程序员受益终生的建议
从业五年多,辗转两个大厂,出过书,创过业,从技术小白成长为基层管理,联合几个业内大牛回答下这个问题,希望能帮到大家,记得帮我点赞哦。 敲黑板!!!读了这篇文章,你将知道如何才能进大厂,如何实现财务自由,如何在工作中游刃有余,这篇文章很长,但绝对是精品,记得帮我点赞哦!!!! 一腔肺腑之言,能看进去多少,就看你自己了!!! 目录: 在校生篇: 为什么要尽量进大厂? 如何选择语言及方...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 free -m 其中:m表示兆,也可以用g,注意都要小写 Men:表示物理内存统计 total:表示物理内存总数(total=used+free) use...
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入 假设现有4个人...
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发...
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 演示地点演示 html代码如下` music 这个年纪 七月的风 音乐 ` 然后就是css`*{ margin: 0; padding: 0; text-decoration: none; list-...
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。
数据库优化 - SQL优化
以实际SQL入手,带你一步一步走上SQL优化之路!
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 cpp 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7 p...
通俗易懂地给女朋友讲:线程池的内部原理
餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小型人工智障。 知识可以运用在不同地方,不一定非是天气预报。
经典算法(5)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹...
面试官:你连RESTful都不知道我怎么敢要你?
干货,2019 RESTful最贱实践
Docker 从入门到掉坑
Docker 介绍 简单的对docker进行介绍,可以把它理解为一个应用程序执行的容器。但是docker本身和虚拟机还是有较为明显的出入的。我大致归纳了一下,可以总结为以下几点: docker自身也有着很多的优点,关于它的优点,可以总结为以下几项: 安装docker 从 2017 年 3 月开始 docker 在原来的基础上分为两个分支版本: Docker CE 和 Doc...
为啥国人偏爱Mybatis,而老外喜欢Hibernate/JPA呢?
关于SQL和ORM的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行了一番讨论,感触还是有一些,于是就有了今天这篇文。 声明:本文不会下关于Mybatis和JPA两个持久层框架哪个更好这样的结论。只是摆事实,讲道理,所以,请各位看官勿喷。 一、事件起因 关于Mybatis和JPA孰优孰劣的问题,争论已经很多年了。一直也没有结论,毕竟每个人的喜好和习惯是大不相同的。我也看...
白话阿里巴巴Java开发手册高级篇
不久前,阿里巴巴发布了《阿里巴巴Java开发手册》,总结了阿里巴巴内部实际项目开发过程中开发人员应该遵守的研发流程规范,这些流程规范在一定程度上能够保证最终的项目交付质量,通过在时间中总结模式,并推广给广大开发人员,来避免研发人员在实践中容易犯的错误,确保最终在大规模协作的项目中达成既定目标。 无独有偶,笔者去年在公司里负责升级和制定研发流程、设计模板、设计标准、代码标准等规范,并在实际工作中进行...
SQL-小白最佳入门sql查询一
不要偷偷的查询我的个人资料,即使你再喜欢我,也不要这样,真的不好;
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
Nginx 原理和架构
Nginx 是一个免费的,开源的,高性能的 HTTP 服务器和反向代理,以及 IMAP / POP3 代理服务器。Nginx 以其高性能,稳定性,丰富的功能,简单的配置和低资源消耗而闻名。 Nginx 的整体架构 Nginx 里有一个 master 进程和多个 worker 进程。master 进程并不处理网络请求,主要负责调度工作进程:加载配置、启动工作进程及非停升级。worker 进程负责处...
Python 编程开发 实用经验和技巧
Python是一门很灵活的语言,也有很多实用的方法,有时候实现一个功能可以用多种方法实现,我这里总结了一些常用的方法和技巧,包括小数保留指定位小数、判断变量的数据类型、类方法@classmethod、制表符中文对齐、遍历字典、datetime.timedelta的使用等,会持续更新......
YouTube排名第一的励志英文演讲《Dream(梦想)》
Idon’t know what that dream is that you have, I don't care how disappointing it might have been as you've been working toward that dream,but that dream that you’re holding in your mind, that it’s po...
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,...
程序员:我终于知道post和get的区别
是一个老生常谈的话题,然而随着不断的学习,对于以前的认识有很多误区,所以还是需要不断地总结的,学而时习之,不亦说乎
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU...
程序员把地府后台管理系统做出来了,还有3.0版本!12月7号最新消息:已在开发中有github地址
第一幕:缘起 听说阎王爷要做个生死簿后台管理系统,我们派去了一个程序员…… 996程序员做的梦: 第一场:团队招募 为了应对地府管理危机,阎王打算找“人”开发一套地府后台管理系统,于是就在地府总经办群中发了项目需求。 话说还是中国电信的信号好,地府都是满格,哈哈!!! 经常会有外行朋友问:看某网站做的不错,功能也简单,你帮忙做一下? 而这次,面对这样的需求,这个程序员...
网易云6亿用户音乐推荐算法
网易云音乐是音乐爱好者的集聚地,云音乐推荐系统致力于通过 AI 算法的落地,实现用户千人千面的个性化推荐,为用户带来不一样的听歌体验。 本次分享重点介绍 AI 算法在音乐推荐中的应用实践,以及在算法落地过程中遇到的挑战和解决方案。 将从如下两个部分展开: AI算法在音乐推荐中的应用 音乐场景下的 AI 思考 从 2013 年 4 月正式上线至今,网易云音乐平台持续提供着:乐屏社区、UGC...
相关热词 c# 图片上传 c# gdi 占用内存 c#中遍历字典 c#控制台模拟dos c# 斜率 最小二乘法 c#进程延迟 c# mysql完整项目 c# grid 总行数 c# web浏览器插件 c# xml 生成xsd
立即提问