Not*_*fer 77
首先,os.Exit()
可以用来正常退出程序而不会出现错误,并且不会出现恐慌,因此这是一个关键的区别.另一个是可以捕获,忽略或记录某个地方的恐慌recover
.
但是如果我们谈论错误的退出代码,那么让我们说:
panic
当出现可怕的错误时使用,可能是程序员错误,应该在进入生产之前被捕获.这就是它打印堆栈的原因.
os.Exit(errorCode)
如果您想要使用或类似的东西:
为脚本目的控制程序的退出代码.
想要在预期的错误上有序退出(例如用户输入错误).
所以基本上恐慌是你的,一个糟糕的退出代码是为您的用户.
Ain*_*r-G 73
首先,无论何时你有"如何在实践中使用"的问题,一个好的方法是搜索 Go源代码(或者任何足够大的Go代码库,真的),以及包文档以获得答案.
现在,os.Exit
并且panic
完全不同.panic
当程序或其部分达到不可恢复状态时使用.
当
panic
调用时,包含隐式的运行时错误,例如将切片索引越界或失败类型断言,它会立即停止执行当前函数并开始展开goroutine的堆栈,沿途运行任何延迟函数.如果该展开到达goroutine堆栈的顶部,则程序将死亡.
os.Exit
当你需要立即中止程序,没有恢复或运行延迟清理语句的可能性时使用,并返回错误代码(其他程序可以用来报告发生的事情).这在测试中很有用,当你已经知道在一次测试失败后,另一次测试也会失败,所以你现在也可以退出.当你的程序完成了它需要做的所有事情时,也可以使用它,现在只需要退出,即在打印帮助信息之后.
大多数时候你不会使用panic
(你应该返回一个error
),而且你几乎不需要os.Exit
在测试之外的某些情况以及快速程序终止.
wea*_*ish 10
主要区别是:
os.Exit
跳过延迟函数的执行。os.Exit
,您可以指定退出代码。panic
正在终止而os.Exit
不是。(似乎其他答案没有提到这一点。)如果你需要执行延迟函数,你别无选择,只能panic
. (另一方面,如果您想跳过延迟函数的执行,请使用os.Exit
.)
如果以这种方式定义非空函数:
return
或终止panic
那么你不能用替换panic
,os.Exit
否则编译器会拒绝编译程序,说“在函数结束时缺少返回”。(Go 在这里非常愚蠢,甚至log.Panic
不终止函数。)
在其他条件下:
panic
时的东西真的发生了连线,如编程逻辑错误。os.Exit
时,你要立即退出,与指定的退出代码。 归档时间: |
|
查看次数: |
44810 次 |
最近记录: |