草庐IT

write_txt

全部标签

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

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

sockets - golang write net conn 不返回错误但是socket的另一端收不到数据

//onlyDatafunc(self*Packet)WriteData(wio.Writer)error{n:=len(self.Data)data:=self.Data[0:n]forn>0{wn,err:=w.Write(data)data=data[wn:n]n-=wniferr!=nil{returnerr}}returnnil}当我用net.Conn(由net.Dial("tcp")创建)调用WriteData函数时,它返回nil,但套接字的另一个端口有时无法接收到发送的数据。似乎连接中断了,但是w.Write仍然没有错误地返回。在我看来,当此套接字的另一端未收到数据包时,

go - binary.Write() 字节排序不适用于 []byte

packagemainimport("encoding/binary""fmt""bytes")funcmain(){b:=new(bytes.Buffer)c:=new(bytes.Buffer)binary.Write(b,binary.LittleEndian,[]byte{0,1})binary.Write(b,binary.BigEndian,[]byte{0,1})binary.Write(c,binary.LittleEndian,uint16(256))binary.Write(c,binary.BigEndian,uint16(256))fmt.Println(b.B

go - 在 Golang 中,为什么 conn.Write tcp 响应为空?

我有一个读取文件的tcp服务器,该文件将文件内容发送到客户端。“status.txt”文件仅包含一个bool值。当我curl时,这显示true(带有前导空格)。dat,err:=ioutil.ReadFile("./status.txt")conn.Write([]byte(""+string(dat)))而此代码导致curl:(52)Emptyreplyfromserver。conn.Write([]byte(string(dat)))知道为什么会这样吗?我不想填充我的响应字符串。 最佳答案 如果您不使用HTTP协议(protoc

docker - Golang 内置 docker 和 requirements.txt 等价物

我知道Golangrequirements.txtequivalent,但问题的背景却大不相同。我正在尝试优化docker容器内的golang程序构建。我的dockerfile看起来像这样:FROMgolang:1.12.5asbuilderWORKDIR$GOPATH/src/test-ldap/COPYmain.go.RUNgoget-d-v./......虽然我的main.go看起来像packagemainimport("log""fmt""gopkg.in/ldap.v3")funcmain(){...当然,每次我对源代码进行更改时,docker层COPYmain.go.已更改

go - 为什么即使有锁,GO 也会出现 'concurrent map writes' panic ?

当尝试将此结构与多个goroutine一起使用时,有时我会遇到以下错误之一:fatalerror:并发映射读取和映射写入或并发映射写入看完thisthread我确保在构造函数中返回一个引用,并将一个引用传递给接收者。使用它的完整代码在thisgithubrepo中typeconcurrentStoragestruct{sync.Mutexdomainstringurlsmap[url.URL]bool}funcnewConcurrentStorage(dstring)*concurrentStorage{return&concurrentStorage{domain:d,urls:ma

string - 如何在 Go 中将整个字符串保存为 txt 文件?

我正在用Go创建一个简单的文字处理程序。在命令行中,我有两个提示:$输入标题:$输入正文:该程序应该将文档保存为txt文件并将其打印到命令行。如果用户用户键入单字标题和单字正文,则该程序可以运行。但是,如果用户输入一个由多个单词组成的标题,就会发生这种情况:$EnterTitle:Hereisatitle$EnterBody:s$title-bash:title:commandnotfound这是我目前的代码:packagemainimport("fmt""io/ioutil")//CreatestructforadocumenttypeDocumentstruct{Titlestri

bufio 包中的 golang Writer.Write() 与 ioutil 包中的 WriteFile()

当我实际上应该在ioutil上使用bufio包时,我很困惑。例如在写入文件或读取文件时。我有这样的场景,其中有多个函数和API逐阶段处理相同的数据。我不确定在这种情况下选择bufio而不是ioutil是否有帮助?请建议。 最佳答案 bufio包的目的如其所述(https://golang.org/pkg/bufio/)-实现缓冲I/O。因此对于写入,如果不刷新,数据将保留在缓冲区中,如this中所示。例子。Bufio的Write还需要一个实现Writer接口(interface)的对象。而ioutil没有缓冲等-您直接写入命名文件,