草庐IT

how-to-create-a-socket-based-ipho

全部标签

json - Go 和 JSON : how to dynamically load a field

我知道如何在go中使用JSON和接口(interface)而没有太多问题。我想让用户从JSON字符串中选择一个JSON元素,并将元素模式存储在一个字符串中,以便我以后可以动态加载它。我有以下JSON:{"id":1,"name":"Agreendoor","price":12.50,"tags":["home","green"]}当然,如果我想要我的JSON的id元素,这很容易,因为id是我要保存的字符串。现在假设我想要标签[1]。随着JSON变得越来越复杂,您会发现这变得越来越难。例如,我可能想保存类似于tags[1].data[0].values.id等的模式......基本上,我

sockets - 如何用 Go 读取 FFMPEG?

如何读取从ffmpeg发送的UDP?我写了一个脚本来监听UDP数据包并将它们写入文件,但是该文件是无效的并且几乎是两倍大小。这是我发送数据的方式:ffmpeg-ivideo.mp4-c:aaac-ar48000-ab196k\-ac2-strict-2-c:vlibx264-vb500k-r25-s320x240\-ss00.000-fmp4-movflagsfrag_keyframe+empty_moov\udp://127.0.0.1:1936这是Go中的代码。它应该简单地将视频写入一个新的视频文件:packagemainimport("net""os")funcmain(){va

sockets - io.复制: How to know if a socket is closed or disconnected

我有一个简单的程序,它将程序的stdin、stdout和stderr连接到一个套接字,就像这样,gofunc(){deferconn.Close();deferstdin.Close();io.Copy(stdin,conn);}();gofunc(){deferconn.Close();deferstdout.Close();deferstderr.Close();io.Copy(conn,stdout);io.Copy(conn,stderr);}();select{}我有两个问题,我必须通过执行select{}让这两个goroutine保持运行当套接字断开连接时,无法通知它。如果

go - 我们可以在 Go 中使用 select to Accept() 来自不同的监听器吗?

就像下面的代码:for{select{caseconn,err:=listener1.Accept():iferr!=nil{log.Fatal(err)}gohandleConn1(conn)caseconn,err:=listener2.Accept():iferr!=nil{log.Fatal(err)}gohandleConn1(conn)}}虽然编辑器告诉我select有问题我们可以在Go中实现类似的东西吗? 最佳答案 select仅适用于channel(请在此处查看更多信息:https://gobyexample.com

sockets - 监听套接字时域使用有什么区别?

我在查看的一些示例之间发现了一些差异,并意识到有些使用域而有些则不使用。两者之间的真正区别是什么?net.Listen("tcp",":8080")net.Listen("tcp","localhost:8080") 最佳答案 它有默认参数,表示0.0.0.0、127.0.0.1、localhost。就是方便。net.Listen("tcp",":8080")在这里你可以硬绑定(bind)任何域。net.Listen("tcp","localhost:8080") 关于sockets-监

sockets - 在 goroutines 中使用套接字的正确方法是什么

我在Go语言中阅读了有关套接字的不同内容。是否可以在2个goroutines中使用,在没有任何并发​​控制的情况下进行读写?我在下面显示代码,但我也无法使用channel。我基本上创建了一个小应用程序来拦截某个应用程序的通信协议(protocol),并且在它到达我电脑中的客户端之前从服务器替换了几个字节。为此,我有2个go例程:一个从服务器读取套接字,替换一些字节并发送给客户端。另一个是从客户端读取套接字并发送到服务器。它可以很好地处理几条消息,然后崩溃。这是我的代码和控制台输出:***注意:在python中的类似实现工作正常。packagemainimport("fmt""net""

unit-testing - 优步 Cadence : How do I assert the call to workflow. sleep ()?

在我的单元测试中,我想断言调用了workflow.Sleep()。我该怎么做? 最佳答案 可以使用TestWorkflowEnvironment.Now()函数访问模拟时间。例如:before:=testenv.Now()testenv.ExecuteWorkflow(...)after:=testenv.Now()然后断言before和after之间的变化。 关于unit-testing-优步Cadence:HowdoIassertthecalltoworkflow.sleep()?,

c - 关于定义 : Rewriting Algorithm from Go Code to C

目前正在将加权DAG转换为用Go语言编写并进行拓扑排序的C代码。实际上我错过了代码的一部分,即示例下面的函数。我不知道“访问”声明是什么。它是另一个函数中的函数声明吗?如果您使用C语法进行解释,那就太好了。func(g*graph)topoSort()[]int{result:=make([]int,g.size())marks:=make([]bool,g.size())resultIndex:=g.size()-1varvisitfunc(int)visit=func(uint){for_,item:=rangeg.adjList[u]{if!marks[item.vertex]{

转到 HTML 模板 : something similar to Jinja2 macros?

这部分是我之前question的后续行动.我现在要解决的问题是用参数转换Jinja2宏,例如,类似{%macroexample(arg1,arg2)%}{%ifarg1%}dosomethingwitharg1andarg2{%endif%}{%endmacro%}AFAICT,在Go中,最接近的等价物是嵌套模板,例如,{{define"example"}}{{if.Arg1}}dosomethingwith.Arg1and.Arg2{{end}}{{end}}但是,在Jinja中,arg1和arg2是我所说的真正的参数,即,当您调用example宏时,您将其调用为{{example(

go - bufio.扫描仪 : how to know if we are processing a new line or a truncated string?

我基本上需要处理从流中读取的有限缓冲区中的每个字符串行。使用bufio.Scanner,我可以逐行扫描扫描仪,但不得不使用似乎过于复杂的解决方案来检测“截断”。有更好的方法吗?非常感谢。我对任何lib或任何东西都不紧张。func(p*Parser)Read(data[]byte,tmpline*string,nint,bufSizeint){varlinestringstrdata:=string(data)scanner:=bufio.NewScanner(strings.NewReader(strdata))line=""forscanner.Scan(){ifline!=""{i