草庐IT

C++标准

全部标签

go - 添加/替换/修补标准库

我有一个(自己编写的)运行时库,多年来我在各种编程项目中使用过它。它在TurboPascal的早期以Pascal库的形式开始存在,此后通过C、Perl和Lua的化身取得了进展。我现在正在考虑将其移至Go(尤其是因为Go和Lua之间有一些有趣的相似之处)。Go的std库的很大一部分或多或少地做了我自己的库所做的事情(例如,标志包或正则表达式的东西),在这种情况下,我可以直接使用它们或编写一个小的接口(interface)层。问题始于那些包,在这些包中,我的模型与Go的模型差异太大,无法通过简单的接口(interface)层来隐藏差异(一个典型的例子是目录遍历函数)。我看到了两条前进的道路

c - 为什么Golang在Linux上使用libc

Closed.ThisquestiondoesnotmeetStackOverflowguidelines。它当前不接受答案。想改善这个问题吗?更新问题,以便将其作为on-topic用于堆栈溢出。去年关闭。Improvethisquestion通过在centos7中执行ldd/usr/local/go/bin/go,我看到Go使用libc和其他一些运行时库:$ldd/usr/local/go/bin/golinux-vdso.so.1(0x00007fff2c9bd000)libpthread.so.0=>/lib/x86_64-linux-gnu/libpthread.so.0(0x

go - 以编程方式为 os.Process 编写标准输入

更新:要以编程方式“驱动”bash,您需要一个伪终端(PTY)。这就是我要找的:https://github.com/kr/ptypackagemainimport("github.com/kr/pty""io""os""os/exec")funcmain(){c:=exec.Command("grep","--color=auto","bar")f,err:=pty.Start(c)iferr!=nil{panic(err)}gofunc(){f.Write([]byte("foo\n"))f.Write([]byte("bar\n"))f.Write([]byte("baz\n")

go - 正在将标准库日志重定向到 logrus 线程安全

我正在使用logrus我的Go项目中用于结构化日志记录的库。我的logrus配置如下://GlobalvariableforloggingvargLog=&Logger{moduleName:ModuleName,logrus:logrus.New()}typeLoggerstruct{moduleNamestringlogrus*logrus.Logger}funcSetupGlobalLogger(logPrefixstring,logModestring)error{iflogMode=="file"{logFilePath:=fmt.Sprintf("var/%s.log",v

go - 是否有将包拆分为模块化组件的标准做法?

我正在开发一个具有多层功能的库。我希望开发人员能够只导入他们需要的部分,即mylib-core、mylib-feature1、mylib-feature2等。每个人都生活在自己的git仓库中。我还想提供一个简单的mylib包,它公开了一组默认功能,这对库的新开发人员很有用。参见d3.js版本4+用于与我正在尝试完成的非常相似的事情。我遇到的问题是显然您不能在包之间共享包名。这是一个问题,因为最好导入所有需要的存储库,然后简单地在mylib名称下提供所有可用内容。我没有看到一个明显的方法来重新导出功能,以构建默认的mylib包。是否有好的解决方案或更惯用的方法来实现我的目标?

go - 替换Golang标准包并在内部调用原来的

假设有一个特殊的硬件可以使某些标准库功能更快。硬件可能存在也可能不存在。我可以写一个包来使用这个硬件功能签名与标准签名一样,但它会强制所有应用程序和其他包根据特定目标上硬件的可用性来决定导入哪个包。在构建时并在所有应用程序和包中修改代码。理想情况下,我更愿意在运行时决定使用哪个包,而不需要应用程序更改它们的导入。该包将检查硬件的可用性,然后使用它或执行标准功能。有什么办法可以实现吗?还有其他方法可以“拦截”对标准包函数的调用吗? 最佳答案 听起来你在谈论一个将被其他应用程序使用的库。您不能(谢天谢地!)以这种方式修改标准库——否则仅

c - 不在 cgo 中显示 printf 结果

当我运行这段代码时,我希望打印出类似A:4,B:89的结果。但实际上,不显示任何内容。为什么这个程序不将结果显示到标准输出?main.go:packagemain/*#include"c.h"*/import"C"import("unsafe")typeSstruct{AintBint}funcmain(){s:=&S{A:4,B:89}pass_to_c:=(*C.S)(unsafe.Pointer(s))C.gostruct(pass_to_c)}c.h#include#includetypedefstruct{longintA;longintB;}S;externvoidgost

api - 如何找出 Go 标准库函数的可能错误值?

当调用返回错误的Go函数时,我想知道如何处理非nil错误值。我可以中止、记录它或将其传递给调用者。或其组合。但如果我能找出问题所在并以更细粒度的方式使用react,那就更好了。因此,我如何才能找出可能的错误值及其含义?例如,我想使用http.NewRequest函数。查一查inthedocs.在那里,它只说有可能的错误条件,但没有说是哪些。我怎样才能找到这些? 最佳答案 首先,如果您还没有读过,我建议您阅读thisblogarticleabouterrorhandlinginGo,它可能会为您澄清一些事情。至于找出Gostdlib函

go - 如何打印通过标准输入引入的行数?

我有以下程序,我想显示从标准输入中出现的特定引入行的次数:packagemainimport("bufio""fmt""os")funcmain(){counts:=make(map[string]int)input:=bufio.NewScanner(os.Stdin)forinput.Scan(){counts[input.Text()]++}//NOTE:ignoringpotentialerrorsfrominput.Err()forline,n:=rangecounts{ifn>1{fmt.Printf("%d\t%s\n",n,line)}}}当我运行该程序时,它允许我输入

go - 提供标准库 (crypto/tls)

我想对Gocrypto/tls标准库进行一些更改。在vendor文件夹中复制crypto/tls是否是执行此操作的好方法?它几乎可以工作,似乎vendored是我编译应用程序(Caddy网络服务器)时使用的副本。除了一个错误,我得到:go/src/github.com/user/caddy/caddytls/httphandler.go:40:cannotuse"vendor/crypto/tls".Configliteral(type*"vendor/crypto/tls".Config)astype*"crypto/tls".Configinfieldvalue有没有一种方法可以避