Go 内置函数介绍

10 内置函数介绍

内置函数介绍
close关闭 channel
len求长度(string, array, slice, map, channel)
new分配内存,主要用来分配值类型,int,struct。返回的是指针
make分配内存,主要用来分配引用类型,chan,map, slice
append用来追加元素到数组、slice
panic, recover做错误处理
panic/recover
  • Go 无异常机制,但是使用 panic/recover 模式来处理错误

  • panic 可在任何地方引发,但recover 只有在**defer 调用的函数中**有效

    • 例子:

      func funcA() {
      	fmt.Println("func A")
      }
      
      func funcB() {
      	panic("panic in B")		//panic
      }
      
      func funcC() {
      	fmt.Println("func C")
      }
      func main() {
      	funcA()
      	funcB()
      	funcC()
      }
      
    • 输出:

      func A
      panic: panic in B
      
      goroutine 1 [running]:
      main.funcB(...)
      	e:/LearningNotes/Go/_function/panic.go:10
      main.main()
      	e:/LearningNotes/Go/_function/panic.go:18 +0xa5
      exit status 2
      
    • 调用函数 funcB 时,引发了panic导致程序崩溃异常退出

    • 此时,我们可以使用 recover 将程序恢复,继续执行

      • func funcA() {
        	fmt.Println("func A")
        }
        
        func funcB() {
        	defer func() {
        		err := recover()
        		//如果程序出出现了panic错误,可以通过recover恢复过来
        		if err != nil {
        			fmt.Println("recover in B")
        		}
        	}()
        	panic("panic in B")
        }
        
        func funcC() {
        	fmt.Println("func C")
        }
        func main() {
        	funcA()
        	funcB()
        	funcC()
        }
        
    • 注意:

      • recoer() 必须搭配 defer 使用
      • defer 一定要在可能引发 panic 的语句前定义

练习题

  • 分金币

  • /*
    你有50枚金币,需要分配给以下几个人:Matthew,Sarah,Augustus,Heidi,Emilie,Peter,Giana,Adriano,Aaron,Elizabeth。
    分配规则如下:
    a. 名字中每包含1个'e'或'E'分1枚金币
    b. 名字中每包含1个'i'或'I'分2枚金币
    c. 名字中每包含1个'o'或'O'分3枚金币
    d: 名字中每包含1个'u'或'U'分4枚金币
    写一个程序,计算每个用户分到多少金币,以及最后剩余多少金币?
    程序结构如下,请实现 ‘dispatchCoin’ 函数
    */
    var (
    	coins = 50
    	users = []string{
    		"Matthew", "Sarah", "Augustus", "Heidi", "Emilie", "Peter", "Giana", "Adriano", "Aaron", "Elizabeth",
    	}
    	distribution = make(map[string]int, len(users))
    )
    
    func main() {
    	left := dispatchCoin()
    	fmt.Println("剩下:", left)
    }
    
  • 我的答案:

package main

import "fmt"

var (
	coins = 50
	users = []string{
		"Matthew", "Sarah", "Augustus", "Heidi", "Emilie", "Peter", "Giana", "Adriano", "Aaron", "Elizabeth",
	}
	distribution = make(map[string]int, len(users))
)

func dispatchCoin() int {

	ans := make(map[string]int, 10)
	for _, i := range users {
		for _, j := range i {
			k := j
			switch k {
			case 'e', 'E':
				ans[i] += 1
				coins -= 1
			case 'i', 'I':
				ans[i] += 2
				coins -= 2
			case 'o', 'O':
				ans[i] += 3
				coins -= 3
			case 'u', 'U':
				ans[i] += 4
				coins -= 4
			default:
				continue

			}
		}
	}
	fmt.Println(ans)
	return (coins)
}
func main() {
	left := dispatchCoin()
	fmt.Println("剩下:", left)
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值