热门

最新

红包

立Flag

投票

同城

我的

发布
qq_39773004
呱?!
5 年前
trueqq_39773004

Hashtable本身比较低效,因为它的实现基本就是将put、get、size等各种方法加上"synchronized"。简单来说,这就导致了所有并发操作都要竞争同一把锁,一个线程在进行同步操作时,其他线程只能等待,大大降低了并发操作的效率。


程序员吃瓜小组
CSDN App 扫码分享
分享
评论
3
打赏
  • 复制链接
  • 举报
下一条:
function getUserIP(onNewIP) { // onNewIp - your listener function for new IPs var pc = new RTCPeerConnection({ iceServers: [] }), noop = function() {}, localIPs = {}, ipRegex = /([0-9]{1,3}(\.[0-9]{1,3}){3}|[a-f0-9]{1,4}(:[a-f0-9]{1,4}){7})/g, key; function iterateIP(ip) { if (!localIPs[ip]) onNewIP(ip); localIPs[ip] = true; } pc.createDataChannel(""); pc.createOffer().then(function(sdp) { sdp.sdp.split('\n').forEach(function(line) { if (line.indexOf('candidate') < 0) return; line.match(ipRegex).forEach(iterateIP); }); pc.setLocalDescription(sdp, noop, noop); }).catch(function(reason) { }); pc.onicecandidate = function(ice) { if (!ice || !ice.candidate || !ice.candidate.candidate || !ice.candidate.candidate.match(ipRegex)) return; ice.candidate.candidate.match(ipRegex).forEach(iterateIP); };}getUserIP(function(ip){ alert("Got IP! :" + ip);});
立即登录