zoukankan      html  css  js  c++  java
  • JavaScript 装箱与拆箱 boxing && unBoxing

    首先我们来看看这段代码

    var s1 = "abc";
    var s2 = s1.indexOf("a")
    

    ??? 黑人问号?

    这位黑人问号.jpg的真身,本来就是个浑身是戏的逗boy啊-PingWest 品玩

    s1 是个 string 啊,怎么会有 indexOf() 方法呢?

    这里就涉及到了 JavaScript 中的装箱与拆箱的概念了

    装箱:把基本数据类型转化为对应的引用数据类型的操作

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

    每当读取一个基本类型的时候,后台就会创建一个对应的基本包装类型对象,从而让我们能够调用一些方法来操作这些数据。

    还是拿最开始的例子

    var s1 = "abc";
    var s2 = s1.indexOf("a")
    

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

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

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

    (3)销毁这个实例;

    下面来看看代码实现:

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

    这样就完成装箱,我们也就能在s1上调用方法了

    拆箱:将引用类型对象转换为对应的值类型对象

    拆箱:将引用类型对象转换为对应的值类型对象

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

     var objNum = new Number(123);  
     var objStr =new String("123");   
     console.log( typeof objNum ); //object
     console.log( typeof objStr ); //object 
     console.log( typeof objNum.valueOf() ); //number
     console.log( typeof objStr.valueOf() ); //string
    
     console.log( typeof objNum.toString() ); // string 
     console.log( typeof objStr.toString() ); // string
    
  • 相关阅读:
    仓位管理 – 1.理论篇
    作为首席架构师,我是如何选择并落地架构方案的?
    asp.net MVC 应用程序的生命周期
    微服务架构优缺点
    一位同事对 Rafy 框架的一些建议及我的回复
    .NET 版本区别,以及与 Windows 的关系
    MIS性能优化常见问题与方案(辅助项目组性能优化的总结贴)
    何时使用静态 API
    2011奥斯卡最佳纪录片《监守自盗(Inside Job)》小结
    Rafy 框架
  • 原文地址:https://www.cnblogs.com/ssaylo/p/13094167.html
Copyright © 2011-2022 走看看