-
Notifications
You must be signed in to change notification settings - Fork 0
/
42.Defer.go
55 lines (41 loc) · 1.35 KB
/
42.Defer.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
/*
Title: 42.Defer.go
Author: OpenSource
Date: 2017-05-22
Description: For Study
Defer is used to ensure that a function call is performed later in a program’s execution,
usually for purposes of cleanup. defer is often used where e.g.
ensure and finally would be used in other languages.
*/
package main
import "fmt"
import "os"
func main() {
fmt.Println("42.Defer.go---------Start------------\n\n")
// Immediately after getting a file object with createFile,
// we defer the closing of that file with closeFile.
// This will be executed at the end of the enclosing function (main),
// after writeFile has finished.
f := createFile("/tmp/defer.txt")
defer closeFile(f)
writeFile(f)
fmt.Println("\n\n42.Defer.go-----------End------------")
// Suppose we wanted to create a file, write to it,
// and then close when we’re done. Here’s how we could do that with defer.
}
func createFile(p string) *os.File{
fmt.Println("------method - call => createFile(p string) *os.File{}")
f, err := os.Create(p)
if err != nil{
panic(err)
}
return f
}
func writeFile(f *os.File){
fmt.Println("------method - call => writeFile(f *os.File){} ")
fmt.Fprintln(f, "data")
}
func closeFile(f *os.File){
fmt.Println("------method - call => closeFile(f *os.File{} ")
f.Close()
}