并发安全基本类型。
使用场景:
gtype使用得非常频繁,任何需要并发安全的场景下都适用。
在普通的并发安全场景中,一个基本类型的变量,特别是一个struct含有若干的属性,往往使用互斥(读写)锁或者多把(读写)锁来进行安全管理。 但这样的使用中,变量/struct/属性的操作性能十分低下,且由于互斥锁机制的存在往往使得操作变得相当复杂,必须小心翼翼地维护好变量/属性的并发安全控制(特别是(RW)Mutex)。
gtype针对于最常用的基本数据类型,提供了对应的并发安全数据类型,便于在并发安全场景下更好地维护变量/属性,开发者无需在struct中再创建和维护繁琐的(RW)Mutex。由于gtype维护的是基本类型的并发安全,因此内部基本都使用了atomic原子操作来维护并发安全性,因此效率往往会比(RW)Mutex互斥锁高出数十倍。
使用方式:
import "github.com/gogf/gf/container/gtype"
接口文档:
https://godoc.org/github.com/gogf/gf/container/gtype
使用示例
gtype并发安全基本类型的使用非常简单,往往就类似以下几个方法(以gtype.Int类型举例)
func NewInt(value ...int) *Intfunc (v *Int) Add(delta int) (new int)func (v *Int) Cas(old, new int) boolfunc (v *Int) Clone() *Intfunc (v *Int) Set(value int) (old int)func (v *Int) String() stringfunc (v *Int) Val() int
示例1,基本使用
package mainimport ("github.com/gogf/gf/container/gtype""fmt")func main() {// 创建一个Int型的并发安全基本类型对象i := gtype.NewInt()// 设置值fmt.Println(i.Set(10))// 获取值fmt.Println(i.Val())// 数值-1,并返回修改之后的数值fmt.Println(i.Add(-1))}
执行后,输出结果为:
0109
示例2,JSON序列化/反序列
gtype模块下的所有容器类型均实现了标准库json数据格式的序列化/反序列化接口。
1、Marshal
package mainimport ("encoding/json""fmt""github.com/gogf/gf/container/gtype")func main() {type Student struct {Id *gtype.IntName *gtype.StringScores *gtype.Interface}s := Student{Id: gtype.NewInt(1),Name: gtype.NewString("john"),Scores: gtype.NewInterface([]int{100, 99, 98}),}b, _ := json.Marshal(s)fmt.Println(string(b))}
执行后,输出结果:
{"Id":1,"Name":"john","Scores":[100,99,98]}
2、Unmarshal
package mainimport ("encoding/json""fmt""github.com/gogf/gf/container/gtype")func main() {b := []byte(`{"Id":1,"Name":"john","Scores":[100,99,98]}`)type Student struct {Id *gtype.IntName *gtype.StringScores *gtype.Interface}s := Student{}json.Unmarshal(b, &s)fmt.Println(s)}
执行后,输出结果:
{1 john [100,99,98]}
