array.pop()
、array.push()
、array.shift()
和 array.unshift()
是 JavaScript 中用于操作数组的四个常用方法。它们分别用于从数组的末尾或开头添加或删除元素。
1. array.pop()
功能:
- 用于删除数组的最后一个元素,并返回被删除的元素。
- 会修改原数组。
语法:
array.pop()
示例:
删除最后一个元素:
let arr = [1, 2, 3];
let lastElement = arr.pop();
console.log(arr); // 输出: [1, 2]
console.log(lastElement); // 输出: 3
空数组调用 pop
:
let arr = [];
let result = arr.pop();
console.log(arr); // 输出: []
console.log(result); // 输出: undefined (空数组没有元素可删除)
2. array.push()
功能:
- 用于在数组的末尾添加一个或多个元素,并返回新数组的长度。
- 会修改原数组。
语法:
array.push(element1, element2, ..., elementN)
示例:
添加单个元素:
let arr = [1, 2, 3];
let newLength = arr.push(4);
console.log(arr); // 输出: [1, 2, 3, 4]
console.log(newLength); // 输出: 4 (新数组的长度)
添加多个元素:
let arr = [1, 2, 3];
let newLength = arr.push(4, 5, 6);
console.log(arr); // 输出: [1, 2, 3, 4, 5, 6]
console.log(newLength); // 输出: 6
3. array.shift()
功能:
- 用于删除数组的第一个元素,并返回被删除的元素。
- 会修改原数组。
语法:
array.shift()
示例:
删除第一个元素:
let arr = [1, 2, 3];
let firstElement = arr.shift();
console.log(arr); // 输出: [2, 3]
console.log(firstElement); // 输出: 1
空数组调用 shift
:
let arr = [];
let result = arr.shift();
console.log(arr); // 输出: []
console.log(result); // 输出: undefined (空数组没有元素可删除)
4. array.unshift()
功能:
- 用于在数组的开头添加一个或多个元素,并返回新数组的长度。
- 会修改原数组。
语法:
array.unshift(element1, element2, ..., elementN)
示例:
添加单个元素:
let arr = [2, 3];
let newLength = arr.unshift(1);
console.log(arr); // 输出: [1, 2, 3]
console.log(newLength); // 输出: 3 (新数组的长度)
添加多个元素:
let arr = [3, 4];
let newLength = arr.unshift(1, 2);
console.log(arr); // 输出: [1, 2, 3, 4]
console.log(newLength); // 输出: 4
对比总结:
方法 | 功能 | 是否修改原数组 | 返回值 | 示例代码 |
---|---|---|---|---|
array.pop() | 删除数组的最后一个元素 | 是 | 被删除的元素 | arr.pop() |
array.push() | 在数组末尾添加一个或多个元素 | 是 | 新数组的长度 | arr.push(4) |
array.shift() | 删除数组的第一个元素 | 是 | 被删除的元素 | arr.shift() |
array.unshift() | 在数组开头添加一个或多个元素 | 是 | 新数组的长度 | arr.unshift(1) |
性能对比:
push()
和pop()
的时间复杂度为 O(1),因为它们只操作数组的末尾。shift()
和unshift()
的时间复杂度为 O(n),因为它们需要移动数组中的所有元素以保持顺序。
因此,在性能敏感的场景下,尽量避免频繁使用 shift()
和 unshift()
。
适用场景:
-
array.pop()
:- 当你需要删除数组的最后一个元素时。
-
array.push()
:- 当你需要在数组末尾添加元素时。
-
array.shift()
:- 当你需要删除数组的第一个元素时(如实现队列)。
-
array.unshift()
:- 当你需要在数组开头添加元素时。
总结:
- 如果只是在数组末尾操作,优先使用
push()
和pop()
,因为它们性能更高。 - 如果需要在数组开头操作,可以使用
unshift()
和shift()
,但要注意性能问题。