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

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

(箭头函数为主语写的)

  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年工作经历的高频面试题,发布出来分享一下,望帮助到你~

相关推荐
BigYe程普3 分钟前
出海技术栈集成教程(四):Resend邮件服务
前端·后端·全栈
辛-夷4 分钟前
JS的学习5
前端·javascript
啃火龙果的兔子11 分钟前
Form.Item中判断其他Form.Item的值
开发语言·前端·javascript
coding随想12 分钟前
CSSStyleSheet:掌控网页样式的“幕后黑手”,你真的了解吗?
前端
Undoom18 分钟前
Trae x Figma MCP一键将设计稿转化为精美网页
前端
情绪的稳定剂_精神的锚20 分钟前
git 提交前修改文件校验和commit提交规范
前端
天高任鸟飞dyz28 分钟前
vue文件或文件夹拖拽上传
前端·javascript·vue.js
EndingCoder37 分钟前
Next.js 中间件:自定义请求处理
开发语言·前端·javascript·react.js·中间件·全栈·next.js
Andy_GF41 分钟前
纯血鸿蒙 HarmonyOS Next 调试证书过期解决流程
前端·ios·harmonyos
现实与幻想~1 小时前
Linux:企业级WEB应用服务器TOMCAT
linux·前端·tomcat