jjzjj

MPI_ERR_BUFFER

全部标签

go - 不能在 func 参数中使用 bytes.Buffer 作为 io.WriterAt 类型

今天在go上苦苦挣扎..我不得不问的第二个问题。我有2个测试写入函数Write(),它采用writerio.WriterAt和contentinterface{}.我正在处理为函数编写的(2)个测试,TestWriteSuccessful和TestWriteFail。我在测试这两个函数时得到的错误是:cannotuse&b(type*bytes.Buffer)astypeio.WriterAtinargumenttoWrite:问题什么实现了我可以在这些测试中替换bytes.Buffer以使测试正常运行的WriterAt?我尝试过的将b的类型更改为os.File-b.len()>0将失

go - 如何修复m [0] == nil {},以便将其计入err

我正在编写一个代码,并停留在m[0]==nil。如果代码包含{[]error{nil,err},则应返回err==1{returnm[0].Error()}但是插入它会将nil计为err并返回form[0]==nil{return"0errors"另一个示例是{[]error{err,nil},应该返回m[0].Error(),而不是err==2我添加了m==nil和(m[0]==nil-否则我会感到恐慌:运行时错误:无效的内存地址或nil指针取消引用)typeErrors[]errorfunc(mErrors)Error()string{ifm==nil{return"(0error

go - 为什么是 "err != nil"?

这个问题在这里已经有了答案:Hidingnilvalues,understandingwhyGofailshere(3个答案)关闭7年前。我遇到这样一种情况,变量“errerror”的值只能是“nil”,但在重新分配后断言“(err==nil)==false”。示例代码如下:packagemainimport("fmt""log")typeTestErrorstruct{Messagestring}func(e*TestError)Error()string{returne.Message}funcNewTestError(errerror)*TestError{iferr==nil{

pointers - 为什么在将它传递给另一个函数时需要指向 Go bytes.Buffer 的指针?

在下面的代码中,write_commas要求缓冲区参数是一个指针。它有效。替代方案(即不使用指针)会导致空白输出。为什么传递实际的bytes.Buffer无法打印任何内容?或者换句话说,传递实际的bytes.Buffer是否会创建一个副本,从而将字节写入一个没有任何内容正在读取的缓冲区?packagemainimport("fmt""bytes")funcmain(){s:="1234567898"fmt.Println(Comma(s))}funcComma(sstring)string{varbufbytes.Buffer//0{whole_part:=sbytes[:decima

go - 如何将 []byte 转换为 *bytes.Buffer

我正在尝试解码通过另一个fasthttp端点发送的gob输出并收到错误Fasthttpendpoint(encode[]stringthroughgob)---->Fasthttpendpoint(接收和解码)buffer:=&bytes.Buffer{}buffer=ctx.PostBody()backToStringSlice:=[]string{}gob.NewDecoder(buffer).Decode(&backToStringSlice)我收到错误:ctx.PostBody()(type[]byte)astype*bytes.Bufferinassignment如何将[]b

go - CheckErr(err) 函数在 golang 中崩溃

如果我运行此代码,一切正常,最终结果没有明显错误(正在打印正确的ID)。stmt,err:=db.Conn.Prepare("INSERTINTOtablenameaVALUES(?)")CheckErr(err)deferstmt.Close()res,err:=stmt.Exec(&t.Id)CheckErr(err)id,err:=res.LastInsertId()fmt.Println(id)但是当我在最后添加另一个CheckErr(err)并运行时,我得到了这个:runtimeerror:invalidmemoryaddressornilpointerdereference

go - 不能在 db.Query 的参数中使用缓冲区(类型 bytes.Buffer)作为类型字符串

我在buffer.WriteString()中编写了一个SQL查询,但无法在db.Query()中使用该缓冲区。buffer.WriteString(fmt.Sprintf(`SELECTc.id,c.company_name,ss.start_date,ss.shift_length,ss.bill_rate,ss.ot_hrs,ss.dt_hrs,ts.pay_rate,ts.wc_rate,ts.paid,td.wcFROMcompanycJOINusersu1ONc.id=u1.company_idJOINschedulesONu1.id=s.user_idJOINschedu

go - 我无法从 strconv 包访问 err.Err

我可能在这里遗漏了一些非常简单的东西:packagemainimport("fmt""strconv""reflect")funcmain(){s:="abd"fmt.Println(s)_,err:=strconv.Atoi(s)iferr!=nil{fmt.Println(err)}fmt.Println(reflect.TypeOf(err))fmt.Println(err.Err)}我正在尝试提取错误本身,例如ErrSyntax或ErrRange,但我做不到。看完之后:https://golang.org/src/strconv/atoi.go?s=3604:3671#L16我

variables - Golang 未定义 : err

我正在尝试简单的以下转换程序。packagemainimport("fmt""strconv")funcmain(){varnumStrstring="2213"varnumVarint64numVar,err=strconv.ParseInt(numStr,10,64)fmt.Println(numVar)}以上抛出以下编译错误。undefined:err然后我尝试定义err,error变量。packagemainimport("fmt""strconv")funcmain(){varnumStrstring="2213"varnumVarint64varerrerrornumVar

json - Protocol Buffer 格式的匿名结构

给定这样一个Go结构:typeHousestruct{AddressstringRooms[]struct{NamestringWindowsintDoorsint}}或等效的JSON表示:{"address":"""rooms":[{"name":"""windows":0"doors":0}]}等效的ProtocolBuffer表示是什么?这或多或少是我想做的(尽管不是有效的Proto语法):messageHouse{stringaddress=1;repeatedmessage{stringname=3;int32windows=4;int32doors=5;}rooms=2;}