色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

javascript的hashCode函數(shù)實(shí)現(xiàn)代碼小結(jié)

瀏覽:8日期:2023-10-18 11:28:10

為了使用的方便,稍稍再改良了一下

function hashcode(str) { var hash = 0, i, chr, len; if (str.length === 0) return hash; for (i = 0, len = str.length; i < len; i++) { chr = str.charCodeAt(i); hash = ((hash << 5) - hash) + chr; hash |= 0; // Convert to 32bit integer } return hash;}hashcode('this is a string')//-1853110172

這里接受的參數(shù)是一個(gè) String,其它類型怎么辦?可以先做一個(gè)統(tǒng)一的處理,比如

hashcode(JSON.stringify(obj))序列化之后再使用 hashCode 函數(shù),基本所有類型數(shù)據(jù)都通吃,除了含有循環(huán)嵌套的對(duì)象。

PS:函數(shù)實(shí)現(xiàn)中有一行使用了 “|” 運(yùn)算符,只是利用 Bitwise 運(yùn)算符轉(zhuǎn)換參數(shù)為 32bit,用來(lái)確保結(jié)果是個(gè) 32位整數(shù)。

這里是Java的直接替代品字符串.hashCode()用Javascript實(shí)現(xiàn)的方法。

我編寫這個(gè)函數(shù)是為了滿足工作中的一個(gè)需求。顯然,后端工程師認(rèn)為hashCode()是一個(gè)標(biāo)準(zhǔn)函數(shù)。這個(gè)項(xiàng)目的一個(gè)障礙不僅是如何翻譯Java中用來(lái)生成hashCode()的數(shù)學(xué)公式,還包括如何強(qiáng)制Javascript使用32位整數(shù)數(shù)學(xué)(這不是一個(gè)小的壯舉)。

幸運(yùn)的是,我發(fā)現(xiàn)Java支持位運(yùn)算符,這些運(yùn)算符被限制在32位整數(shù)數(shù)學(xué)中。

下面是Javascript生成的字符串原型。使用這個(gè)原型,您可以簡(jiǎn)單地對(duì)任何字符串調(diào)用.hashCode(),例如“some string”.hashCode(),并接收一個(gè)數(shù)字哈希代碼(更具體地說(shuō),是一個(gè)Java等效代碼),如1395333309。

String.prototype.hashCode = function(){var hash = 0;if (this.length == 0) return hash;for (i = 0; i < this.length; i++) {char = this.charCodeAt(i);hash = ((hash<<5)-hash)+char;hash = hash & hash; // Convert to 32bit integer}return hash;}

下面是其它網(wǎng)友的補(bǔ)充

hashCode = function(str){ var hash = 0; if (str.length == 0) return hash; for (i = 0; i < str.length; i++) { char = str.charCodeAt(i); hash = ((hash<<5)-hash)+char; hash = hash & hash; // Convert to 32bit integer } return hash;}djb2Code = function(str){ var hash = 5381; for (i = 0; i < str.length; i++) { char = str.charCodeAt(i); hash = ((hash << 5) + hash) + char; /* hash * 33 + c */ } return hash;}sdbmCode = function(str){ var hash = 0; for (i = 0; i < str.length; i++) { char = str.charCodeAt(i); hash = char + (hash << 6) + (hash << 16) - hash; } return hash;}loseCode = function(str){ var hash = 0; for (i = 0; i < str.length; i++) { char = str.charCodeAt(i); hash += char; } return hash;}

以上就是javascript的hashCode函數(shù)實(shí)現(xiàn)代碼小結(jié)的詳細(xì)內(nèi)容,更多關(guān)于javascript hashCode的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 久久91视频 | 草草在线观看视频 | 男女扒开双腿猛进入免费网站 | 亚洲欧美中文日韩二区一区 | 欧美一级毛片在线 | 国产精品免费观看视频 | 国产精品欧美日韩 | 欧美在线一| 国产成人cao在线 | 欧美精品一区二区在线观看 | 欧美一级日本一级韩国一级 | 波多野在线播放 | 国产爽的冒白浆的视频高清 | 久久久久久a亚洲欧洲aⅴ | 久久精品国产亚洲欧美 | 国产三级视频网站 | 久久久久久久99久久久毒国产 | 在线欧美日韩精品一区二区 | 免费的a级毛片 | 国产成人高清亚洲一区91 | 国产激情久久久久久影院 | 久草免费公开视频 | 奇米网狠狠干 | 精品久久久久久综合网 | 手机看片神马午夜片 | 欧美一级影院 | 亚洲欧美日韩国产精品 | 国产免费一区二区在线看 | 手机看片久久高清国产日韩 | 国产三级毛片 | 成人区在线观看免费视频 | 亚州视频在线 | 欧美成人免费高清二区三区 | 综合558欧美成人永久网站 | 在线观看亚洲免费视频 | 97视频免费公开成人福利 | 国产成人精品视频 | 国产亚洲精品九九久在线观看 | 亚洲国产精品一区二区首页 | 操操综合 | 欧美日韩国产综合一区二区三区 |