mirror of
https://github.com/gopl-zh/gopl-zh.github.com.git
synced 2024-11-24 07:14:47 +00:00
Compare commits
2 Commits
7ae51ed0e2
...
4ed47b2687
Author | SHA1 | Date | |
---|---|---|---|
|
4ed47b2687 | ||
|
f226048bf5 |
@ -338,7 +338,7 @@ func fetch(url string) (filename string, n int64, err error) {
|
||||
}
|
||||
</code></pre>
|
||||
<p>对resp.Body.Close延迟调用我们已经见过了,在此不做解释。上例中,通过os.Create打开文件进行写入,在关闭文件时,我们没有对f.close采用defer机制,因为这会产生一些微妙的错误。许多文件系统,尤其是NFS,写入文件时发生的错误会被延迟到文件关闭时反馈。如果没有检查文件关闭时的反馈信息,可能会导致数据丢失,而我们还误以为写入操作成功。如果io.Copy和f.close都失败了,我们倾向于将io.Copy的错误信息反馈给调用者,因为它先于f.close发生,更有可能接近问题的本质。</p>
|
||||
<p>**练习5.18:**不修改fetch的行为,重写fetch函数,要求使用defer机制关闭文件。</p>
|
||||
<p><strong>练习5.18:</strong> 不修改fetch的行为,重写fetch函数,要求使用defer机制关闭文件。</p>
|
||||
|
||||
|
||||
<!-- 公众号 -->
|
||||
|
@ -163,7 +163,7 @@
|
||||
|
||||
<h1 id="第6章-方法"><a class="header" href="#第6章-方法">第6章 方法</a></h1>
|
||||
<p>从90年代早期开始,面向对象编程(OOP)就成为了称霸工程界和教育界的编程范式,所以之后几乎所有大规模被应用的语言都包含了对OOP的支持,go语言也不例外。</p>
|
||||
<p>尽管没有被大众所接受的明确的OOP的定义,从我们的理解来讲,一个对象其实也就是一个简单的值或者一个变量,在这个对象中会包含一些方法,而一个方法则是一个一个和特殊类型关联的函数。一个面向对象的程序会用方法来表达其属性和对应的操作,这样使用这个对象的用户就不需要直接去操作对象,而是借助方法来做这些事情。</p>
|
||||
<p>尽管没有被大众所接受的明确的OOP的定义,从我们的理解来讲,一个对象其实也就是一个简单的值或者一个变量,在这个对象中会包含一些方法,而一个方法则是一个和特殊类型关联的函数。一个面向对象的程序会用方法来表达其属性和对应的操作,这样使用这个对象的用户就不需要直接去操作对象,而是借助方法来做这些事情。</p>
|
||||
<p>在早些的章节中,我们已经使用了标准库提供的一些方法,比如time.Duration这个类型的Seconds方法:</p>
|
||||
<pre><code class="language-Go">const day = 24 * time.Hour
|
||||
fmt.Println(day.Seconds()) // "86400"
|
||||
|
@ -4418,7 +4418,7 @@ func fetch(url string) (filename string, n int64, err error) {
|
||||
}
|
||||
</code></pre>
|
||||
<p>对resp.Body.Close延迟调用我们已经见过了,在此不做解释。上例中,通过os.Create打开文件进行写入,在关闭文件时,我们没有对f.close采用defer机制,因为这会产生一些微妙的错误。许多文件系统,尤其是NFS,写入文件时发生的错误会被延迟到文件关闭时反馈。如果没有检查文件关闭时的反馈信息,可能会导致数据丢失,而我们还误以为写入操作成功。如果io.Copy和f.close都失败了,我们倾向于将io.Copy的错误信息反馈给调用者,因为它先于f.close发生,更有可能接近问题的本质。</p>
|
||||
<p>**练习5.18:**不修改fetch的行为,重写fetch函数,要求使用defer机制关闭文件。</p>
|
||||
<p><strong>练习5.18:</strong> 不修改fetch的行为,重写fetch函数,要求使用defer机制关闭文件。</p>
|
||||
<div style="break-before: page; page-break-before: always;"></div><h2 id="59-panic异常"><a class="header" href="#59-panic异常">5.9. Panic异常</a></h2>
|
||||
<p>Go的类型系统会在编译时捕获很多错误,但有些错误只能在运行时检查,如数组访问越界、空指针引用等。这些运行时错误会引起panic异常。</p>
|
||||
<p>一般而言,当panic异常发生时,程序会中断运行,并立即执行在该goroutine(可以先理解成线程,在第8章会详细介绍)中被延迟的函数(defer 机制)。随后,程序崩溃并输出日志信息。日志信息包括panic value和函数调用的堆栈跟踪信息。panic value通常是某种错误信息。对于每个goroutine,日志信息中都会有与之相对的,发生panic时的函数调用堆栈跟踪信息。通常,我们不需要再次运行程序去定位问题,日志信息已经提供了足够的诊断依据。因此,在我们填写问题报告时,一般会将panic异常和日志信息一并记录。</p>
|
||||
@ -4569,7 +4569,7 @@ func soleTitle(doc *html.Node) (title string, err error) {
|
||||
<p><strong>练习5.19:</strong> 使用panic和recover编写一个不包含return语句但能返回一个非零值的函数。</p>
|
||||
<div style="break-before: page; page-break-before: always;"></div><h1 id="第6章-方法"><a class="header" href="#第6章-方法">第6章 方法</a></h1>
|
||||
<p>从90年代早期开始,面向对象编程(OOP)就成为了称霸工程界和教育界的编程范式,所以之后几乎所有大规模被应用的语言都包含了对OOP的支持,go语言也不例外。</p>
|
||||
<p>尽管没有被大众所接受的明确的OOP的定义,从我们的理解来讲,一个对象其实也就是一个简单的值或者一个变量,在这个对象中会包含一些方法,而一个方法则是一个一个和特殊类型关联的函数。一个面向对象的程序会用方法来表达其属性和对应的操作,这样使用这个对象的用户就不需要直接去操作对象,而是借助方法来做这些事情。</p>
|
||||
<p>尽管没有被大众所接受的明确的OOP的定义,从我们的理解来讲,一个对象其实也就是一个简单的值或者一个变量,在这个对象中会包含一些方法,而一个方法则是一个和特殊类型关联的函数。一个面向对象的程序会用方法来表达其属性和对应的操作,这样使用这个对象的用户就不需要直接去操作对象,而是借助方法来做这些事情。</p>
|
||||
<p>在早些的章节中,我们已经使用了标准库提供的一些方法,比如time.Duration这个类型的Seconds方法:</p>
|
||||
<pre><code class="language-Go">const day = 24 * time.Hour
|
||||
fmt.Println(day.Seconds()) // "86400"
|
||||
|
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
Loading…
Reference in New Issue
Block a user