大学生前端必知:箭头函数与普通函数的区别,数组与链表的区别是什么?

一、箭头函数与普通函数有以下区别:

(箭头函数为主语写的)

  1. this的绑定:这是箭头函数与普通函数最显著的区别。 在普通函数中,this的值取决于函数的调用方式,可能是全局对象(在浏览器中为window),也可能是某个对象。 而在箭头函数中,this的值继承自包含它的函数或全局作用域,也就是说,箭头函数不会创建自己的 this上下文,所以this的值是固定的。
  2. 没有prototype属性:箭头函数没有prototype属性,因此不能用作构造函数,也就是说不能使用new关键字来调用箭头函数。
  3. 没有arguments对象:箭头函数没有arguments对象,如果需要访问函数的参数,可以使用剩余参数(rest parameters)代替。对,就是那个"点点点",运算符...
  4. 不能用作生成器函数:箭头函数不能用作生成器函数,也就是说它们不能包含yield关键字。
  5. 没有super关键字:因为箭头函数没有自己的this,所以它们也不能使用 super关键字。
  6. 语法更简洁:箭头函数的语法比普通函数更简洁,特别是在处理简单的函数时。

这些区别使得箭头函数在某些场景下更为适用,例如在回调函数、定时器、事件监听器等需要快速定义和使用的函数中。同时,由于箭头函数在this绑定上的特殊性质,它也可以避免一些常见的this相关的问题。然而,由于箭头函数的一些限制,它们并不适用于所有场景,例如在需要构建原型或使用super关键字的类中,或者需要用作生成器函数的场景中。

二、数组与链表的区别:

  1. 存储方式: 数组是连续存储的 ,它在创建时需要一块整块的空间,并且长度是固定的。 而链表是链式存储的,它在内存空间中不一定是连续的,且长度可变,每个节点保存了相邻节点的指针。
  2. 访问元素的方式数组 可以通过下标进行随机访问 ,访问速度快。 而链表 只能从头节点开始,按照顺序访问链表中的元素,访问速度相对较慢。
  3. 增删效率:在数组中插入或删除元素时,可能需要移动大量的元素,因此时间复杂度是O(n)。 而在链表中,进行插入或删除操作时,只需改变相关节点的指针,时间复杂度为O(1),效率更高。
  4. 内存分配方式:数组是静态分配内存的,一旦创建,大小就不能 改变。 而链表是动态分配内存的,可以根据需要动态地增加或减少节点。
  5. 越界问题数组存在越界问题 ,如果访问超出数组长度的下标,会导致错误(js访问是undefined)。 而链表不存在越界问题 ,因为链表是通过指针连接的,访问超出 范围的节点会返回null空指针

PS 博主清颖的话:

这些都来自个人曾经的云笔记,也是1-3年工作经历的高频面试题,发布出来分享一下,望帮助到你~

相关推荐
颜酱6 分钟前
Monorepo 架构以及工具选型、搭建
前端·javascript·node.js
oden10 分钟前
ChatGPT不推荐你?7个GEO技巧让AI主动引用你的内容
前端
X***489644 分钟前
JavaScript在Node.js中的Nx
javascript·node.js·vim
o***Z4481 小时前
JavaScript在Node.js中的内存管理
开发语言·javascript·node.js
李游Leo1 小时前
前端安全攻防指南:XSS / CSRF / 点击劫持与常见防护实践(含真实案例拆解)
前端·安全·xss
我命由我123451 小时前
微信开发者工具 - 模拟器分离窗口与关闭分离窗口
前端·javascript·学习·微信小程序·前端框架·html·js
E***q5391 小时前
Vue增强现实开发
前端·vue.js·ar
S***42801 小时前
JavaScript在Web中的Angular
前端·javascript·angular.js
4***14902 小时前
Vue代码规范详解
javascript·vue.js·代码规范
黑幕困兽2 小时前
ehcarts 实现 饼图扇区间隙+透明外描边
前端·echarts