为什么go语言中返回的指针类型,不需要用*取值(解引用),就可以直接赋值呢?

Go 中返回的是指针,但你却能直接用"."访问字段,看起来像是"没有解引用",其实是 Go 帮你自动处理了"指针解引用"的语法糖。

在 Go 中,如果你有一个结构体指针(例如 *FileMeta),你可以直接用 p.Field 的方式访问字段,Go 会自动帮你做 (*p).Field 的转换。

🧠 背后原理:自动解引用(auto dereferencing)

go 复制代码
type FileMeta struct {
	FileName string
}

var f = &FileMeta{FileName: "test"}
fmt.Println(f.FileName)  // ✅ 等价于 fmt.Println((*f).FileName)

Go 编译器会自动将指针字段访问 f.Field 翻译为 (*f).Field,这叫做"自动解引用",是 Go 语言为了简化语法做的语法糖处理。

❓ 那什么时候需要 * 解引用?

你只在需要整个值而不是字段的时候才需要手动解引用,例如赋值、拷贝等:

go 复制代码
p := &Person{Name: "Alice"}
val := *p  // 拷贝整个结构体
fmt.Println(val.Name)

今天在写代码的时候发现的很奇妙的go特性:go不需要手动解引用,可以直接.field取值

go 复制代码
func GetFileInfo(fileSha1 string) (*fileInfo, bool) {
	stmt, err := mydb.DBconn().Prepare(
		"select file_sha1,file_addr,file_name,file_size from tbl_file " +
			"where file_sha1=? and status=1 limit 1")
	if err != nil {
		fmt.Println(err)
		return &fileInfo{}, false
	}
	defer stmt.Close()
	fileInfo := fileInfo{}
	//var fileInfo fileInfo
	err = stmt.QueryRow(fileSha1).Scan(&fileInfo.FileSha1, &fileInfo.Location, &fileInfo.FileName, &fileInfo.FileSize)
	if err != nil {
		fmt.Println("查询失败!" + err.Error())
		return &fileInfo, false
	}
	return &fileInfo, true
}
go 复制代码
func GetFileMetaDB(filehash string) (*FileMeta, bool) {
	fileInfo, ok := db.GetFileInfo(filehash)
	if !ok {
		return &FileMeta{}, false
	}
	filemetaDB := FileMeta{
		FileSha1: fileInfo.FileSha1,
		FileSize: fileInfo.FileSize.Int64,
		Location: fileInfo.Location.String,
		FileName: fileInfo.FileName.String,
	}
	return &filemetaDB, true
}
相关推荐
独隅3 小时前
在 Lua 中,你可以使用 `os.date()` 函数轻松地将时间戳转换为格式化的时间字符串
开发语言·lua
思麟呀4 小时前
Linux的基础IO流
linux·运维·服务器·开发语言·c++
星释4 小时前
Rust 练习册 :Pythagorean Triplet与数学算法
开发语言·算法·rust
星释4 小时前
Rust 练习册 :Nth Prime与素数算法
开发语言·算法·rust
lkbhua莱克瓦245 小时前
Java基础——集合进阶3
java·开发语言·笔记
码事漫谈5 小时前
智能体颠覆教育行业调研报告:英语、编程、语文、数学学科应用分析
后端
蓝-萧5 小时前
使用Docker构建Node.js应用的详细指南
java·后端
多喝开水少熬夜5 小时前
Trie树相关算法题java实现
java·开发语言·算法
QT 小鲜肉5 小时前
【QT/C++】Qt定时器QTimer类的实现方法详解(超详细)
开发语言·数据库·c++·笔记·qt·学习
码事漫谈5 小时前
《C语言点滴》——笑着入门,扎实成长
后端