当前位置: 首页 > 编程笔记 >

javascript实现的HashMap类代码

秦渝
2023-03-14
本文向大家介绍javascript实现的HashMap类代码,包括了javascript实现的HashMap类代码的使用技巧和注意事项,需要的朋友参考一下


<script language = "javascript" >

function HashMap() {

    /**Map大小**/

    var size = 0;

    /**对象**/

    var entry = new Object();

    /**Map的存put方法**/

    this.put = function(key, value) {

        if (!this.containsKey(key)) {

            size++;

            entry[key] = value;

        }

    }

    /**Map取get方法**/

    this.get = function(key) {

        return this.containsKey(key) ? entry[key] : null;

    }

    /**Map删除remove方法**/

    this.remove = function(key) {

        if (this.containsKey(key) && (delete entry[key])) {

            size--;

        }

    }

    /**是否包含Key**/

    this.containsKey = function(key) {

        return (key in entry);

    }

    /**是否包含Value**/

    this.containsValue = function(value) {

        for (var prop in entry) {

            if (entry[prop] == value) {

                return true;

            }

        }

        return false;

    }

    /**所有的Value**/

    this.values = function() {

        var values = new Array();

        for (var prop in entry) {

            values.push(entry[prop]);

        }

        return values;

    }

    /**所有的 Key**/

    this.keys = function() {

        var keys = new Array();

        for (var prop in entry) {

            keys.push(prop);

        }

        return keys;

    }

    /**Map size**/

    this.size = function() {

        return size;

    }

    /**清空Map**/

    this.clear = function() {

        size = 0;

        entry = new Object();

    }

} //创建HashMap对象 var hashMap = new HashMap(); hashMap.put("A", "1"); hashMap.put("B", "2"); hashMap.put("A", "5"); hashMap.put("C", "3"); hashMap.put("A", "4"); alert(hashMap.size());

</script>

 类似资料:
  • 本文向大家介绍Javascript代码实现仿实例化类,包括了Javascript代码实现仿实例化类的使用技巧和注意事项,需要的朋友参考一下 Javascript能做的事情越发的多了起来,随之而来的问题即是Js代码量的增加,面对代码的加多,我选择了仿面向对像类实例化里的构造函数自动启动的方式,把所有的js代码,以注册的形式,类化了起来。 代码 以上所述就是本文给大家分享的全部内容了,希望能够对大家学

  • 本文向大家介绍HashMap的底层实现?相关面试题,主要包含被问及HashMap的底层实现?时的应答技巧和注意事项,需要的朋友参考一下 JDK1.8之前 JDK1.8 之前 底层是 数组和链表 结合在一起使用也就是 链表散列。HashMap 通过 key 的 hashCode 经过扰动函数处理过后得到 hash 值,然后通过 (n - 1) & hash 判断当前元素存放的位置(这里的 n 指的是

  • 本文向大家介绍javascript实现二叉树的代码,包括了javascript实现二叉树的代码的使用技巧和注意事项,需要的朋友参考一下 前言: 二叉树的特点(例图只是二叉树的一种情况,不要尝试用例图推理以下结论) 除了最下面一层,每个节点都是父节点,每个节点都有且最多有两个子节点; 除了嘴上面一层,每个节点是子节点,每个节点都会有一个父节点; 最上面一层的节点(即例图中的节点50)为根节点; 最下

  • 问题内容: 在Java实现中,我发现 我知道并了解不允许创建通用数组,但是我无法理解的是整个过程如何工作。我的意思是当我们做类似的事情时 上面的代码如何导致创建类型为Entry的数组 好吧,很少有人无法理解我的要求。改写我要问的是做这样的事情有什么意义 当它不导致 问题答案: 该实现使类型为对象的数组 而不提供通用类型参数(source)。这是允许的,但是要理解编译器不再保证类型安全。例如,在代码

  • 本文向大家介绍Javascript 实现匿名递归的实例代码,包括了Javascript 实现匿名递归的实例代码的使用技巧和注意事项,需要的朋友参考一下 递归是一种常见的编程技巧,实名递归相信大家都不陌生,但如果想要实现匿名递归呢?比如想要返回一个匿名递归函数,又或者是定义一个匿名递归函数并直接调用它,该怎样去做呢?本文将来探讨一下它的实现。 实名递归 我们还是先从实名递归说起吧,还是用那个最简单的

  • 本文向大家介绍javascript实现简易计算器的代码,包括了javascript实现简易计算器的代码的使用技巧和注意事项,需要的朋友参考一下 今天闲来无聊,想写点什么,突然想到用javascript写一个计算器。程序还存在很多的Bug,先在这里记录一下,以后慢慢更正。 代码如下: 以上这篇javascript实现简易计算器的代码就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多