JavaScript 函数参数与实参:传递原始类型和非原始类型变量的区别是什么?

javascript 函数参数与实参:传递原始类型和非原始类型变量的区别是什么?

函数参数和实参的关系

当我们传递变量值给函数时,会遇到关于函数参数和实参之间关系的问题。在 javascript 中,函数实参与形参的关系取决于所传递变量的类型。

传递原始类型变量

在传递原始类型变量(如字符串、数字、布尔值)时,形参得到的是实参值的副本。这意味着对形参的任何修改都不会影响实参。例如:

立即学习“Java免费学习笔记(深入)”;

阿里云-虚拟数字人 阿里云-虚拟数字人

阿里云-虚拟数字人是什么? …

阿里云-虚拟数字人 2 查看详情 阿里云-虚拟数字人

function changenum(num) {  num = 10;  console.log("num:", num); // 输出: 10}const x = 5;changenum(x);console.log("x:", x); // 输出: 5

传递非原始类型变量

当传递非原始类型变量(如数组、对象)时,形参得到的不是值的副本,而是对原对象的引用。这意味着对形参的任何修改都会影响实参。例如:

function changeArray(array) {  array[0] = 10;  console.log("array:", array); // 输出: [10, 2, 3]}const a = [1, 2, 3];changeArray(a);console.log("a:", a); // 输出: [10, 2, 3]

在上面的示例中,当我们调用 changearray 函数时,变量 a 的值被传递给 array 参数。array 参数得到的不是 a 值的副本,而是对 a 数组的引用。因此,对 array 的修改也影响了 a 数组。

因此,了解函数参数和实参之间的关系对于正确地处理变量至关重要。在传递原始类型变量时,不需要担心对实参的影响,但是在传递非原始类型变量时,应该意识到对形参的修改也会修改实参。

以上就是JavaScript 函数参数与实参:传递原始类型和非原始类型变量的区别是什么?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/430968.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月7日 13:49:26
下一篇 2025年11月7日 14:00:59

相关推荐

  • Go语言中自定义字符串类型与常量转换机制解析

    本文深入探讨go语言中自定义字符串类型(如`type stringtype string`)与内置`string`类型之间的区别,以及go严格的类型系统如何影响它们的互操作性。我们将分析 untyped 常量(如`const firststring = “first”`)的特…

    2025年12月16日
    000
  • 如何在Golang中实现指针接收者与值接收者区别_Golang结构体方法接收者使用方法汇总

    值接收者传递副本,适合小型结构体和只读操作;指针接收者传递地址,可修改原对象,适用于大结构体或需修改状态的场景。 在Golang中,结构体的方法可以定义在值接收者或指针接收者上,二者在使用场景和行为上有明显区别。理解它们的差异对编写高效、正确的代码至关重要。 值接收者 vs 指针接收者的基本区别 当…

    2025年12月16日
    000
  • Go在App Engine上的内存管理:理解Alloc与Sys的差异与优化

    本文深入探讨go应用在google app engine(gae)环境中内存管理中`runtime.memstats.alloc`与`sys`字段的差异。我们将阐明go垃圾回收机制如何影响系统级内存占用,解释为何app engine通常根据`sys`而非`alloc`来判断内存使用并终止实例。通过代…

    2025年12月16日
    000
  • Golang如何处理结构体指针与值类型赋值_Golang结构体指针值赋值详解

    结构体值类型保存副本,指针类型保存地址;函数传参为值传递,值接收者操作副本,指针接收者可修改原数据;大结构体或需修改时应使用指针。 在Go语言中,结构体(struct)是构建复杂数据类型的重要方式。理解结构体的值类型与指针类型的赋值行为,对编写高效、安全的代码至关重要。特别是在涉及函数传参、方法绑定…

    2025年12月16日
    000
  • Golang如何处理指针类型断言与类型转换_Golang指针类型断言详解

    指针类型断言需匹配接口内实际类型,如i.(User)用于提取User,断言成功后应检查指针是否为nil;Go不支持直接指针类型转换,需通过值转换或unsafe包操作;对接口进行断言时必须确保类型完全一致,常见错误是混淆指针与值类型。 在Go语言中,指针类型的类型断言和类型转换是开发中常见但容易出错的…

    2025年12月16日
    000
  • 如何在Golang中理解指针与内存地址

    指针是存储变量内存地址的变量,通过&取地址、声明和解引用;Go中指针用于函数传参修改原值、节省大对象传递开销及实现数据共享;new(T)为类型T分配零值内存并返回T指针,仅用于基础类型或结构体;make仅用于slice、map、channel的初始化,不返回指针;nil指针未指向有效内存,解…

    2025年12月16日
    000
  • 在 git2go 中获取 Git 文件模式(Filemode)及处理符号链接

    本文详细介绍了如何使用 `git2go` 库获取 git 仓库中文件或目录的模式(filemode)。通过访问 `treeentry` 结构体的 `filemode` 字段,开发者可以识别条目类型,特别是如何利用 `git.filemodelink` 常量来检测并解析符号链接的目标路径。文章强调了 …

    2025年12月16日
    000
  • Golang模板解析问题:空白页面的原因与解决方案

    本文旨在解决Golang模板解析时出现空白页面的问题。通过分析`template.ParseFiles`和`template.New`的区别,解释了模板名称不匹配导致的问题,并提供了两种有效的解决方案,帮助开发者正确使用Golang模板引擎。 在使用Golang进行Web开发时,模板引擎是不可或缺的…

    2025年12月16日
    000
  • Go 命名返回值与 flag 包的变量声明机制解析

    本文深入探讨 go 语言中命名返回值的工作机制,解释为何在函数签名中声明的命名返回值可以直接用于 `flag.intvar` 等函数,而无需额外使用 `var` 关键字进行显式声明。我们将通过示例代码对比分析,明确命名返回值在函数入口处自动初始化为零值的特性,以及其与未声明变量导致编译错误的根本区别…

    2025年12月16日
    000
  • Go语言多返回值:底层实现与工作原理

    go语言的多返回值机制并非简单地返回一个元组或数组,而是在底层通过将返回值直接放置到调用栈上或寄存器中实现。调用方随后从这些位置检索数据,这种直接的内存或寄存器操作方式,确保了高效的数据传递,与c语言处理单个返回值的方式有异曲同工之妙,但go扩展了其功能以支持多个返回值。 Go语言多返回值机制概述 …

    2025年12月16日
    000
  • Go语言中“声明但未使用”错误的深度解析与解决方案

    本文深入探讨了go语言中常见的“声明但未使用”编译错误,特别是在循环中使用短变量声明符`:=`时引发的变量遮蔽问题。我们将通过示例代码详细解释其发生机制,并提供使用赋值操作符`=`等多种解决方案及最佳实践,帮助开发者避免此类错误,提升代码质量和可读性。 理解Go语言的变量声明与作用域 在Go语言中,…

    2025年12月16日
    000
  • Go 语言中利用 reflect 包动态创建指定类型切片

    本教程详细阐述了如何在 Go 语言中使用 `reflect` 包动态创建指定类型的切片。通过 `reflect.SliceOf` 获取切片类型,并结合 `reflect.MakeSlice` 实现切片的实例化,同时探讨了创建零值切片或空切片的两种方法,并提供示例代码和使用场景建议。 引言:动态切片创…

    2025年12月16日
    000
  • Go语言中变量声明与短变量声明的陷阱:作用域与变量遮蔽

    本文深入探讨go语言中`var`关键字声明与`:=`短变量声明的区别,特别是它们在不同作用域内可能导致的变量遮蔽问题。通过具体示例,解释了为何编译器会报告“变量已声明但未使用”的错误,并提供了正确的变量使用方式,旨在帮助开发者避免此类常见的编译陷阱,提升代码的健壮性和可读性。 理解Go语言的变量声明…

    2025年12月16日
    000
  • Go语言反射:动态创建指定类型的切片(Array)实例

    本文深入探讨了在go语言中如何利用反射机制动态创建指定类型的切片(slice)实例。我们将学习如何使用`reflect.makeslice`来创建具有初始长度和容量的切片,以及如何通过`reflect.zero`来生成一个nil切片,这在处理运行时未知类型或需要构建通用数据结构时尤为关键。 在Go语…

    2025年12月16日
    000
  • Go 语言中结构体方法调用:值类型与指针类型的区别

    本文旨在阐明 Go 语言中,当结构体方法接收者为指针类型时,通过结构体实例(值类型)和结构体指针调用该方法的差异。我们将深入探讨 Go 语言的隐式转换机制,解释为何这两种调用方式最终都能正确执行,并强调理解值类型和指针类型在方法调用中的重要性。 在 Go 语言中,方法是与特定类型关联的函数。当方法接…

    2025年12月16日
    000
  • Go 语言方法调用:结构体与结构体指针的区别

    本文深入探讨了 Go 语言中结构体方法调用的两种方式:直接在结构体实例上调用和通过指向结构体的指针调用。虽然两种方式通常都能得到相同的结果,但其底层机制存在差异。理解这些差异有助于编写更高效、更健壮的 Go 代码。本文将详细解释这两种调用方式的原理,并通过示例代码进行演示,帮助读者深入理解。 在 G…

    2025年12月16日
    000
  • Go并发编程:理解无缓冲通道的死锁

    本文深入探讨了Go语言中无缓冲通道导致死锁的原因。通过分析代码示例,解释了无缓冲通道的阻塞特性,以及在单goroutine中使用无缓冲通道为何会引发死锁。同时,提供了避免死锁的方案,并强调了并发编程中goroutine和通道的协同作用。 在Go语言的并发编程模型中,通道(channel)扮演着至关重…

    2025年12月16日
    000
  • 深入理解Go语言的类型系统:自定义字符串类型与常量转换

    Go语言以其严格的类型系统著称,即使是基于内置类型(如`string`)创建的自定义类型,也被视为完全独立的类型。本文将深入探讨Go语言中自定义字符串类型与内置`string`类型之间的区别,以及在函数调用和类型转换时需要注意的关键点。我们将通过示例代码演示为何直接传递自定义字符串类型到期望`str…

    2025年12月16日
    000
  • Golang如何理解指针与slice、map的区别

    指针直接传递内存地址,可修改原值;slice和map虽为值拷贝,但内部含指针,故能共享底层数组或哈希表,函数中修改元素会反映到外部。 在Go语言中,指针、slice和map的行为容易让人混淆,尤其是在传参和赋值时的表现。理解它们的关键在于:指针是内存地址的引用,而slice和map虽然也表现得像“引…

    2025年12月16日
    000
  • Golang如何通过反射判断函数是否可调用

    答案:在Go中使用reflect.Value的CanCall()方法可判断函数是否可调用,仅当Kind为Func且非nil时返回true,适用于函数、方法或闭包的反射调用检查。 在Go语言中,可以通过反射(reflect包)来判断一个函数是否可调用。关键在于使用 reflect.Value 的 Ca…

    2025年12月16日
    000

发表回复

登录后才能评论
关注微信