深拷贝写法
时间: 2023-07-08 11:21:19 浏览: 54
深拷贝是指在进行复制时,不仅复制对象本身,还要复制对象内部所有的引用类型数据(如数组、对象等)所引用的对象,使得复制后的对象与原对象完全独立,互不影响。
以下是一种常见的 JavaScript 深拷贝写法:
```
function deepClone(obj) {
if (obj === null || typeof obj !== 'object') {
return obj;
}
let clone = Array.isArray(obj) ? [] : {};
for (let key in obj) {
clone[key] = deepClone(obj[key]);
}
return clone;
}
```
该函数接收一个对象作为参数,如果该对象为 null 或者不是一个对象类型,直接返回该对象。如果是一个数组,新建一个数组,否则新建一个对象。然后遍历原对象中的属性,对每个属性进行递归调用,直到属性不再是一个对象类型,将其赋值给新对象对应的属性。最后返回新对象即可。
需要注意的是,该函数在处理对象时,只会拷贝可枚举的属性,不会拷贝对象的原型链上的属性和方法。如果需要拷贝原型链上的属性和方法,可以通过 Object.create() 方法创建一个新对象,并将原对象作为其原型,然后将新对象作为拷贝对象。
相关问题
Connect 写法
Connect的写法有多种,可以根据需要选择适合的方式。其中一种常见的写法是使用老版本标准的connect函数,例如:connect(btnClick,SIGNAL(Clicked(bool)),this,SLOT(onClicked(bool)))。这种写法比较繁琐,但是很明确地指定了要连接的信号和槽。另外一种写法是使用更简洁的语法,例如:connect(btnClick, static_cast(&MyButton::sigClicked), this,&Widget::onClicked)。这种写法可以允许信号和槽的重载,但是需要注意编译器可能无法自动选择正确的槽函数。建议在信号重载时使用第二种写法,而在槽重载时使用第一种写法,以确保连接的准确性。
makefile写法
makefile是一种用于自动化构建和编译程序的脚本文件。makefile的基本写法包括目标、依赖、规则和命令这三个要素。
1. 目标:目标是指需要生成的文件或执行的任务。在makefile中,目标通常是一个可执行文件或一个文件的对象文件。可以有多个目标,每个目标占据一行,并以冒号(:)结尾。
2. 依赖:依赖是指目标生成所依赖的文件或任务。在makefile中,依赖通常是源文件或其他目标。依赖也可以有多个,每个依赖之间用空格分隔,放在目标的后面。
3. 规则:规则是指定义了目标和依赖之间关系的部分。在makefile中,规则以目标为开头,后面是一个冒号(:),然后是依赖。规则可以有多行,每行以一个Tab键开头,表示规则所对应的命令。
例如,下面是一个简单的makefile示例:
```
target: dependency
command
```
其中,`target`是目标,`dependency`是依赖,`command`是需要执行的命令。
通过这样的规则,当依赖发生变化时,可以使用make命令来自动更新目标。make工具会自动识别目标和依赖之间的关系,并执行相应的命令来生成目标。
需要注意的是,makefile中的命令必须以Tab键开头,否则make工具无法正确解析。
这只是makefile的一种简单写法,实际上,makefile可以包含更复杂的规则和命令,以满足具体项目的需求。可以通过学习更多的makefile语法和使用方法来进一步掌握makefile的写法。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* *3* [手把手教你写makefile](https://blog.csdn.net/weixin_43574962/article/details/104108641)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"]
[ .reference_list ]