草庐IT

total_size_in_bytes

全部标签

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 - "Missing type in composite literal"结构中映射的匿名列表

编辑:编译错误在Missingtypeincompositeliteral与我的问题相同,它们的组成差异很大,以至于我不明白我将如何将解决方案应用到我的程序中,因此创建了这个问题。我是新来的,我正在尝试为我已验证可以成功调用的函数编写测试,如下所示:funcmain(){items:=[]map[string]int{map[string]int{"value":100,"weight":5,},map[string]int{"value":90,"weight":2,},map[string]int{"value":80,"weight":2,},}fmt.Println(KnapS

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

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)}

arrays - Golang : Parsing two array of arrays in JSON, 使用相同的结构

这个问题在这里已经有了答案:Unmarshalingjsonintoatype(2个答案)HowtoUnmarshalthepairvaluesinannestedarraybyjsonforGolang(2个答案)UnmarshalJsondatainaspecificstruct(1个回答)关闭3年前。假设我有这个数据:{"code":10000,"msg":"Successfulrequestprocessing","asks":[["0.03434400","0.31100000"],["0.03436300","0.18900000"],[],"bids":[["0.0342