欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2023年06月14日 12:31:07   投稿:mdxy-dxy  
網(wǎng)上找了好一輪,找到個(gè)比較像樣而且足夠短的 hashCode 實(shí)現(xiàn),是從 Java 的 hashCode 中借鑒而得的。原理見(jiàn) Java hashCode() ,也可以跟這里的 Java String 的源碼 參照對(duì)比一下

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

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

下面是newasp系統(tǒng)自帶的一個(gè)

String.prototype.hashCode = function() {for (var a = 31,b = 0,c = this.length; b < c;) a ^= (a << 5) + (a >> 2) + this.charCodeAt(b++);return a};

這里接受的參數(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)的方法。

我編寫(xiě)這個(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)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 全面講解JavaScript原型與原型鏈

    全面講解JavaScript原型與原型鏈

    本文主要介紹了全面講解JavaScript原型與原型鏈,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • js 獲取圖像縮放后的實(shí)際寬高,位置等信息

    js 獲取圖像縮放后的實(shí)際寬高,位置等信息

    本文主要介紹了js獲取圖像縮放后的實(shí)際寬高,位置等信息的方法,具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧
    2017-03-03
  • Bootstrap里的文件分別代表什么意思及其引用方法

    Bootstrap里的文件分別代表什么意思及其引用方法

    這篇文章主要介紹了Bootstrap里的文件分別代表什么意思及其引用方法 ,需要的朋友可以參考下
    2017-05-05
  • Bootstrap table 定制提示語(yǔ)的加載過(guò)程

    Bootstrap table 定制提示語(yǔ)的加載過(guò)程

    bootstrap-table是在bootstrap-table的基礎(chǔ)上寫(xiě)出來(lái)的,專門(mén)用于顯示數(shù)據(jù)的表格插件。這篇文章主要介紹了Bootstrap table 定制提示語(yǔ),需要的朋友可以參考下
    2017-02-02
  • canvas實(shí)現(xiàn)圖像布局填充功能

    canvas實(shí)現(xiàn)圖像布局填充功能

    這篇文章主要為大家詳細(xì)介紹了canvas實(shí)現(xiàn)圖像布局填充功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • javascript獲取以及設(shè)置光標(biāo)位置

    javascript獲取以及設(shè)置光標(biāo)位置

    本文介紹了javascript獲取以及設(shè)置光標(biāo)位置的方法,具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧
    2017-02-02
  • js實(shí)現(xiàn)使用輸入input和改變change事件模擬手動(dòng)輸入

    js實(shí)現(xiàn)使用輸入input和改變change事件模擬手動(dòng)輸入

    聚焦于JavaScript中的輸入模擬技術(shù),本指南將帶你探索如何使用input和change事件來(lái)創(chuàng)造逼真的手動(dòng)輸入效果,通過(guò)簡(jiǎn)單的代碼實(shí)現(xiàn),你將掌握這一實(shí)用的技巧,為你的Web應(yīng)用增添交互的樂(lè)趣,需要的朋友可以參考下
    2024-03-03
  • js實(shí)現(xiàn)七夕表白彈幕效果 jQuery實(shí)現(xiàn)彈幕技術(shù)

    js實(shí)現(xiàn)七夕表白彈幕效果 jQuery實(shí)現(xiàn)彈幕技術(shù)

    這篇文章主要介紹了js實(shí)現(xiàn)七夕表白彈幕效果,jQuery實(shí)現(xiàn)彈幕技術(shù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • asp錯(cuò)誤 '80040e21' 多步 OLE DB 操作產(chǎn)生錯(cuò)誤

    asp錯(cuò)誤 '80040e21' 多步 OLE DB&nbs

    今天在寫(xiě)asp入庫(kù)操作的時(shí)候提示Microsoft OLE DB Provider for ODBC Drivers 錯(cuò)誤 80040e21 多步 OLE DB 操作產(chǎn)生錯(cuò)誤,請(qǐng)檢查每個(gè) OLE DB 狀態(tài)值,經(jīng)測(cè)試時(shí)函數(shù)定義文件沒(méi)有加載導(dǎo)致類型不對(duì),所以無(wú)法入庫(kù)
    2023-05-05
  • javascript入門(mén)之?dāng)?shù)組[新手必看]

    javascript入門(mén)之?dāng)?shù)組[新手必看]

    本文介紹了javascript 數(shù)組的定義和數(shù)組元素的操作,ECMAScript中的數(shù)組方法...希望對(duì)大家有所幫助
    2016-11-11

最新評(píng)論