buffer.go 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. package xugu
  2. import (
  3. "errors"
  4. "fmt"
  5. "net"
  6. "time"
  7. )
  8. var (
  9. ErrBusyBuffer = errors.New("busy buffer")
  10. )
  11. type buffer struct {
  12. buf []byte // buf 是一个字节缓冲区,长度和容量相等。
  13. conn net.Conn
  14. idx int
  15. length int
  16. timeout time.Duration
  17. }
  18. // newBuffer 分配并返回一个新的缓冲区。
  19. func newBuffer(nc net.Conn) buffer {
  20. return buffer{
  21. buf: make([]byte, 2048),
  22. conn: nc,
  23. }
  24. }
  25. // store 存储 buf,这是一个更新的缓冲区,如果合适的话。
  26. func (b *buffer) store(buf []byte) error {
  27. if len(buf) > cap(b.buf) {
  28. fmt.Println("大于缓冲区: len(buf) > cap(b.buf)")
  29. return ErrBusyBuffer
  30. }
  31. b.buf = buf[:cap(buf)]
  32. return nil
  33. }
  34. func (b *buffer) peekChar() byte {
  35. ret := b.buf[b.idx]
  36. return ret
  37. }
  38. // 返回指定字节的切片
  39. func (b *buffer) readNext(need int, reverse bool) []byte {
  40. //长度不够返回
  41. if len(b.buf[b.idx:]) < need {
  42. //调用一次接收服务器消息
  43. b.conn.Read(b.buf[b.idx:])
  44. offset := b.idx
  45. b.idx += need
  46. return b.buf[offset:b.idx]
  47. }
  48. offset := b.idx
  49. b.idx += need
  50. fmt.Println("readNext: 大端值", b.buf[offset:b.idx], " - ", string(b.buf[offset:b.idx]))
  51. //fmt.Println("readNext: ", b.buf[offset:b.idx])
  52. if reverse {
  53. tmp2 := b.buf[offset:b.idx]
  54. fmt.Println("readNext: 转换小端前", tmp2, " - ", string(tmp2))
  55. tmp := reverseBytes(b.buf[offset:b.idx])
  56. fmt.Println("readNext: 转换小端后", tmp, " - ", string(tmp))
  57. return tmp
  58. } else {
  59. return b.buf[offset:b.idx]
  60. }
  61. }