草庐IT

input_buffer

全部标签

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 - 通过 golang os/exec 使用 sftp << INPUT

我想做的是在golang中通过SFTP从我的服务器导出文件。这是麻烦的代码cmd=exec.Command("sftp","login@sftp.com",`INPUTcd/some/pathputfile.gzquitINPUT`)cmd.Stderr=&stderrerr=cmd.Run()iferr!=nil{fmt.Println(stderr.String())os.Exit(1)}fmt.Println("done")它会完成但不会导入file.gz。 最佳答案 我终于找到了解决方案。cmd=exec.Command("

go - 带有 gRPC 的 golang protocol buffers 可以在不同的 OS 平台上交叉编译和使用吗?

这个问题专门关于在不同的操作系统平台上编译和使用golangProtocolBuffer(使用gRPC),我还没有看到类似的问题。是否可以在Windows上编译一个.proto文件,然后在Linux上使用生成的文件?还是相反?我在Windows和Linux上编译了相同的.proto文件,diff显示了不同的结果。一个区别是Windows编译版本有时会在请求结构的字段中重复json,如下所示:Field1Name*type`protobuf,bytes,1,opt,name=my_name,json=myName"json:"my_name,omitempty"`而Linux版本是:Fi

go - bytes.Buffer ReadFrom 与 r.Read 不同?

在连接错误的情况下,我想从ioReader获取数据流并在通过httppost将其作为流发送之前对其进行缓冲。为此,我计划使用bytes.Buffer并将其从读取器复制到缓冲区。一个单独的goroutine将从缓冲区读取并将读取器传递给http.Request。现在,bytes.BufferReadFrom的行为不是我所期望的。我正在用管道模拟数据流:r,w:=io.Pipe()gofunc(){fori:=0;i当从读取器读取byteslice时,每次写入后Read返回,但是,当使用ReadFrom时,它不会停止读取直到写入器关闭。这:buf:=&bytes.Buffer{}nIn,e

macos - 运行 go 给我 - go clang : error: no input files

goget-u-vgithub.com/kubernetes-sigs/aws-iam-authenticator/cmd/aws-iam-authenticator在MacOSX10.13.6(17G65)给我:goclang:error:noinputfiles有什么建议吗? 最佳答案 据我所知,指定的repo不存在或不可访问,(您的链接返回404)因此您得到“无输入文件”,这是不言自明的。 关于macos-运行go给我-goclang:error:noinputfiles,我们在S

go - 编译 Protocol Buffer :Missing output directives

我尝试编译原型(prototype)(Ubuntu18.04)protoc—go_out=.test.protoMissingoutputdirectives.我的环境goenvGOARCH="amd64"GOBIN=""GOCACHE="/home/miki/.cache/go-build"GOEXE=""GOHOSTARCH="amd64"GOHOSTOS="linux"GOOS="linux"GOPATH="/home/miki/go"GORACE=""GOROOT="/usr"GOTMPDIR=""GOTOOLDIR="/usr/lib/gcc/x86_64-linux-gnu

input - golang 读取超过一行的文本输入并停止 ctrl+s

如何在golang中读取多行,控制台输入。reader:=bufio.NewReader(os.Stdin)fmt.Println("EnterText:")text,_:=reader.ReadString('\n')如果用户点击:ctrl+s,我必须如何更改ReadString(???)以停止阅读新行(\n)必须保留为输入的组成部分。是否有一些库/框架?感谢您的帮助。干杯 最佳答案 这是Linux的答案(也适用于其他*nix平台)Ctrl+S是一个控制字符DC3,意思是“XOFF,停止发送”。如果您按Ctrl+S,终端将卡住。C

php - 另一个 PHP XML 解析错误 : "Input is not proper UTF-8, indicate encoding!"

错误:Warning:simplexml_load_string()[function.simplexml-load-string]:Entity:line3:parsererror:InputisnotproperUTF-8,indicateencoding!Bytes:0xE70x610x690x73数据库中的XML(在FF中查看源代码的输出):role_fraRoleenfrançaisRoleçenfrançais如果我没理解错的话,这个错误与old_value标签中编码的第一个ç有关。准确的说,这个错误是根据bytes:"çais"?这是我加载X

java - 如何在 Java 中使用 `protocol buffer` 和 `protobuf-java-format` 从 XML 创建对象

我正在使用protocolbuffer和protobuf-java-format创建一个示例程序。我的原型(prototype)文件是packagecom.sample;optionjava_package="com.sample";optionjava_outer_classname="PersonProtos";messagePerson{requiredstringname=1;requiredint32id=2;optionalstringemail=3;}我的示例程序是packagecom.sample;importjava.io.BufferedReader;importj

python lxml : import XSD from a buffer?

我正在使用python中的LXML来验证具有匹配XSD的XML。该XSD导入第二个“通用”XSD,其中包含一些通用定义。问题是这些XSD不作为文件存在于本地。它们只是我保存在内存中的缓冲区,但是当XSD执行时或它在文件系统的当前目录中查找导入的文件。有没有办法让它不那样做?也许提前提供进口的XSD?LXML使用libxml2和libxslt进行解析。导入的XSD文件的打开源自libxml2代码的深处,不经过python的文件处理,因此只需覆盖open()不起作用。似乎libxml2没有任何工具可以为其提供文件解析器。它只是调用fopen()直接。因此,解决方案可能需要处于更高级别,可能