gf/container/gtype/byte.go

77 lines
2.1 KiB
Go
Raw Normal View History

// Copyright 2018 gf Author(https://github.com/gogf/gf). All Rights Reserved.
2018-04-12 14:09:33 +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,
// You can obtain one at https://github.com/gogf/gf.
2018-04-12 14:09:33 +08:00
package gtype
import (
"github.com/gogf/gf/util/gconv"
"strconv"
2019-06-19 09:06:52 +08:00
"sync/atomic"
2018-04-12 14:09:33 +08:00
)
2019-12-20 23:23:50 +08:00
// Byte is a struct for concurrent-safe operation for type byte.
2018-04-12 14:09:33 +08:00
type Byte struct {
value int32
2018-04-12 14:09:33 +08:00
}
2019-12-20 23:23:50 +08:00
// NewByte creates and returns a concurrent-safe object for byte type,
// with given initial value <value>.
2019-06-19 09:06:52 +08:00
func NewByte(value ...byte) *Byte {
if len(value) > 0 {
return &Byte{
value: int32(value[0]),
}
2019-06-19 09:06:52 +08:00
}
return &Byte{}
2018-04-12 14:09:33 +08:00
}
// Clone clones and returns a new concurrent-safe object for byte type.
func (v *Byte) Clone() *Byte {
2019-06-19 09:06:52 +08:00
return NewByte(v.Val())
2018-08-28 17:06:49 +08:00
}
// Set atomically stores <value> into t.value and returns the previous value of t.value.
func (v *Byte) Set(value byte) (old byte) {
2019-06-19 09:06:52 +08:00
return byte(atomic.SwapInt32(&v.value, int32(value)))
2018-04-12 14:09:33 +08:00
}
2019-12-20 23:23:50 +08:00
// Val atomically loads and returns t.value.
func (v *Byte) Val() byte {
2019-06-19 09:06:52 +08:00
return byte(atomic.LoadInt32(&v.value))
2018-04-12 14:09:33 +08:00
}
// Add atomically adds <delta> to t.value and returns the new value.
func (v *Byte) Add(delta byte) (new byte) {
2019-06-19 09:06:52 +08:00
return byte(atomic.AddInt32(&v.value, int32(delta)))
}
// Cas executes the compare-and-swap operation for value.
func (v *Byte) Cas(old, new byte) (swapped bool) {
return atomic.CompareAndSwapInt32(&v.value, int32(old), int32(new))
2018-04-12 14:09:33 +08:00
}
// String implements String interface for string printing.
func (v *Byte) String() string {
return strconv.FormatUint(uint64(v.Val()), 10)
}
// MarshalJSON implements the interface MarshalJSON for json.Marshal.
func (v *Byte) MarshalJSON() ([]byte, error) {
return gconv.UnsafeStrToBytes(strconv.FormatUint(uint64(v.Val()), 10)), nil
}
// UnmarshalJSON implements the interface UnmarshalJSON for json.Unmarshal.
func (v *Byte) UnmarshalJSON(b []byte) error {
v.Set(gconv.Uint8(gconv.UnsafeBytesToStr(b)))
return nil
}
// UnmarshalValue is an interface implement which sets any type of value for <v>.
func (v *Byte) UnmarshalValue(value interface{}) error {
v.Set(gconv.Byte(value))
return nil
}