草庐IT

points_into_buffer

全部标签

go - 为什么从 byte.Buffer 读取时我会得到一个永无止境的循环

目前我正在编写一个从bytes.Buffer读取缓冲区的程序。它应该在找到字符e时停止阅读。但是当我使用for循环读取缓冲区时,我注意到了一些奇怪的事情。当我将字节读取作为for语句的一部分时,我得到一个无限循环(exampleingoplayground):b:=bytes.NewBuffer([]byte("uoiea"))forv,_:=b.ReadByte();v!='e';{println("Thevalueis"+string(v))}但是如果我删除它并将它放在for循环中,它不会(exampleingoplayground):b:=bytes.NewBuffer([]by

arrays - Golang 创建 bytes.Buffer 数组的多读取器

我需要创建slice的MultiReader[]*bytes.Bufferbuffer_slice:=...(type[]*bytes.Buffer)当我写io.MultiReader(buffer_slice)我得到错误:不能在io.MultiReader的参数中使用buffer_slice(类型[]*bytes.Buffer)作为io.Reader类型:[]*bytes.Buffer没有实现io.Reader(缺少Read方法)。但是函数签名MultiReader(readers...Reader)Reader我明白了,传输数组没有意义,实际问题:除了琐碎的循环,没有更多的选择吗?

go - 如何处理 bytes.Buffer 流中的 io.EOF?

https://play.golang.org/p/JKXKa7Pvjd我想弄清楚如何使用bytes.Buffer测试我的后台函数,其中流中可以有随机io.EOF?例子:packagemainimport("fmt""io""bytes""time")funcmain(){buffer:=new(bytes.Buffer)gobackground(buffer)i:=0fori我要找的结果是:1)teststring2)teststring3)teststring4)teststring5)teststring如何使用time.Sleep(1*time.Second)模拟延迟来实现这一

go - bytes.Buffer 的限制?

我正在尝试使用包“compress/gzip”压缩一段字节。我正在写入一个bytes.Buffer并且我正在写入45976字节,当我尝试使用gzip.reader解压缩内容然后使用阅读器函数时-我发现并非所有内容都已恢复。bytes.buffer有一些限制吗?这是一种绕过或改变它的方法吗?这是我的代码(编辑):funccompress_and_uncompress(){varbufbytes.Bufferw:=gzip.NewWriter(&buf)i,err:=w.Write([]byte(long_string))if(err!=nil){log.Fatal(err)}w.Clos

go - 为什么是 log.Println ("does not log into file")?

这是我第一次尝试使用golang登录文件。file,_:=os.Open("logfile")log.SetOutput(file)log.Println("foo")这些线路建立,但不工作。为什么? 最佳答案 os.Open调用OpenFile(名称,O_RDONLY,0)。如果文件不存在,这没有标志O_CREATE来创建文件。因此,您需要使用O_CREATE标志调用OpenFile。我把错误代码注释掉了:packagemainimport("log""os""syscall")const(O_RDONLYint=syscall.

去 fmt.Scan into Array

fmt包有一个Scan函数,它读取标准输入,并将连续的空格分隔值写入您提供的变量。有没有一种方法可以将它与Slices一起使用,这样我就可以创建一个sicen的slice,然后扫描读取n个值并将它们放入slice中? 最佳答案 只需将对fmt.Scan的调用包装在for循环中即可。 关于去fmt.ScanintoArray,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/16931

go - Protocol Buffer 使用枚举

你好,我正在使用protobuf,但我遇到了问题。我有一些枚举函数,但其​​中我有相同的别名,当我尝试为某种语言“go”编译文件时,编译器返回错误。我复制了protobuf文档中的示例来定义枚举,但仍然无法正常工作。enumEnumAllowingAlias{optionallow_alias=true;UNKNOWN=0;STARTED=1;RUNNING=1;}enumEnumNotAllowingAlias{UNKNOWN=0;STARTED=1;//RUNNING=1;//UncommentingthislinewillcauseacompileerrorinsideGoogl

golang : difference between var b Buffer and bytes. 缓冲区{}

varbbytes.Buffer//ABufferneedsnoinitialization.b:=bytes.Buffer{}这两个有什么区别?我在这里试过:http://play.golang.org/p/lnkkULeIYm没看出区别。谢谢, 最佳答案 :=是var的简写语法,在这种情况下b是一个零值bytes.Buffer。varbbytes.Buffer//isthesameasvarb=bytes.Buffer{}//isthesameasb:=bytes.Buffer{}您不能在函数外使用简写版本,因此对于全局变量,您

json - 出现错误 : math/big: cannot unmarshal into a *big. Int

我正在尝试将json字符串解码为golang中的大整数。我收到以下错误。还有另一种方法可以使它起作用吗?Therewasanerror:math/big:cannotunmarshal"\"82794247871852158897004947856472973914188862150580220767211643167985440428259\""intoa*big.Int代码:Playground:https://play.golang.org/p/F5RMehTau8epackagemainimport("fmt""math/big""encoding/json")typeSign

json - 通过 Go 在 Protocol Buffers v3 的 oneOf 字段中使用结构

因此尝试同时使用ProtocolBuffersv3和Go(两者都是新的)。example.protosyntax="proto3";packagetest;import"google/protobuf/timestamp.proto";messageMetadata{uint64userID=2;google.protobuf.Timestamptime=3;}//SignOffwhenuserlogsoutofGlorymessageSignOff{Metadatametadata=1;}//SignOnwhenuserlogsintoGlorymessageSignOn{Metad