代码拉取完成,页面将自动刷新
package example
import (
"errors"
"sync/atomic"
"gitee.com/dennis-kk/rpc-go-backend/idlrpc/pkg/protocol"
)
//@title 双队列,一读一写
type TransportRing struct {
transID uint32
isclose uint32
recvbuffer []byte
sendchan chan []byte
}
func NewTransportRing() *TransportRing {
return &TransportRing{
//recvchan: make(chan []byte, 1024*1024),
sendchan: make(chan []byte, 1024*1024),
isclose: 0,
}
}
func (trans *TransportRing) LocalAddr() string {
return ""
}
func (trans *TransportRing) RemoteAddr() string {
return ""
}
func (trans *TransportRing) GlobalIndex() protocol.GlobalIndexType {
return 0
}
func (trans *TransportRing) Write(pkg []byte, length int) (int, error) {
trans.recvbuffer = append(trans.recvbuffer, pkg...)
return len(trans.recvbuffer), nil
}
func (trans *TransportRing) Read(pkg []byte, length int) (int, error) {
if len(trans.recvbuffer) < length {
return 0, nil
}
real := copy(pkg, trans.recvbuffer[:length])
if real != length {
return 0, nil
}
trans.recvbuffer = trans.recvbuffer[length:]
return length, nil
}
func (trans *TransportRing) Peek(length int) ([]byte, int, error) {
if trans == nil {
return nil, 0, errors.New("Messages Trans Error !")
}
if len(trans.recvbuffer) < length {
return nil, len(trans.recvbuffer), nil
}
return trans.recvbuffer[:length], length, nil
}
func (trans *TransportRing) Send(pkg []byte) error {
if atomic.LoadUint32(&trans.isclose) == 0 {
trans.sendchan <- pkg
}
return nil
}
func (trans *TransportRing) PopSend() []byte {
return <-trans.sendchan
}
func (trans *TransportRing) Size() uint32 {
return uint32(len(trans.recvbuffer))
}
func (trans *TransportRing) Close() {
atomic.StoreUint32(&trans.isclose, 1)
}
func (trans *TransportRing) IsClose() bool {
return atomic.LoadUint32(&trans.isclose) == 0
}
func (trans *TransportRing) GetID() uint32 {
return trans.transID
}
func (trans *TransportRing) SetID(id uint32) {
trans.transID = id
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。