JavaScript中装箱与拆箱(boxing及unBoxing)的用法具体是怎样的?

2026-04-03 08:481阅读0评论SEO资源
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计718个文字,预计阅读时间需要3分钟。

JavaScript中装箱与拆箱(boxing及unBoxing)的用法具体是怎样的?

首先,我们来分析这段代码:

javascriptvar s1=abc;var s2=s1.indexOf(a) + s1;

这里,`s1` 是一个字符串,值为 `abc`。`s2` 的值是通过调用 `s1.indexOf(a)` 来获取字符 `a` 在 `s1` 中的位置,然后把这个位置加上整个字符串 `s1` 的值。

`indexOf` 方法是 JavaScript 中字符串对象的一个方法,它返回指定值在字符串中第一次出现的位置。如果没有找到指定的值,则返回 `-1`。

所以,`s1.indexOf(a)` 的结果将是 `0`,因为 `a` 在 `abc` 中第一次出现的位置是 `0`。

然后,`s2` 的值就是 `0 + abc`,即 `abc`。

总结一下,这段代码的输出结果是 `abc`。

首先我们来看看这段代码

JavaScript中装箱与拆箱(boxing及unBoxing)的用法具体是怎样的?

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

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。

本文共计718个文字,预计阅读时间需要3分钟。

JavaScript中装箱与拆箱(boxing及unBoxing)的用法具体是怎样的?

首先,我们来分析这段代码:

javascriptvar s1=abc;var s2=s1.indexOf(a) + s1;

这里,`s1` 是一个字符串,值为 `abc`。`s2` 的值是通过调用 `s1.indexOf(a)` 来获取字符 `a` 在 `s1` 中的位置,然后把这个位置加上整个字符串 `s1` 的值。

`indexOf` 方法是 JavaScript 中字符串对象的一个方法,它返回指定值在字符串中第一次出现的位置。如果没有找到指定的值,则返回 `-1`。

所以,`s1.indexOf(a)` 的结果将是 `0`,因为 `a` 在 `abc` 中第一次出现的位置是 `0`。

然后,`s2` 的值就是 `0 + abc`,即 `abc`。

总结一下,这段代码的输出结果是 `abc`。

首先我们来看看这段代码

JavaScript中装箱与拆箱(boxing及unBoxing)的用法具体是怎样的?

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

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。