js 写的Map

function Map()
{
	this.elements = {};
	this.size = 0;
}

// get the size of the Map
Map.prototype.size = function(){
	return this.size;
};

// judge the Map's empty
Map.prototype.isEmpty = function(){
	return (this.size < 1);
};

//clear the map
Map.prototype.clear = function() {
	this.elements = {};
	this.size = 0;
}

//add the elements
Map.prototype.put = function(key, value)
{
	var oldValue = this.elements[key];
	if(oldValue == undefined)
	{
		this.size++;
	}
	this.elements[key] = value;
	return oldValue;
};

//get the value according to the key
Map.prototype.get = function(key)
{
	return this.elements[key];
};

//remove the elements according to the key
Map.prototype.remove = function(key)
{
	var oldValue = this.elements[key];
	if(oldValue != undefined)
	{
		this.size--;
		delete this.elements[key];
	}
	return oldValue;
};

//get all the keys of Map
Map.prototype.keys = function(){
	var keyArray = new Array();
	for(var j in this.elements){
		keyArray.push(j);
	}
	return keyArray;
};

//get all the values of Map
Map.prototype.values = function(){
	var valueArray = new Array();
	for(var j in this.elements){
		valueArray.push(this.elements[j]);
	}
	return valueArray;
};

//contain key 
Map.prototype.containsKey = function(key) {
	for(var j in this.elements){
		if(j == value)return true;
	} 
	return false;
}
//contain value 
Map.prototype.containsValue = function(value) {
	for(var j in this.elements){
		if(this.elements[j] == value)return true;
	} 
	return false;
}

function Set(getKey)
{
	this.map = new Map();
	this.getKey = getKey;
}

Set.prototype.add = function(value)
{
	var key = this.getKey(value);
	this.map.put(key, value);
}

Set.prototype.remove = function(value)
{
	var key = this.getKey(value);
	this.map.remove(key);
}

Set.protorype.getAll=function()
{
	var tempArray=new Array();
	for(var i in this.obj)
	{
		tempArray.push(i);
	}
	return tempArray;
}

Set.prototype.size = function()
{
	return this.map.size();
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值