[已解决]RPC传输结构体的问题

luijianfie · · 2261 次点击 · 开始浏览    置顶
这是一个创建于 的主题,其中的信息可能已经有所发展或是发生改变。

刚学go不久,遇到比较奇怪的事情,想请教一下。(另外排版比较挫,见谅) 是这样的 leaderSendAppendEntries里面通过goroutine来执行 rf.sendAppendEntriesRPC(index, &args, &reply),然后发现这么传的话args到了RequestAppendEntiresRPC里面总是nil。 但是通过rf.sendAppendEntriesRPC(index, argsOutsize, &reply)的方式来发送,也就是从goroutine外传输argsOutsize指针,就没什么问题,这个是什么原因呢? `func (rf *Raft) leaderSendAppendEntries(cmd interface{}){` argsOutsize := AppendEntriesRPCArgs{...} go func(rf *Raft, index int, argsOutsize *AppendEntriesRPCArgs, result []bool) { for { reply := AppendEntriesRPCReply{} args := AppendEntriesRPCArgs{ Term: rf.currentTerm, LeaderId: rf.me, PrevLogIndex: rf.nextIndex[index] - 1, PrevLogTerm: rf.log[rf.nextIndex[index]-1].(logContent).Term, LeaderCommit: rf.commitIndex, Entries: make([]interface{}, 0), } if cmd != nil { (args).Entries = append(args.Entries, rf.log[args.PrevLogIndex+1:]...) } ok := rf.sendAppendEntriesRPC(index, &args, &reply) //ok := rf.sendAppendEntriesRPC(index,argsOutsize , &reply) } }(rf, index, &argsOutsize , result) } } ```func (rf *Raft) sendAppendEntriesRPC(server int, args *AppendEntriesRPCArgs, reply *AppendEntriesRPCReply) bool {``` ok := rf.peers[server].Call("Raft.RequestAppendEntiresRPC", args, reply) return ok }

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

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

2261 次点击  
加入收藏 微博
1 回复  |  直到 2021-03-19 14:20:12
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传