- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我有 2 个函数:
func sampleFunction () {
u, err := findDog(1)
if err != nil {
// We couldn't find the dog, print a message.
fmt.Println(err)
// Custom error types.
if _, ok := err.(*dneError); ok {
fmt.Println("Custom dog dne error for the end-user here.")
}
} else {
// Do something with u.
u.doSomething() // Is this idiomatic in Go?
// Should we explicility check for u != nil?
// Or does the if check above need to return?
// (even if I would like the function to be longer)
}
}
// findDog returns a dog with a given ID. If not found, returns an error.
func findDog(id int) (*models.Dog, error) {
found, err := models.FindDog(id)
// Is this return scheme/flow too brittle?
if err != nil {
return nil, &dneError{fmt.Sprintf("Dog %d does not exist in the" +
"database: %s", id, err.Error())}
}
return found, nil
}
我只想确保正确处理错误和 nils,所以我的 2 个主要问题是:
在 findDog 中,我是否在两种情况下都适本地返回了 nil?
在 sampleFunction 中,不显式检查 u != nil 是惯用的,还是我完全错误地这样做了?
我的目标是在需要时向程序员正确显示错误/问题,并在用户需要时向用户显示错误/问题,同时遵守惯用标准。感谢您的宝贵时间。
最佳答案
是的,这是地道的 Go。因为错误是预先处理的,所以错误意味着失败并且结果是 nil
,或者例如也许是一个没有任何用处的部分写入的缓冲区。
附言我还有一个建议可以使事情更加地道。这个成语有点像“缩进错误 block ,而不是代码”。您在 sampleFunction
中特别有一个 if/else,但在大多数错误检查情况下(不是全部)您处理它并返回,然后跳过 else 并且流程继续。为什么在不需要时缩进?这具有使长函数易于阅读的效果,因为函数的预期流程可以从上到下阅读,而不必在 if/else block 之间来回跳转。至少在很多场合。
我修改了对某人存储库的拉取请求,因为我有一个 if/else,其中 if with return 就足够了。
编辑所以我的回答让我有点困扰,现在我记得为什么了。非 nil
error
返回通常是惯用的,表示其他返回值无用,但确实有异常(exception)。 一定要检查个别文档。
作为具体示例,请参见 bytes.Buffer.ReadBytes
If ReadBytes encounters an error before finding a delimiter, it returns the data read before the error and the error itself (often io.EOF).
关于go - 在 Golang 中处理 nil 和错误的惯用方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52462569/
我对 Clojure 和函数式编程有了大约一周的了解——我的所有背景都是 OOP。我想利用 Clojure 备受争议的易读性和固有逻辑,但现在我不知道我是否成功地做到了这一点,只是没有完全理解它,或者
场景: val col: IndexedSeq[Array[Char]] = for (i = 0 && arr(last.y)(west) == '.') { arr(last.y)(w
我正面临 AngularJS、服务和范围的“问题”。 这不是一个真正的问题(我找到了几种使其工作的方法),但我想知道我是否在做正确的事情,或者我正在做的事情是否会导致将来出现问题 我有一个保存一些全局
进行以下数据结构转换的“Rubyist”方法是什么: 我有 incoming = [ {:date => 20090501, :width => 2}, {:
如何在 go 中编写返回集合最小值的函数?我不只是在寻找解决方案(我知道我可以在遍历第一个元素时只初始化最小值,然后设置一个我初始化最小值的 bool 变量),而是一个惯用的解决方案。由于 go 没有
好的,我知道我应该对我的特定应用程序进行基准测试,等等,但是: -Xmx 的默认 JVM 设置、默认垃圾收集器等,对于大多数典型的 Java 程序来说是合理的默认设置,并且可能不适合惯用的 Scala
既然 shared_ptr 在 tr1 中,你认为 std::auto_ptr 的使用会发生什么?它们都有不同的用例,但 auto_ptr 的所有用例也都可以用 shared_ptr 解决。你会放弃
这个问题在这里已经有了答案: What are the differences between type() and isinstance()? (8 个回答) 关闭 9 年前。 我需要知道 Pyth
在指定和创建数字函数时,是否有关于何时返回 null 以及何时返回 NaN 的任何 C# 惯用准则,当两者似乎都是有效输出时。 导致这个问题的具体例子是我正在为 Enumerable 集合创建一个百分
这个问题在这里已经有了答案: Retrieving the top 100 numbers from one hundred million of numbers [duplicate] (12 个
我可以通过反射检索方法,以某种方式将其与目标对象结合起来,并将其作为看起来像 Scala 中的函数的东西返回(即您可以使用括号调用它)吗?参数列表是可变的。它不一定是“一流”函数(我已经更新了问题),
我是一名优秀的程序员,十分优秀!