GO_Function_07

Funktion

  1. Kann mehrere Rückgabewerte haben
  2. Alle Parameter werden als Wert übergeben: Slice, Map, Channel erwecken den Eindruck, als würden sie als Referenz übergeben
  3. Funktionen können als Werte für Variablen verwendet werden
  4. Funktionen können Parameter annehmen und Werte zurückgeben

Funktion: Variable Parameter und Verzögerung

variabler Parameter

func sum(ops ...int) int {
    
    
s := 0
for _, op := range ops {
    
    
s += op
}
return s
}

Funktion aufschieben

func TestDefer(t *testing.T) {
    
    
defer func() {
    
    
t.Log("Clear resources")
}()
t.Log("Started")
panic("Fatal error) //defer仍会执行
}

Demo


// 返回俩个随机数
func returnMultiValues() (int, int) {
    
    
	return rand.Intn(15), rand.Intn(30)
}

// 计算函数操作的时长
func timeSpent(inner func(op int) int) func(op int) int {
    
    
	return func(n int) int {
    
    
		start := time.Now()
		ret := inner(n)
		fmt.Println("time spent:", time.Since(start).Seconds())
		return ret
	}
}

func slowFun(op int) int {
    
    
	time.Sleep(time.Second * 1)
	return op
}

func TestFn(t *testing.T) {
    
    
	a, b := returnMultiValues()
	t.Log(a, b)
	timeSF := timeSpent(slowFun)
	t.Log(timeSF(10))
}


func Sum(ops ...int) int {
    
    
	ret := 0
	for _, op := range ops {
    
    
		ret += op
	}
	return ret
}

func TestVarParam(t *testing.T) {
    
    
	t.Log(Sum(1, 2, 3, 4))
	t.Log(Sum(1, 2, 3, 4, 5))
}

func Clear() {
    
    
	fmt.Println("Clear resources.")
}

func TestDefer(t *testing.T) {
    
    
	defer Clear()
	fmt.Println("Start")
	//panic("err")
}

Demo1

func TestFn(t *testing.T) {
    
    
	a, b := returnMultiValues()
	t.Log(a, b)
	timeSF := timeSpent(slowFun)
	t.Log(timeSF(10))
}

Ergebnis1:

=== RUN   TestFn
    fun_test.go:32: 11 27
time spent: 1.0093736
    fun_test.go:34: 10
--- PASS: TestFn (1.01s)
PASS

Demo2

func TestVarParam(t *testing.T) {
    
    
	t.Log(Sum(1, 2, 3, 4))
	t.Log(Sum(1, 2, 3, 4, 5))
}

Ergebnis:

=== RUN   TestVarParam
    fun_test.go:47: 10
    fun_test.go:48: 15
--- PASS: TestVarParam (0.00s)
PASS

Demo3

func TestDefer(t *testing.T) {
    
    
	defer Clear()
	fmt.Println("Start")
	//panic("err")
}

Ergebnis:

=== RUN   TestDefer
Start
Clear resources.
--- PASS: TestDefer (0.00s)
PASS

Guess you like

Origin blog.csdn.net/qq_31686241/article/details/126613275