草庐IT

byte-compiling

全部标签

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

arrays - 函数应返回 sha256/sha384/sha512 结果作为 byte slice

我正在编写一个函数,它将输入数据作为字符串和要调用的SHA算法的位大小。它应该将生成的散列作为byteslice返回(第一次尝试):packagemainimport("crypto/sha256""crypto/sha512""errors""fmt")funcmain(){input:="Thisisatest."sha256,_:=shaSum(input,256)sha384,_:=shaSum(input,384)sha512,_:=shaSum(input,512)fmt.Println(input,sha256,sha384,sha512)}funcshaSum(data

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 - 如何修复 'constant x oveflows byte' 错误?

你好,我正在尝试用常量制作一个字节slice,但我收到了constantxoverflowsbyte错误。这是我的常量:const(Starttrame1=0x10AStarttrame2=0x10BStarttrame3=0X10CStarttrame4=0X10DStarttrame5=0X10EStarttrame6=0x10F)下面是我声明slice的方式:varstartValues=[6]byte{Starttrame1,Starttrame2,Startrame3,Starttrame4,Starttrame5,Starttrame6}每次构建时,我都会得到constan

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

compilation - Windows 64 位的 .go 文件编译错误

我最初的问题是,this.peterSO正确回答了这个问题。但是,当我尝试执行.go程序时,我发现了类似this的错误。对于程序1和this对于程序2.任何人都可以帮助我,如何解决这个问题? 最佳答案 您已经安装了多个版本的Go,包括release/release.r60.3和weekly.2011-09-01forwindows386。如果您的PATH环境变量指向8gfor[windows386release.r60.310076]但您的GOROOT环境变量指向[windows386weekly.2011-09-019631]的包

golang 默认将 json 对象解码为 map[string]interface{},如何将其解码为 []byte?

默认情况下,golang将json对象解码为map[string]interface{},如何将其解码为[]byte?因为我需要在获得其类型后将其二次解码为结构实例。 最佳答案 为什么不直接将json解码到结构中?或者如果你有更多的对象到结构的slice中?packagemainimport("encoding/json""fmt")typeTestJsonstruct{FoostringBazstring}var(jsonValue=`{"FOO":"BAR","BAZ":"QUX"}`jsonValueSlice=`[{"FOO

unit-testing - 如何测试 bytes.ErrTooLarge panic 错误

我想在bytes.Buffer.Write方法上模拟bytes.ErrTooLargepanic错误并测试panic处理。我试图写入无限量的数据以超过内存,但随后整个测试崩溃了。还有哪些选择? 最佳答案 听起来像是模拟对象的工作。在测试期间使用此(badBuffer)代替bytes.Buffer。typebadBufferbytes.Bufferfunc(b*badBuffer)Write(p[]byte)(nint,errerror){panic(bytes.ErrTooLarge)}

Golang 而不是工作函数 bytes.Contains()

我对函数bytes.Contains(b,subslice[]byte)bool有奇怪的问题。它没有在函数(c*IPConn)Read(b[]byte)(int,error)中接收到的字节数组中找到字符。应用程序是一个简单的服务器。所以我有字节数组,它是通过服务器接收到变量bufbuf:=make([]byte,1024)Len,err:=c.conn.Read(buf)//belowreceivedcontentinbuf//{"abc":[{"b":5,"bca":14,"xyz":0}]}{"abc":[{"b":7,"hjk":14,"qwe":0}]}现在我想使用下面的函数在