奇怪的BUG,救救救救救救救救救救救

xiaoxiao_110 · 2021-10-30 22:27:42 · 1990 次点击 · 大约8小时之前 开始浏览    置顶
这是一个创建于 2021-10-30 22:27:42 的主题,其中的信息可能已经有所发展或是发生改变。

buf := make([]byte, 4)
_, _ = xxx.Read(buf) // xxx 是net.Conn
bagFlag := uint32(data[0]) | uint32(data[1])<<8 | uint32(data[2])<<16 | uint32(data[3])<<24
// fmt.Println("")  // 如果注释掉这一条,bagFlag的值不是预期的值,加上就能正常获取预期的值。
if bagFlag != 4294967295 {
    continue
}

那句fmt.Println 注释掉就没法获取到预期的值,加上就正常了。吐血啦,不知道原因在哪啊。


有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1990 次点击  
加入收藏 微博
10 回复  |  直到 2021-11-18 14:46:14
__Golang__
__Golang__ · #1 · 3年之前

data数据是啥

__Golang__
__Golang__ · #2 · 3年之前

data:=[4]byte{255,255,255,255} bagFlag := uint32(data[0]) | uint32(data[1])<<8 | uint32(data[2])<<16 | uint32(data[3])<<24 先看你data数据对不对

fenglangjuxu
fenglangjuxu · #3 · 3年之前

的确 挺诡异

jinl80
jinl80 · #4 · 3年之前

Reader interface 并不是全部读完了才会返回, 你需要等返回的err 是EOF才能下一步,加了fmt.Println之后相当于增加了等待了时间让网络读取完数据

fenglangjuxu
fenglangjuxu · #5 · 3年之前
jinl80jinl80 #4 回复

Reader interface 并不是全部读完了才会返回, 你需要等返回的err 是EOF才能下一步,加了fmt.Println之后相当于增加了等待了时间让网络读取完数据

zan

Kisesy
Kisesy · #6 · 3年之前

读的时候用 io.readfull() 试试

wn0112
wn0112 · #7 · 3年之前

因为Read是异步的吧? 还没读完. 加个print 有耗时了, 就读完了, 就正确了. 你换成 sleep 估计也可以

moryaden
moryaden · #8 · 3年之前
KisesyKisesy #6 回复

读的时候用 io.readfull() 试试

正解 需要 ReadFull

lysShub
lysShub · #9 · 3年之前

楼上在搞什么,read读取时阻塞的啊。而且就算时异步的,print打印的阻塞也在bagFlag 赋值之后,是没效果的

_Aiden_
_Aiden_ · #10 · 3年之前

一楼问的没错啊,data是个啥,和buf都不是同一个变量

添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传