Commit 1476686c authored by Rob Pike's avatar Rob Pike

doc/effective_go.html: a little more about errors

Make it a little clearer how they are used, in particular that
it is not enough just to return a nil pointer on error, but also
to return an error value explaining the problem.

Fixes #1963.

LGTM=bradfitz
R=golang-codereviews, bradfitz
CC=golang-codereviews
https://golang.org/cl/97360045
parent 61d8a337
...@@ -3287,9 +3287,18 @@ the garbage collector for bookkeeping. ...@@ -3287,9 +3287,18 @@ the garbage collector for bookkeeping.
<p> <p>
Library routines must often return some sort of error indication to Library routines must often return some sort of error indication to
the caller. As mentioned earlier, Go's multivalue return makes it the caller.
As mentioned earlier, Go's multivalue return makes it
easy to return a detailed error description alongside the normal easy to return a detailed error description alongside the normal
return value. By convention, errors have type <code>error</code>, return value.
It is good style to use this feature to provide detailed error information.
For example, as we'll see, <code>os.Open</code> doesn't
just return a <code>nil</code> pointer on failure, it also returns an
error value that describes what went wrong.
</p>
<p>
By convention, errors have type <code>error</code>,
a simple built-in interface. a simple built-in interface.
</p> </p>
<pre> <pre>
...@@ -3301,7 +3310,12 @@ type error interface { ...@@ -3301,7 +3310,12 @@ type error interface {
A library writer is free to implement this interface with a A library writer is free to implement this interface with a
richer model under the covers, making it possible not only richer model under the covers, making it possible not only
to see the error but also to provide some context. to see the error but also to provide some context.
For example, <code>os.Open</code> returns an <code>os.PathError</code>. As mentioned, alongside the usual <code>*os.File</code>
return value, <code>os.Open</code> also returns an
error value.
If the file is opened successfully, the error will be <code>nil</code>,
but when there is a problem, it will hold an
<code>os.PathError</code>:
</p> </p>
<pre> <pre>
// PathError records an error and the operation and // PathError records an error and the operation and
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment