zoukankan      html  css  js  c++  java
  • javascript中的装箱和拆箱操作

    1,装箱:

    把基本数据类型转换为对应的引用类型的操作称为装箱,把引用类型转换为基本的数据类型称为拆箱。

    在《javascript高级程序设计》中有这样一句话:

    每当读取一个基本类型的时候,后台就会创建一个对应的基本包装类型对象,从而让我们能够调用一些方法来操作这些数据。
    var s1 = "some text";
    var s2 = s1.substring(2);

    如上所视,变量s1是一个基本类型值,它不是对象,所以它不应该有方法。但是js内部为我们完成了一系列处理(即我们称之为装箱),使得它能够调用方法,实现的机制如下:

    (1)创建String类型的一个实例;

    (2)在实例上调用指定的方法;

    (3)销毁这个实例;

    这个过程也可以用代码来展现:

    var s1  = new String("some text");
    var s2 = s1.substring(2);
    s1 = null;

    我在很多地方都看到过说装箱操作会泄露内存,可是这里明明是销毁了实例的,哎,我还是相信《javascript高级程序设计》吧,认为它不会泄露,如果你有见解,请留言!

    2,拆箱:

    将引用类型对象转换为对应的值类型对象,它是通过引用类型的valueOf()或者toString()方法来实现的。如果是自定义的对象,你也可以自定义它的valueOf()/tostring()方法,实现对这个对象的拆箱。

     1 var objNum = new Number(123);  
     2 var objStr =new String("123");  
     3 
     4 console.log( typeof objNum ); //object
     5 console.log( typeof objStr ); //object
     6 
     7 console.log( typeof objNum.valueOf() ); //number
     8 console.log( typeof objStr.valueOf() ); //string
    9 10 console.log( typeof objNum.toString() ); // string 
    11 console.log( typeof objStr.toString() ); // string

    开心一刻:

  • 相关阅读:
    【Lintcode】112.Remove Duplicates from Sorted List
    【Lintcode】087.Remove Node in Binary Search Tree
    【Lintcode】011.Search Range in Binary Search Tree
    【Lintcode】095.Validate Binary Search Tree
    【Lintcode】069.Binary Tree Level Order Traversal
    【Lintcode】088.Lowest Common Ancestor
    【Lintcode】094.Binary Tree Maximum Path Sum
    【算法总结】二叉树
    库(静态库和动态库)
    从尾到头打印链表
  • 原文地址:https://www.cnblogs.com/wenber/p/3628944.html
Copyright © 2011-2022 走看看