面试常问:数组遍历forEach和map的区别

简介: 一.forEach的用法:二.map的用法:

一.forEach的用法:

let arr = ["a", "b", "c", "1", "2", 3];
    var a = arr.forEach(function (value, index, arr) {
        //console.log(arr[index]); // 打印结果为 "a", "b", "c", "1", "2", 3
        return value + value;
    })
console.log("forEach返回值:", a); // undefined


二.map的用法:

let arr = ["a", "b", "c", "1", "2", 3];
var b = arr.map(function (value, index, arr) {
        //console.log(arr[index]); // 打印结果为 "a", "b", "c", "1", "2", 3
        return value + value;
    })
 console.log("map返回值:", b); // ['aa', 'bb', 'cc', '11', '22', 6]


fb25ff02e4af4f35a9e67cdc0cc1cb7a.png


三.总结:

数组常用遍历方法:
            1. forEach(function(value, index, arr){}); // for循环的加强版
            value: 数组中的每一个元素
            index: 下标/索引
            arr: 数组本身
            会改变原数组 没有返回值
            直接引入当前遍历数组的内存地址 类似于浅拷贝的套路
            2.map(function(value, index, arr){}); // for循环的加强版
            value: 数组中的每一个元素
            index: 下标/索引
            arr: 数组本身
            有返回值 不改变原数组(形成了新的数组)
            形成了新的数组, 地址和值都改变 类似于深拷贝
            forEach() <===> for(let i = 0; i < arr.length; i++){}<==>map()

相同点:都能遍历数组

不同点:map:有返回值 不改变原数组 形成了新的数组, 地址和值都改变 类似于深拷贝

             forEach:会改变原数组 没有返回值,相当于forEach遍历是直接引入当前遍历数组的内存地址

类似于浅拷贝

下期了解一下堆和栈的概念以及深拷贝浅拷贝

相关文章
|
2月前
|
Go
go语言中遍历映射(map)
go语言中遍历映射(map)
79 8
|
1月前
|
Go
go语言for遍历映射(map)
go语言for遍历映射(map)
51 12
|
2月前
|
存储
`map()`方法在什么场景下会比 `forEach()`方法更高效?
综上所述,当需要对数组元素进行复杂的转换并生成新数组、进行链式调用和函数式编程、处理元素之间存在明确映射关系的情况以及与其他数组方法结合使用时,`map()`方法比`forEach()`方法更高效,能够使代码更加简洁、清晰和易于维护。
73 32
|
2月前
|
Java 程序员
Java社招面试题:& 和 && 的区别,HR的套路险些让我翻车!
小米,29岁程序员,分享了一次面试经历,详细解析了Java中&和&&的区别及应用场景,展示了扎实的基础知识和良好的应变能力,最终成功获得Offer。
95 14
|
1月前
|
Java 关系型数据库 数据库
京东面试:聊聊Spring事务?Spring事务的10种失效场景?加入型传播和嵌套型传播有什么区别?
45岁老架构师尼恩分享了Spring事务的核心知识点,包括事务的两种管理方式(编程式和声明式)、@Transactional注解的五大属性(transactionManager、propagation、isolation、timeout、readOnly、rollbackFor)、事务的七种传播行为、事务隔离级别及其与数据库隔离级别的关系,以及Spring事务的10种失效场景。尼恩还强调了面试中如何给出高质量答案,推荐阅读《尼恩Java面试宝典PDF》以提升面试表现。更多技术资料可在公众号【技术自由圈】获取。
|
2月前
|
存储 Go
go语言 遍历映射(map)
go语言 遍历映射(map)
48 2
|
4月前
|
Go 定位技术 索引
Go 语言Map(集合) | 19
Go 语言Map(集合) | 19
|
4月前
|
存储 前端开发 API
ES6的Set和Map你都知道吗?一文了解集合和字典在前端中的应用
该文章详细介绍了ES6中Set和Map数据结构的特性和使用方法,并探讨了它们在前端开发中的具体应用,包括如何利用这些数据结构来解决常见的编程问题。
ES6的Set和Map你都知道吗?一文了解集合和字典在前端中的应用
|
5月前
|
存储 安全 Java
java集合框架复习----(4)Map、List、set
这篇文章是Java集合框架的复习总结,重点介绍了Map集合的特点和HashMap的使用,以及Collections工具类的使用示例,同时回顾了List、Set和Map集合的概念和特点,以及Collection工具类的作用。
java集合框架复习----(4)Map、List、set
|
5月前
|
Java
【Java集合类面试二十二】、Map和Set有什么区别?
该CSDN博客文章讨论了Map和Set的区别,但提供的内容摘要并未直接解释这两种集合类型的差异。通常,Map是一种键值对集合,提供通过键快速检索值的能力,而Set是一个不允许重复元素的集合。