草庐IT

multi-byte

全部标签

戈朗 : Parse bit values from a byte

我需要解析一个由两个字节组成的网络数据包:第一个由8位组成,根据它们的顺序设置某些标志(例如),第二个是uint8(很简单)1-在线0-不活跃1-漂亮1-很帅0-秃头0-聋人0-静音0-盲我如何从字节原语中解析它? 最佳答案 一些用于处理二进制文件的有用的Go标准库包:encoding/binarymath/bits要从字节中提取单个位,您应该使用按位运算符-|、&和>>>。Forexample:packagemainimport("fmt")funcmain(){v:=byte(0xB2)if(v>>4)&1==1{fmt.Pri

arrays - GO 中的 : Parsing byte array of excel data using https://github. com/tealeg/xlsx 库

我想使用https://github.com/tealeg/xlsx解析excel数据的字节数组GOLANG中的库。实际上,我正在从请求(作为字节数组)获取数据到我的GRPC服务器,我必须在其中解析和处理它。我检查了库API,但它接受文件名作为参数。"github.com/tealeg/xlsx"funcmain(){xlsx.OpenFile("file.xslx")}知道如何直接传递字节数组并对其进行处理。 最佳答案 明白了。用过的funcOpenBinary(bs[]byte)(*文件,错误)

arrays - [] byte {10}或[] byte(“\n”)与[] byte {92,110}

我正在使用github.com/tarm/serial来连接一些串行仪器。在开发过程中,我使用/dev/ttyp0和/dev/ptyp0对,其中go进程连接到一个,我使用screen连接到另一个。我编写了一个函数,它与serial.Config.ReadTimeout结合起来,最多可以读取ReadTimeout或接收到给定的字节序列。该功能是:funcreadToTermination(sserial.Port,termination[]byte,ratetime.Duration)[]byte{varout[]bytelterm:=len(termination)for{buf:=m

go - 新手 : Properly sizing a []byte size in GO (Chunking)

新手警报!不太确定该怎么做-我想做一个“文件分块器”,我从二进制文件中抓取固定的slice,以便以后作为学习项目上传。我目前有这个:type(fileChunk[]bytefileChunks[]fileChunk)funcNumChunks(fios.FileInfo,chunkSizeint)int{chunks:=fi.Size()/int64(chunkSize)ifrem:=fi.Size()%int64(chunkSize)!=0;rem{chunks++}returnint(chunks)}//leftouterrchecksforbrevityfuncchunker(f

戈朗 : How can I populate a multi-struct map in a loop?

我有客户与API交互的日志文件。我想解析这些日志并将结果提供给结构映射,以便我可以将数据组织成有用的信息。例如,我想响应以下查询:“显示每个用户每天的请求总数”。我已经创建了一个看起来足够的结构来保存数据。但是,当我尝试运行程序时出现错误:无效操作:dates[fields[1]](type*Dates不支持索引)[processexitedwithnon-zerostatus]。http://play.golang.org/p/8u3jX26kttpackagemainimport("fmt""strings")typeStatsstruct{totalNumberOfRequest

winapi - 从 unsafe.Pointer 获取特定 byte slice 的最佳(最安全 + 最高性能)方法是什么

我正在尝试转换thisc++去。简而言之,这就是C代码正在做的事情:staticconstchar*pSharedMem=NULL;intsessionInfoOffset;returnpSharedMem+pHeader->sessionInfoOffset;这是我的(伪)go代码:varpSharedMemunsafe.PointersessionInfoLenC.intbyteSlice:=C.GoBytes(pSharedMem,pHeader.sessionInfoLen)returnbyteSlice[pHeader.sessionInfoOffset:]我从来没有真正编写

go - 从第一个 CRLF 到最后读取一个 []byte

在golang中,有一个[]byte(来自ioutil.ReadAll),我应该需要从第一个换行符CRLF开始读取直到block结束。你能给我举些例子吗? 最佳答案 这可以使用bytes.Index轻松完成函数,它返回给定的字节子片在另一个byteslice中的索引:funcafterCRLF(data[]byte)[]byte{crlf:=[]byte("\r\n")index:=bytes.Index(data,crlf)ifindex==-1{returnnil}returndata[index+len(crlf):]}注意:

html - golang html/template ExecuteTemplate errant byte 它来自哪里?

背景我试图为Go编写一些GZIP中间件,但遇到了一个问题,因为http.DetectContentType()返回的是text/plain而不是text/html所以我追踪到第一个被写入的文本是某种类型或错误的字节,我仍在努力追查。我知道有很多解决方法,比如在执行模板时显式设置ContentType或使用bytes.Buffer并一次写入所有内容,但我真的很想找出导致写入这个单个字节的原因。例子这是一个非常人为的例子,它显示了同样的问题https://play.golang.org/p/SSrWP9jLRq运行时你会看到打印的第一件事是:“LENBYTES:1String:”嫌疑人如示

memory-management - bytes.Buffer 是否执行大量重新分配?

我想做的是有一个io.MultiWriter写入标准输出和字节缓冲区。像这样:packagemainimport"bytes"import"fmt"import"io"import"os"funcmain(){varbbytes.Buffermulti:=io.MultiWriter(&b,os.Stdout)fmt.Fprintf(multi,"eachofthesestrings\n")fmt.Fprintf(multi,"mightbelarge\n")fmt.Fprintf(multi,"andtherearemanyofthem\n")fmt.Println(b.String

go - 不能在赋值中使用 &dashUrl(类型 *[]byte)作为类型 *string

我正在尝试解析一个可能为空的表单帖子,如果是,我将更改变量。尝试使用*string类型。我遇到的问题是它不会为dashUrl转换,但会为start_time转换packagemainimport("encoding/base64""strconv""github.com/gocraft/web")typeYoutubeContextstruct{StartTime*float64`json:"start_time"`DashUrl*string`json:"dash_url"`}func(c*YoutubeContext)SetYoutubeContext(rwweb.Response