对象:锁对 receiver 的影响

本文探讨了Go语言中receiver设定的选择,强调了在涉及锁(mutex)时,使用指针receiver的重要性,以确保同步机制的有效性。通过分析锁对receiver的影响,解释了为何在多进程访问时,复制数据结构会导致锁失效。此外,文章还通过汇编调试,揭示了方法调用时,编译器如何隐式传递receiver参数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

receiver设定

  • 要修改数据状态,使用*T。
  • 无需修改状态的小对象或固定值,建议使用T。
  • 大对象使用*T,避免过高的参数复制成本。
  • 引用类型、字符串、函数等指针包装对象,直接使用T。
  • 包含锁(mutex)的复合结构,使用*T,避免锁被复制后失效。
  • 无法确定时使用*T,以维护唯一实例。

到底用X还是用*X,什么情况用值,什么情况用指针?它们都属于X类型的方法,怎么选择有一些简单的规则。比如修改X状态用指针,因为第一个参数是指针才能修改,传进来是拷贝修改不了。第二就是不打算修改而且是个小对象或者值是固定的建议用拷贝,因为要尽可能的避免去修改。这样的话在多个线程调用的时候不用进行同步,如果两个线程同时引用,只用指针引用同一个数据要同步处理。如果对象很大的情况下,参数复制成本会很高。另外引用类型字符串、切片、通道就是包装指针,没有必要再用指针方式。如果复合结构有锁的情况下,需要使用指针,因为复制复合结构变成两个,那同步机制可能失效。方法是用来修改或者维护或者展示原始数据的。

锁(mutex)对receiver的影响

假设定义数据结构,数据结构内部有个匿名字段用于加锁的,多进程访问需要小心,value方法Data是个复制品,复制品的M

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值