草庐IT

READ_WRITE

全部标签

go - 如何循环直到 *ipconn.Read() 读取了所有发送给它的数据

我在go中使用*ipconn.Write方法发送一些数据,但似乎*ipconn.Read()一次只能读取20个字节这里是服务器发送数据ln,err:=net.Listen("tcp","localhost:8888")conn,err:=ln.Accept()tmp:=make([]byte,10000)tmp=[]byte("abcdefghijklmnopqrstuvwxyz")conn.Write(tmp)这里是客户端接收数据conn,err:=net.Dial("tcp","localhost:8888")data:=make([]byte,100000)conn.Read(d

go - 在 Heroku 上获取零星的 "http: proxy error: read tcp: i/o timeout"

关闭。这个问题需要debuggingdetails.它目前不接受答案。编辑问题以包含desiredbehavior,aspecificproblemorerror,andtheshortestcodenecessarytoreproducetheproblem.这将有助于其他人回答问题。关闭4年前。Improvethisquestion我在Heroku上偶尔会遇到这个错误:代理服务:Dec2714:53:05betalo-turnpike-productionapp/web.2:{[...]}Dec2714:53:08my-proxyapp/web.2:{"level":"error"

golang Read(p []byte) 没有读取完整字节?

最近使用golangRead(p[]byte),打算读取完整的len(p)字节。但是我发现Read不能保证读取len(p)字节。也就是说,我需要读取4个字节,但实际上它只给了我1个字节。最后我改用了io.ReadFull。现在我很困惑,这个函数是什么意思?使用Read的正确场景是什么?它读取的字节数可能比您需要的少。 最佳答案 如果您查看文档和源代码,您就会明白为什么bufio.Read(p[]byte)不保证将数据完整读取到pReader中。Readreadsdataintop.Itreturnsthenumberofbytesr

go - 我是否对 "How to Write Go Code"示例中 Go 工作区中的 git 存储库结构感到困惑?

我对HowtoWriteGoCode有两点困惑文章。它们可能是文章中的错误,或者我可能只是忽略了重点。在描述典型工作区的结构时,文章说Thesrcsubdirectorytypicallycontainsmultipleversioncontrolrepositories(suchasforGitorMercurial)thattrackthedevelopmentofoneormoresourcepackages.文章中的第一个示例工作区与此描述相匹配,有2个文件夹代表存储库(github.com/golang/example/和golang.org/x/image/),每一个在其正

unit-testing - 单元测试 os.File.Write 调用

我想对调用os.File.Write()的函数进行单元测试,并希望达到100%的覆盖率。此函数返回n和一个错误。引发错误很容易。我只需要关闭文件。我怎样才能不引起写入错误和写入数据长度的值n不同?看起来我应该创建一个虚拟的os.File,我可以在上面控制返回的错误。不幸的是,os.File不是一个接口(interface)。编辑:根据PeterOS的回答,仔细检查文档后,Write()方法,是否为io.Writer或io.File如果err为nil,将始终返回写入的slice的长度。结果,看来我的问题毫无意义。我学到了一些重要的东西,谢谢。我有一些代码要清理。附带说明一下,我对100%

go - fatal error : concurrent map read and map write

fatalerror:concurrentmapreadandmapwritegoroutine5065809[running]:runtime.throw(0x6b4281,0x21)/usr/local/go/src/runtime/panic.go:566+0x95fp=0xc420c05670sp=0xc420c05650runtime.mapaccess1_faststr(0x65ea20,0xc420015020,0xc42178ea8e,0x16,0x0)/usr/local/go/src/runtime/hashmap_fast.go:201+0x4f3fp=0xc42

sql-server - Golang 连接到 SQL Server 错误 - "TLS Handshake failed: Cannot read handshake packet: EOF"

我编写了一个系统,可以自动在MicrosoftAzure上部署VM,在上面安装SqlServer,然后针对新安装的服务器执行.sql脚本以初始化环境。周五,这一切都按预期进行。今天,我遇到了这个错误。我的代码具有以下相关导入:import("database/sql"_"github.com/denisenkom/go-mssqldb")并使用以下代码在安装后实际连接到数据库(为简洁起见删除了错误处理)://variablesconnectionString:="sqlserver://MasterUser:MasterPassword@xx.xx.xx.xxx:1433"dbName

go - conn.Read 在通过其他 go 例程关闭 conn 时进入无限循环

我的代码有点复杂,但简单来说,它有多个go例程,所有都调用不同的TCP服务器,并在流中出现可读消息时在for循环中读取输入。到目前为止,一切都很好。现在有另一个go例程来管理之前的一堆“客户端”并在用户需要时关闭它们。为此,我将每个“conn”与适当的goroutine客户端相关联并关闭它。我面临的问题是,只要我调用任何conn对象的close函数,其对应的Read函数就会进入无限循环,不断读取空字符串。我写了一个简单的代码,类似于我在多个go例程中处理连接的方式-https://play.golang.org/p/wq7zt9Kqz7长话短说简而言之,我有一个“类”,它代表一个远程服

go - 运行 dep 时出错确保 : Grouped write of manifest, 锁和 vendor :无法统计 VerifyVendor 声称存在的文件

运行depensure时出现以下错误:Groupedwriteofmanifest,lockandvendor:couldnotstatfilethatVerifyVendorclaimedexisted:stat"pathtopackageinsidevendor":nosuchfileordirectory这是我的Gopkg.toml:[[constraint]]name="github.com/PuerkitoBio/goquery"version="1.5.0"[[constraint]]branch="master"name="github.com/auth0-communi

random - crypto/rand read() 的两个返回值在什么情况下有用?

crypto/rand的典型用法是这样的:salt:=make([]byte,saltLength)n,err:=rand.Read(salt)它用一系列随机字节填充我在这里标记为“salt”的字节slice。在什么情况下随机数生成器可能会失败?在err不为零的情况下退回到数学/兰德等价物是否不安全?由于字节slice的长度是已知的,n对我来说似乎也没用,我有什么理由不直接使用_,err代替它吗? 最佳答案 为了安全起见,您的代码应该看起来更像这样:packagemainimport("crypto/rand""fmt")funcm