193节---------6月17日

本文探讨了JavaScript中简单数据类型(如string, number, boolean)与复杂数据类型(如object, array)的区别,涉及存储位置(栈 vs 堆)、传参机制以及API与WebAPI的应用。重点讲解了内存分配原理和参数传递方式的差异。
摘要由CSDN通过智能技术生成

简单数据类型和复杂数据类型

简单数据类型又叫做基本数据类型或值类型。复杂数据类型又叫做引用类型。

  • 值类型:在存储时变量中存储的是值本身,如string,number,boolean,undefined,null
    • 如果有个变量打算存储为对象,暂时没想好放啥,这个时候就给null,但是null返回的是一个空的对象object。
  • 引用类型:在存储时变量中存储的仅仅是地址,通过new关键字创建的对象(系统对象、自定义对象)如object,array,date

堆和栈

  • 堆:由操作系统自动分配释放存放函数的参数值、局部变量的值等。其操作方式类似与数据结构中的栈。简单数据类型放到栈里。
  • 堆:一般由程序员分配释放,若程序员不释放,由垃圾回收机制回收。复杂数据类型存放到堆里。

注意:JS中没有堆栈的概念,在此为了方便理解代码的执行方式


内存分配

简单数据类型,在栈中直接开辟一个空间存放值

复杂数据类型在站里面存放地址(十六进制),然后这个地址指向堆里面的


传参

简单类型传参

函数的参数也可以看作是一个变量,当我们把一个值类型变量作为参数传递给函数的形参时,其实是把变量在栈空间里的值复制了一份给形参,那么在方法内部对形参做任何修改,都不会影响到外部的变量。

复杂类型传参

函数的参数也可以看作是一个变量,当我们把一个引用类型变量作为参数传递给函数的形参时,其实是把堆地址复制给了形参,形参和实参中保存的是同一个堆地址,所以操作的对象那个是同一个


API和Web API

API

是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节

WebAPI

是浏览器提供的一套操作浏览器功能和页面元素的API(BOM和DOM)

注意:

  • API是为程序员提供的一个接口,帮助我们实现某种功能,会使用即可
  • Web API主要是针对浏览器提供的接口,主要针对浏览器做交互效果
  • Web API一半都有输入和输出(函数的传参和返回值),Web API很多都是方法(函数)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值