首页 > 后端开发 > Golang > 正文

Golang函数如何定义_Golang函数参数返回值与命名规范

P粉602998670
发布: 2025-12-20 17:11:02
原创
390人浏览过
Go函数定义简洁明确,参数类型写在变量名后、返回值类型在签名末尾,支持多返回值和命名返回值;所有参数值传递,切片等类型表现类似引用;命名规范为小写驼峰、意图清晰。

golang函数如何定义_golang函数参数返回值与命名规范

Go语言中函数定义简洁明确,核心在于参数类型写在变量名之后、返回值类型紧随函数签名末尾,支持多返回值和命名返回值——这是和其他语言(比如Python或Java)最直观的区别

函数基本定义格式

Go函数以func关键字开头,语法结构为:

func 函数名(参数名 类型, 参数名 类型) 返回值类型 { 函数体 }

例如:

立即学习go语言免费学习笔记(深入)”;

func add(a int, b int) int {
  return a + b
}

注意:参数列表中相同类型的相邻参数可合并写法:
func add(a, b int) int { return a + b }

Supermeme
Supermeme

Supermeme是一个AI驱动的Meme生成器,可以快速生成有趣的Meme梗图

Supermeme 114
查看详情 Supermeme

多返回值与命名返回值

Go原生支持多个返回值,常见于错误处理(如value, err)。返回值可命名,此时会在函数入口自动声明为局部变量,且return语句可不带参数(称为“裸返回”)。

示例:

func divide(a, b float64) (result float64, err error) {
  if b == 0 {
    err = fmt.Errorf("division by zero")
    return // 裸返回,自动返回当前 result 和 err 的值
  }
  result = a / b
  return
}

⚠️ 注意:命名返回值提升可读性,但不宜滥用;裸返回容易掩盖逻辑,仅在逻辑简单、意图明确时使用。

参数类型:值传递、指针、切片、接口等

  • 所有参数都是值传递 —— 传入的是副本。若需修改原值,须传指针(如 func swap(x, y *int))
  • 切片(slice)、map、channel、func 类型本身包含指针字段,传参时“表现像引用”,但底层仍是值传递(复制头信息)
  • 可变参数用...语法,必须放在参数列表末尾,类型统一,例如 func sum(nums ...int) int
  • 接收接口类型参数可提高灵活性,例如 func printAll(w io.Writer, msgs ...string)

命名规范:小写驼峰 + 意图清晰

Go社区约定:导出(对外公开)函数首字母大写,未导出函数全小写;名称应体现行为而非类型。

  • ✅ 推荐:CalculateTotal, isValid, newRouter, parseJSON
  • ❌ 避免:GetUserList(冗余动词+名词,可简化为 userslistUsers),IntAdd(类型前缀不必要)
  • 单测函数名常以 Test 开头 + 被测函数名 + 场景,如 TestDivideByZero

基本上就这些。Go函数设计强调显式、直接、少隐含规则——写清楚参数、写清楚返回、名字说清干啥,代码就自然好懂好维护。

以上就是Golang函数如何定义_Golang函数参数返回值与命名规范的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号