利用hasOwnProperty实现的高效的javascript hashtable

javascript中,object的实现就是hash表,因此只要在object上封装点方法,再利用原生的hasOwnProperty方法就可以实现简单高效的hashtable

var  HashTable  =  Class.create();
HashTable.prototype
=
{
    initialize:
function ()
    {
        
this ._content  = {};
    },
    Count:
function ()
    {
        
var  count  =   0 ;
        
for ( var  i  in   this ._content) count ++ ;
        
return  count;
    },
    Items:
function (key)
    {
        
if ( this .Contains(key))
        {
            
return   this ._content[key];
        }
    },
    Add:
function (key,value)
    {
        
if ( this ._content.hasOwnProperty(key)) 
        {
            
return   false ;
        }
        
else
        {
            
this ._content[key]  =  value;
            
return   true ;
        }
    },
    Clear:
function ()
    {
        
this ._content   =  {};
    },
    Contains:
function (key)
    {
        
return   this ._content.hasOwnProperty(key);
    },
    Remove:
function (key)
    {
        
delete   this ._content[key];
    }
}

测试如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    
<title>Untitled Page</title>

    
<script src="../O.cn_My/js/prototype.js" type="text/javascript"></script>

    
<script src="hashtable.js" type="text/javascript"></script>
   
</head>
<body>
        
<div id="output"></div>
</body>
 
<script type="text/javascript">
        
var hashtable = new HashTable();
        
for(var i = 0 ;i<100000;i++)
        {
            hashtable.Add(i
*1.2,i);
        }
        
var now = (new Date()).getTime();
        
var temp ="";
        
for(var i=0;i<1000;i++)
        {
             
if(hashtable.Contains(1+i*2.8))
             {  
                hashtable.Remove(i
*2.8);
             }
        }
        hashtable.Clear();
        $(
"output").innerHTML = " time pass:"+((new Date()).getTime()-now)+"ms";
        
//alert(hashtable.Count());
        
    
</script>
</html>

得出的结果是,100000大的hash表,进行1000次的判断,才花费15ms. 很快的速度了,可以用来做程序的优化.
注意: 字符串和数字相加会有糟糕的效率,导致时间多花了一倍,影响测试.
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
JavaScript中,有几种方法可以删除数据,具体取决于你要删除的数据类型和存储位置。以下是常见的几种方式: 1. **数组元素删除**: - `splice()` 方法:用于直接从数组中删除指定位置或范围的元素。 ```javascript let arr = [1, 2, 3, 4]; arr.splice(index, deleteCount); // 删除从index开始的deleteCount个元素 ``` - `pop()` 和 `shift()`:分别删除数组末尾和开头的元素,并返回被删除的元素。 ```javascript let lastItem = arr.pop(); // 删除并返回末尾元素 let firstItem = arr.shift(); // 删除并返回开头元素 ``` 2. **对象属性删除**: - 对象属性可以通过 `delete` 关键字删除。 ```javascript let obj = { name: 'John', age: 30 }; delete obj.age; // 删除age属性 ``` 3. **数组和对象清除所有属性**: - 对于数组,可以使用 `length` 属性置为 0 来“删除”所有元素,但不会释放内存。 - 对于对象,没有直接的“清空”方法,但可以遍历并删除所有属性。 ```javascript let arr = []; arr.length = 0; // 数组清空 let obj = {}; for (let prop in obj) { if (obj.hasOwnProperty(prop)) { delete obj[prop]; // 对象逐个属性删除 } } ``` 4. **数组实例的 `clear()` 方法(可选)**: 如果数组实现了 `clear()` 方法(如某些库中的自定义数组),可以直接调用该方法。 ```javascript let customArray = new CustomArray([...]); customArray.clear(); // 清除自定义数组的所有元素 ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值