草庐IT

points_into_buffer

全部标签

arrays - 戈朗 : Byte insert into [ ] byte

我正在处理GRPC流,在服务器端,我在for循环中接收到多个字节,我想合并到一个字节数组中(我尝试了附加方法但没有使用),在这里我附上了我的示例代码。任何人指导我。示例代码func(s*ServerGRPC)Upload(streampb.GuploadService_UploadServer)(errerror){for{resp,err:=stream.Recv()iferr!=nil{iferr==io.EOF{gotoEND}err=errors.Wrapf(err,"failedunexpectadelywhilereadingchunksfromstream")return

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 - 不能在 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

floating-point - 常量截断为整数

以下GO程序报错:./fft.go:13:constant-6.28319truncatedtointeger./fft.go:13:cannotuse-7*k/N(typeint)astypefloat64inassignment程序:packagemainimport("math""fmt")funcmain(){fmt.Println("Helloworld",math.E)vark,Nint=1,10varansfloat64=0varcfloat64=(-2.0*math.Pi*k)/Nx:=make([]float64,N)fori:=0;i为什么我不能在float64类型

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

go - 在 Go 中使用 bytes.Buffer 实现类斐波那契字符串连接的正确方法是什么?

我在Go中使用“+”和bytes.Buffer(“WriteString”和“Write(bytes)”)测试了简单的字符串连接。结果显示“+”比其他两个慢得多,这是有道理的。但是,当我使用这三种方式来实现类似斐波那契的字符串连接(即a、b、ab、bab、abbab、bababbab、abbabbababb)时,“+”表现最好。示例代码和基准测试结果如下所示。字符串“+”funcFibonacci(nint)string{FiboResult:=""prev_result:="a"next_result:="b"ifn==1{FiboResult="a"}elseifn==2{Fibo

floating-point - 为什么 float 不正确?

为什么有些数字存储为浮点数时会失去准确性?例如,十进制数9.2可以精确地表示为两个十进制整数(92/10)的比率,两个整数都可以精确地以二进制(0b1011100/0b1010)表示。但是,存储为浮点数的相同比率永远不会完全等于9.2:32-bit"singleprecision"float:9.1999998092651367187564-bit"doubleprecision"float:9.199999999999999289457264239899814128875732421875这样一个看似简单的数字如何在存储的64位中过大? 最佳答案

go - 获取 golang 的 Protocol Buffer 选项信息

ProtocolBuffer定义如下,TestMessage有两个选项msg_option_a和msg_option_b:syntax="proto3";packagegrpctest;optiongo_package="pb";import"google/protobuf/descriptor.proto";extendgoogle.protobuf.MessageOptions{int32msg_option_a=50011;int32msg_option_b=50012;}messageTestMessage{option(msg_option_a)=22;option(msg_

postgresql - 如何使用 go pg CRUD Postgres Point 数据类型

我正在使用Point数据类型在Postgres数据库中存储坐标。如何将Point数据类型映射到Golang数据类型?我没有找到任何相同的文档。 最佳答案 go-pg没有对点类型的本地支持(从PostGIS开始)。我所做的立交桥(可能不是最好的解决方案,但我确实设法让它工作)是在我的模型上放置单独的纬度和经度字段,并在查询本身上使用ColumnExpr使用ST_X(对于经度)和ST_Y(对于纬度,不要忘记)获取单个值。型号:typeMyModelstruct{IDint64NamestringLocationLatfloat64Loc