草庐IT

tcp_keepalive_time

全部标签

戈朗 : Wait x amount of time before looping again without starting new goroutine

我有一个循环,需要等待一段随机时间才能再次循环。我有什么:for{rand.Seed(time.Now().UnixNano())r:=rand.Int()//Dostufft,_:=time.ParseDuration(string(r)+"ms")time.Sleep(t)}不幸的是,循环会运行多次,就像time.Sleep不工作一样。 最佳答案 您应该检查当前从t,_:=time.ParseDuration中丢弃的错误:您传递给Sleep的time.Duration处于零值,这会导致函数休眠0纳秒。更改#1:处理错误t,err

time - 如何仅使用 time.After 编写我自己的 Sleep 函数?

我正在尝试使用Go中的time.After编写自己的sleep函数,等同于time.Sleep。这是代码。第一次尝试:funcSleep(xint){msg:=make(chanint)msg:=第二次尝试:funcSleep(xint){time.After(time.Second*x)}两者都返回错误,有人可以向我解释如何使用time.After编写等同于time.Sleep的sleep函数吗?如果可能的话,我什么时候使用channel? 最佳答案 time.After()返回给你一个channel。在指定的持续时间后,将在ch

Go time.Tick 与 time.NewTicker

我是Go的新手,最近才开始学习。我遇到过自动收报机和计时器。在代码中,我们可以通过两种方式创建代码throttler:=time.Tick(time.Millisecond*50)除了语法之外,它们之间还有什么区别? 最佳答案 来自time.Tickdocumentation:TickisaconveniencewrapperforNewTickerprovidingaccesstothetickingchannelonly.WhileTickisusefulforclientsthathavenoneedtoshutdownthe

parsing - 将字符串解析为 time.Time 值

这个问题在这里已经有了答案:ParsingRFC-3339/ISO-8601date-timestringinGo(8个答案)关闭5年前。我有一个格式为20171023T183552的字符串时间。我没有找到任何格式来解析这个字符串值。有什么方法可以将此字符串值转换为Gotime.Time吗?编辑-这不是重复的问题。我知道如何解析,但我不知道我们可以使用时间格式包中列出的布局以外的任何布局。这个答案消除了我的疑问。

sockets - 通过 TCP 处理多个客户端

好的,我刚开始学习golang,到目前为止我很喜欢它。但是我没有发现他们的文档适合入门者,这是我的问题。我想编写接受连接并向客户端写入内容的小服务器程序。到目前为止没有问题。然而,一旦它获得真正的功能,我就需要能够处理多个客户端,我认为这也是goroutines的一个很好的练习。listener,error:=net.Listen("tcp",remote)con,error:=listener.Accept()gohandleClient(&con);funchandleClient(con*net.Conn){我已经删除了大部分代码。问题是,无论我尝试什么,我都无法通过con。co

go - 将整个函数放在一个带有 time.Sleep 的无限循环中还是循环一个 go routine 效率更高?

我有一个函数,我想每20秒左右轮询一次,现在它在go例程中被调用,如下所示:转到StartTradeBot()然后在函数体中:funcStartTradeBot(){for{//Allthestufftodotime.Sleep(20*time.Second)}}这样效率更高吗?或者我应该像这样包装我的goroutinefor{goStartTradeBot()time.Sleep(20*time.Second)} 最佳答案 关于如何做到这一点,至少有三种变体,每种都有不同的功能。因为间隔是20秒,所以性能上的差异可以忽略不计。选择

Golang tcp客户端服务器程序

我可以做服务器程序或客户端程序,但我不知道如何做客户端/服务器程序。有人知道这段代码有什么问题吗?谢谢。packagemainimport("net""os""bufio""io")funcmain(){listen,_:=net.Listen("tcp","localhost:9001")dial,_:=net.Dial("tcp","localhost:9002")scanner:=bufio.NewScanner(os.Stdin)forscanner.Scan(){conn,_:=listen.Accept()ifscanner.Text()=="a"{conn.Close()

parsing - 更改 time.Time 时区而不重新解析

我正在处理使用错误时区解析的time.Time对象。它们内部有一个UTCtz,但原始数据来自旧版MySQL数据库,该数据库在内部存储带有欧洲/巴黎时区的日期时间。我想在不重新解析的情况下更改时间的内部时区。我尝试了time.In()函数,但它没有解决我的用例,因为它返回另一个时区的同一时间。我的最终解决方案是使用https://golang.org/pkg/time/#ParseInLocation使用正确的位置从原始值重新创建日期。但是,如果可以避免这种情况,那就更好了。有什么想法吗?谢谢。 最佳答案 你能为他们添加固定offes

go - 为什么这两个 time.Time 实例对于 UTC 是相同的而对于另一个位置是不同的?

我希望这两个time.Time实例是相同的。但是,我不确定为什么我得到的比较结果是错误的。packagemainimport("fmt""time")funcmain(){t:=int64(1497029400000)locYangon,_:=time.LoadLocation("Asia/Yangon")dt:=fromEpoch(t).In(locYangon)locYangon2,_:=time.LoadLocation("Asia/Yangon")dt2:=fromEpoch(t).In(locYangon2)fmt.Println(dt2==dt)}funcfromEpoch

asynchronous - 如何有效地解码 gobs 并等待更多通过 tcp 连接到达

我想为游戏应用程序建立TCP连接。时间效率很重要。我想有效地接收许多对象。由于负载的原因,提高CPU效率也很重要。到目前为止,我可以确保每次使用go的net库调用连接时都会调用handleConnection。但是,一旦创建了连接,我就必须进行轮询(一遍又一遍地检查以查看连接上是否已准备好新数据)。这似乎效率低下。如果新数据不必要地占用CPU,我不想运行该检查以查看新数据是否已准备就绪。我一直在寻找诸如以下两个选项之类的东西,但没有找到我要找的东西。(1)执行以某种方式阻塞(不占用CPU)的读取操作,然后在连接流上准备好新内容时解除阻塞。我找不到那个。(2)采用异步方法,当新数据到达连