2019-02-02 16:18:25 +08:00
|
|
|
// Copyright 2018 gf Author(https://github.com/gogf/gf). All Rights Reserved.
|
2018-03-27 15:09:17 +08:00
|
|
|
//
|
|
|
|
// This Source Code Form is subject to the terms of the MIT License.
|
|
|
|
// If a copy of the MIT was not distributed with this file,
|
2019-02-02 16:18:25 +08:00
|
|
|
// You can obtain one at https://github.com/gogf/gf.
|
2018-03-27 15:09:17 +08:00
|
|
|
|
|
|
|
package gtype
|
|
|
|
|
|
|
|
import (
|
2019-09-29 15:59:09 +08:00
|
|
|
"github.com/gogf/gf/util/gconv"
|
|
|
|
"strconv"
|
2019-06-19 09:06:52 +08:00
|
|
|
"sync/atomic"
|
2018-03-27 15:09:17 +08:00
|
|
|
)
|
|
|
|
|
2019-12-20 23:23:50 +08:00
|
|
|
// Int32 is a struct for concurrent-safe operation for type int32.
|
2018-03-27 15:09:17 +08:00
|
|
|
type Int32 struct {
|
2019-04-15 22:55:12 +08:00
|
|
|
value int32
|
2018-03-27 15:09:17 +08:00
|
|
|
}
|
|
|
|
|
2019-12-20 23:23:50 +08:00
|
|
|
// NewInt32 creates and returns a concurrent-safe object for int32 type,
|
2019-04-15 22:55:12 +08:00
|
|
|
// with given initial value <value>.
|
2019-06-19 09:06:52 +08:00
|
|
|
func NewInt32(value ...int32) *Int32 {
|
|
|
|
if len(value) > 0 {
|
|
|
|
return &Int32{
|
|
|
|
value: value[0],
|
2019-04-15 22:55:12 +08:00
|
|
|
}
|
2019-06-19 09:06:52 +08:00
|
|
|
}
|
|
|
|
return &Int32{}
|
2018-03-27 15:09:17 +08:00
|
|
|
}
|
|
|
|
|
2019-04-15 22:55:12 +08:00
|
|
|
// Clone clones and returns a new concurrent-safe object for int32 type.
|
2019-06-18 08:37:21 +08:00
|
|
|
func (v *Int32) Clone() *Int32 {
|
2019-06-19 09:06:52 +08:00
|
|
|
return NewInt32(v.Val())
|
2018-08-28 17:06:49 +08:00
|
|
|
}
|
|
|
|
|
2019-05-08 17:21:18 +08:00
|
|
|
// Set atomically stores <value> into t.value and returns the previous value of t.value.
|
2019-06-18 08:37:21 +08:00
|
|
|
func (v *Int32) Set(value int32) (old int32) {
|
2019-06-19 09:06:52 +08:00
|
|
|
return atomic.SwapInt32(&v.value, value)
|
2018-03-27 15:09:17 +08:00
|
|
|
}
|
|
|
|
|
2019-12-20 23:23:50 +08:00
|
|
|
// Val atomically loads and returns t.value.
|
2019-06-18 08:37:21 +08:00
|
|
|
func (v *Int32) Val() int32 {
|
2019-06-19 09:06:52 +08:00
|
|
|
return atomic.LoadInt32(&v.value)
|
2018-03-27 15:09:17 +08:00
|
|
|
}
|
|
|
|
|
2019-05-08 17:21:18 +08:00
|
|
|
// Add atomically adds <delta> to t.value and returns the new value.
|
2019-06-18 08:37:21 +08:00
|
|
|
func (v *Int32) Add(delta int32) (new int32) {
|
2019-06-19 09:06:52 +08:00
|
|
|
return atomic.AddInt32(&v.value, delta)
|
2019-06-18 08:37:21 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// Cas executes the compare-and-swap operation for value.
|
2020-01-16 21:04:28 +08:00
|
|
|
func (v *Int32) Cas(old, new int32) (swapped bool) {
|
2019-06-18 08:37:21 +08:00
|
|
|
return atomic.CompareAndSwapInt32(&v.value, old, new)
|
2019-06-19 09:06:52 +08:00
|
|
|
}
|
2019-09-29 15:59:09 +08:00
|
|
|
|
2019-10-01 16:03:18 +08:00
|
|
|
// String implements String interface for string printing.
|
|
|
|
func (v *Int32) String() string {
|
|
|
|
return strconv.Itoa(int(v.Val()))
|
|
|
|
}
|
|
|
|
|
2019-09-29 15:59:09 +08:00
|
|
|
// MarshalJSON implements the interface MarshalJSON for json.Marshal.
|
|
|
|
func (v *Int32) MarshalJSON() ([]byte, error) {
|
|
|
|
return gconv.UnsafeStrToBytes(strconv.Itoa(int(v.Val()))), nil
|
|
|
|
}
|
2019-09-29 20:12:59 +08:00
|
|
|
|
|
|
|
// UnmarshalJSON implements the interface UnmarshalJSON for json.Unmarshal.
|
|
|
|
func (v *Int32) UnmarshalJSON(b []byte) error {
|
|
|
|
v.Set(gconv.Int32(gconv.UnsafeBytesToStr(b)))
|
|
|
|
return nil
|
|
|
|
}
|
2020-01-20 19:56:42 +08:00
|
|
|
|
|
|
|
// UnmarshalValue is an interface implement which sets any type of value for <v>.
|
|
|
|
func (v *Int32) UnmarshalValue(value interface{}) error {
|
|
|
|
v.Set(gconv.Int32(value))
|
|
|
|
return nil
|
|
|
|
}
|