javascript的hashCode函数实现代码小结


Posted in Javascript onAugust 11, 2020

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

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

这里接受的参数是一个 String,其它类型怎么办?可以先做一个统一的处理,比如

hashcode(JSON.stringify(obj))
序列化之后再使用 hashCode 函数,基本所有类型数据都通吃,除了含有循环嵌套的对象。

PS:
函数实现中有一行使用了 “|” 运算符,只是利用 Bitwise 运算符转换参数为 32bit,用来确保结果是个 32位整数。

这里是Java的直接替代品字符串.hashCode()用Javascript实现的方法。

我编写这个函数是为了满足工作中的一个需求。显然,后端工程师认为hashCode()是一个标准函数。这个项目的一个障碍不仅是如何翻译Java中用来生成hashCode()的数学公式,还包括如何强制Javascript使用32位整数数学(这不是一个小的壮举)。

幸运的是,我发现Java支持位运算符,这些运算符被限制在32位整数数学中。

下面是Javascript生成的字符串原型。使用这个原型,您可以简单地对任何字符串调用.hashCode(),例如“some string”.hashCode(),并接收一个数字哈希代码(更具体地说,是一个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;
}

下面是其它网友的补充

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函数实现代码小结的详细内容,更多关于javascript hashCode的资料请关注三水点靠木其它相关文章!

Javascript 相关文章推荐
不错的asp中显示新闻的功能
Oct 13 Javascript
关于 byval 与 byref 的区别分析总结
Oct 08 Javascript
对象无length属性时IE6/IE7中无法将其转换成伪数组(ArrayLike)
Jul 31 Javascript
javascript-表格排序(降序/反序)实现介绍(附图)
May 30 Javascript
jquery二级导航内容均分的原理及实现
Aug 13 Javascript
jQuery打印图片pdf、txt示例代码
Jul 22 Javascript
JavaScript 基本概念
Jan 20 Javascript
jQuery实现表格文本框淡入更改值后淡出效果
Sep 27 Javascript
Vue列表页渲染优化详解
Jul 24 Javascript
node跨域转发 express+http-proxy-middleware的使用
May 31 Javascript
详解使用webpack+electron+reactJs开发windows桌面应用
Feb 01 Javascript
JavaScript实现随机点名器
Mar 25 Javascript
vue axios封装httpjs,接口公用配置拦截操作
Aug 11 #Javascript
解决vue刷新页面以后丢失store的数据问题
Aug 11 #Javascript
封装 axios+promise通用请求函数操作
Aug 11 #Javascript
在vue中使用回调函数,this调用无效的解决
Aug 11 #Javascript
vue 调用 RESTful风格接口操作
Aug 11 #Javascript
vue之封装多个组件调用同一接口的案例
Aug 11 #Javascript
vue接口请求加密实例
Aug 11 #Javascript
You might like
gearman中任务的优先级和返回状态实例分析
2020/02/27 PHP
yii2.0框架数据库操作简单示例【添加,修改,删除,查询,打印等】
2020/04/13 PHP
tp5.1 框架join方法用法实例分析
2020/05/26 PHP
JavaScript面向对象之静态与非静态类
2010/02/03 Javascript
IE8下Jquery获取select选中的值post到后台报错问题
2014/07/02 Javascript
js正则表达式注册页面表单验证
2016/10/11 Javascript
解决在Bootstrap模糊框中使用WebUploader的问题
2018/03/22 Javascript
微信小程序实现登录遮罩效果
2018/11/01 Javascript
如何使用vuex实现兄弟组件通信
2018/11/02 Javascript
vue中引入第三方字体文件的方法示例
2018/12/17 Javascript
vue3.0中使用postcss-pxtorem的具体方法
2019/11/20 Javascript
jquery更改元素属性attr()方法操作示例
2020/05/22 jQuery
JavaScript 如何在浏览器中使用摄像头
2020/12/02 Javascript
Linux上安装Python的PIL和Pillow库处理图片的实例教程
2016/06/23 Python
Python中dict和set的用法讲解
2019/03/28 Python
pandas的to_datetime时间转换使用及学习心得
2019/08/11 Python
基于python解线性矩阵方程(numpy中的matrix类)
2019/10/21 Python
如何基于python操作json文件获取内容
2019/12/24 Python
PyCharm 无法 import pandas 程序卡住的解决方式
2020/03/09 Python
Python爬虫定时计划任务的几种常见方法(推荐)
2021/01/15 Python
HTML5 实现图片上传预处理功能
2020/02/06 HTML / CSS
澳大利亚第一旅行车和房车配件店:Caravan RV Camping
2020/12/26 全球购物
Ibatis中如何提高SQL Map的性能
2013/05/11 面试题
解释一下ruby中的特殊方法与特殊类
2013/02/26 面试题
开工庆典邀请函范文
2014/01/16 职场文书
区长工作作风个人整改措施
2014/10/01 职场文书
升职自荐信怎么写
2015/03/05 职场文书
停课通知书
2015/04/24 职场文书
预备党员转正意见
2015/06/01 职场文书
钢琴师观后感
2015/06/12 职场文书
新娘父亲婚礼致辞
2015/07/27 职场文书
企业财务管理制度范本
2015/08/04 职场文书
使用canvas仿Echarts实现金字塔图的实例代码
2021/11/11 HTML / CSS
Winsows11性能如何? win11性能测评多核竟比Win10差了10%
2021/11/21 数码科技
Java 多线程并发FutureTask
2022/06/28 Java/Android
python 镜像环境搭建总结
2022/09/23 Python