我一直在使用 golang 来自动化一些部署过程,我不得不使用 exec 包来调用一些 bash 脚本。
我使用了 exec.Command("/home/rodrigo/my-deploy.sh").CombinedOutput() 我看到了他的实现
func (c *Cmd) CombinedOutput() ([]byte, error) {
if c.Stdout != nil {
return nil, errors.New("exec: Stdout already set")
}
if c.Stderr != nil {
return nil, errors.New("exec: Stderr already set")
}
var b bytes.Buffer
c.Stdout = &b
c.Stderr = &b
err := c.Run()
return b.Bytes(), err
}
我意识到在使用 CombinedOutput() 时您不能分配 c.Stdout 我认为这没问题,但通知 api 调用者的方式不正确.
CombinedOutput() 当你以错误的方式使用它时返回一个错误,所以如果你打算使用 CombinedOutput() 那么你不应该分配 c.Stderr 或 c.Stdout 之前,如果你这样做,那么你将收到一个错误。
但这个错误不是因为你的脚本抛出错误,而是因为你使用了错误的 api,在那种情况下我相信你应该得到一个 panic 因为不应该使用错误的 api处理(我认为)。
我来自 Java World,当您以错误的方式使用某些方法时,您会收到一个 RuntimeException,例如。
public void run(Job job) throws NotCompletedJob {
if (job.getId() != null) {
throw new IllegalArgumentException("This job should not have id");
}
job.setId(calculateId());
job.run();
}
有了这个签名,我可以知道我用一个有 id 的 Job 调用 run(obj); 是错误的,事实上我可以区分我的脚本是有错误还是我' m 以错误的方式使用 api。
NotCompletedJob 是一个已检查的异常,所以我必须处理它,但 IllegalArgumentException 不是,所以我可以随时得到它。捕获 IllegalArgumentException 或任何其他 RuntimeException 并不总是被认为是一种好的做法,因为它们表明从程序员的角度来看你有一个错误,并且它不是像 NotCompletedJob。
话虽如此,我如何区分当前 CombinedOutput() 实现中的编程错误(例如错误的 api 用法)和预期错误(脚本未正常完成)?
为了澄清我的担忧,我并不是说 CombinedOuput 的当前实现是错误的,但我不明白调用者如何区分是正在执行的命令错误还是由他的错误引起的错误api 用法。
我认为最好的方法是在调用者以错误的方式使用 api 时 panic ,就像调用者将 nil 引用传递给期望非 nil 引用的函数(实际上这是当前的行为)。
最佳答案
I come from Java World and when you are using some method in the wrong way then you receive an RuntimeException.
您现在处于围棋世界中。因此,该论点是无效的。放弃 Java。
The Go Programming Language Specification
Two built-in functions, panic and recover, assist in reporting and handling run-time panics and program-defined error conditions.
func panic(interface{}) func recover() interface{}While executing a function F, an explicit call to panic or a run-time panic terminates the execution of F. Any functions deferred by F are then executed as usual. Next, any deferred functions run by F's caller are run, and so on up to any deferred by the top-level function in the executing goroutine. At that point, the program is terminated and the error condition is reported, including the value of the argument to panic. This termination sequence is called panicking.
The Go Blog
The convention in the Go libraries is that even when a package uses panic internally, its external API still presents explicit error return values.
This page collects common comments made during reviews of Go code, so that a single detailed explanation can be referred to by shorthands. This is a laundry list of common mistakes, not a style guide.
See https://golang.org/doc/effective_go.html#errors. Don't use panic for normal error handling. Use error and multiple return values.
The usual way to report an error to a caller is to return an error as an extra return value.
您的 Go 服务器程序正在同时处理 100,000 个客户端。如果发生错误,报告并处理;始终检查错误。不要让所有 100,000 个客户端因 panic 而崩溃。 Go 包不应该 panic。
阅读 Go 文档和 Go 标准库代码。
关于go - 在 golang 中处理逻辑错误与编程错误的惯用方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50762775/
我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div
总的来说,我对ruby还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
我正在尝试设置一个puppet节点,但rubygems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由rubygems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby
大约一年前,我决定确保每个包含非唯一文本的Flash通知都将从模块中的方法中获取文本。我这样做的最初原因是为了避免一遍又一遍地输入相同的字符串。如果我想更改措辞,我可以在一个地方轻松完成,而且一遍又一遍地重复同一件事而出现拼写错误的可能性也会降低。我最终得到的是这样的:moduleMessagesdefformat_error_messages(errors)errors.map{|attribute,message|"Error:#{attribute.to_s.titleize}#{message}."}enddeferror_message_could_not_find(obje
我想了解Ruby方法methods()是如何工作的。我尝试使用“ruby方法”在Google上搜索,但这不是我需要的。我也看过ruby-doc.org,但我没有找到这种方法。你能详细解释一下它是如何工作的或者给我一个链接吗?更新我用methods()方法做了实验,得到了这样的结果:'labrat'代码classFirstdeffirst_instance_mymethodenddefself.first_class_mymethodendendclassSecond使用类#returnsavailablemethodslistforclassandancestorsputsSeco
Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack
我在我的项目中添加了一个系统来重置用户密码并通过电子邮件将密码发送给他,以防他忘记密码。昨天它运行良好(当我实现它时)。当我今天尝试启动服务器时,出现以下错误。=>BootingWEBrick=>Rails3.2.1applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-CtoshutdownserverExiting/Users/vinayshenoy/.rvm/gems/ruby-1.9.3-p0/gems/actionmailer-3.2.1/lib/action_mailer
设置:狂欢ruby1.9.2高线(1.6.13)描述:我已经相当习惯在其他一些项目中使用highline,但已经有几个月没有使用它了。现在,在Ruby1.9.2上全新安装时,它似乎不允许在同一行回答提示。所以以前我会看到类似的东西:require"highline/import"ask"Whatisyourfavoritecolor?"并得到:Whatisyourfavoritecolor?|现在我看到类似的东西:Whatisyourfavoritecolor?|竖线(|)符号是我的终端光标。知道为什么会发生这种变化吗? 最佳答案
我已经从我的命令行中获得了一切,所以我可以运行rubymyfile并且它可以正常工作。但是当我尝试从sublime中运行它时,我得到了undefinedmethod`require_relative'formain:Object有人知道我的sublime设置中缺少什么吗?我正在使用OSX并安装了rvm。 最佳答案 或者,您可以只使用“require”,它应该可以正常工作。我认为“require_relative”仅适用于ruby1.9+ 关于ruby-主要:Objectwhenrun