zoukankan      html  css  js  c++  java
  • 关于数组复制的问题

    引用自:http://blog.sina.com.cn/s/blog_51baa1570100io8r.html

    一、 错误实现
    var array1 = new Array("1","2","3"); 
    var array2; 
    array2 = array1; 
    array1.length = 0; 
    alert(array2); //返回为空

    这种做法是错的,因为javascript分原始类型与引用类型(与java、c#类似)。Array是引用类

    型。array2得到的是引用,所以对array1的修改会影响到array2。

    二、 使用slice()

    可使用slice()进行复制,因为slice()返回也是数组。

    var array1 = new Array("1","2","3"); 
    var array2; 
    array2 = array1.slice(0); 
    array1.length = 0; 
    alert(array2); //返回1、2、3  

    三、 使用concat()

    注意concat()返回的并不是调用函数的Array,而是一个新的Array,所以可以利用这一点进行复制。

    var array1 = new Array("1","2","3"); 
    var array2; 
    array2 = array1.concat(); 
    array1.length = 0; 
    alert(array2); //返回1、2、3 

    四、 测试

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> 
    <html> 
    <head> 
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
    <title>Array Test</title> 
    <script type="text/javascript"> 
    var array1; 
    var array2; 
    
    function clone1() {
    array1 = new Array("1","2","3");
    array2 = array1; 
    array1.length = 0; 
    alert(array2); 
    } 
    
    function clone2() { 
    array1 = new Array("1","2","3");
    array2 = array1.slice(0); 
    array1.length = 0; 
    alert(array2);
    } 
    
    function clone3() { 
    array1 = new Array("1","2","3");
    array2 = array1.concat(); 
    array1.length = 0; 
    alert(array2);
    } 
    
    </script> 
    
    </head> 
    <body> 
    <input type="button" value="clone1" onclick="clone1()" /><br /> 
    <input type="button" value="clone2" onclick="clone2()" /><br /> 
    <input type="button" value="clone3" onclick="clone3()" /><br /> 
    </body> 
    </html>
  • 相关阅读:
    linux系统swap分区容量扩展
    linux系统lv_root分区容量扩展
    linux系统创建新LV,挂载新分区。
    linux 服务器重启后lvm 变成inactive状态解决
    Linux下使用fdisk扩大分区容量
    go语言 调用飞书群消息机器人接口
    SpringCloud Sentinel 学习笔记
    Git 笔记整理
    SpringBoot 整合 RabbitMQ 学习笔记
    js递归生成树形结构-vue
  • 原文地址:https://www.cnblogs.com/cnblogs-jcy/p/5262849.html
Copyright © 2011-2022 走看看