zoukankan      html  css  js  c++  java
  • Let's GO(二)

    人生苦短,Let's GO

    今天我学了什么?

    1. Map

    map:映射,使用散列表(hash)实现
    map[keyType]valueType

    var a map[string]int
    var a map[string]int
    //defaule nil
    fmt.Println(a==nil)
    //init make(map,cap) 
    a = make(map[string]int,10)
    a["一"] = 1
    a["二"] = 2
    a["四"] = 4
    a["五"] = 5
    fmt.Println(a)
    fmt.Printf("a:%#v
    ",a)
    b := map[int]bool {
    		1 : true,
    		2 : false,
    	}
    fmt.Printf("b:%#v
    ",b)
    
    // 探测是否存在map[key]
    f,ok := a["三"]
    fmt.Println(f,ok)
    //ok == true
    

    map默认是无序的,怎么让它按一定的顺序操作呢

    //用slice取key
    keys := make([]string,0,100)
    for k := range c  {
    	keys = append(keys,k)
    }
    //key排序
    sort.Strings(keys)
    for _,key := range keys {
    	fmt.Println(key,c[key])
    }
    

    有点绕口的两个东西,想起了c++的指针常量和常量指针..

    //mapslice
    //init slice,then init map
    var mapSlice = make([]map[string]int,8,8)
    mapSlice[0] = make(map[string]int,10)
    mapSlice[0]["hello"] = 1
    fmt.Println(mapSlice)
    //slicemap
    //init map, then init slice
    var sliceMap = make(map[string][]int,10)
    sliceMap["hello"] = make([]int,0,10)
    sliceMap["hello"] = append(sliceMap["hello"],1,2,3,4,5)
    fmt.Println(sliceMap)
    

    map 东西还挺多的哈

    2.函数

    func name() (return) { //左大括号一定要写在同一行,不然无效
    }

    func intSum(x int, y int) int {
    	return x+y
    }
    
    //可变参数(...)
    func intsum2(a ...int) int  {
    	ret := 0
    	for _,i := range a {
    		ret += i
    	}
    	return ret
    }
    
    //go 的函数可以return 多个值
    func calc(a,b int) (sum ,sub int)  {
    	return a+b,a-b
    }
    
    //函数也可做参数
    func compute(x,y int,op func(int,int) int) int {
    	return op(x,y)
    }
    
    //函数alias?
    abc := calc
    x,y  := abc(1,2)
    
    //匿名函数:直接写在调用的地方
    func() {
    	fmt.Println("Anonymous Function")
    	}() //记得加()表示立即调用
    

    3.闭包

    引用大佬的话:闭包 = 函数 + 环境(外层变量的引用)

    //闭包 = 函数 + 环境
    //func return func
    func a() func() {
            str := "闭包"
    	return func(){
    		fmt.Println("this is a ",str)
    	}
    }
    
    func main() {
    r := a()
    r()   
    }
    
    //再来个复杂点的
    func makeSuffixFunc(suffix string) func(string) string {
    	return func(name string) string {
    		if !strings.HasSuffix(name,suffix) {
    			return name + suffix
    		}
    		return name
    	}
    }
    

    总结

    Talk is Cheap , Show me the Code

    学到的感到的都在代码和注释里了。
    今天,就先写到这里吧,结构体的内容还没学完,明天再一次性发。
    那么,人生苦短,朋友,Let's GO!

  • 相关阅读:
    poj 2229 Sumsets
    HDU- 2063 过山车
    编写一个简易购物车,实现向购物车内添加商品,移除指定商品及清空购物车功能。
    编写一个实现页面计数,要求当刷新页面时,不增加计数
    4-1:编写一个简单的留言簿,写入留言提交后显示留言内容。
    HDU-3706 Second My Problem First
    HDU-1896 Stones
    4-16 表单提交信息和获取。
    HDU-1873 看病要排队
    HDU-1509 Windows Message Queue
  • 原文地址:https://www.cnblogs.com/syisyuan/p/12879455.html
Copyright © 2011-2022 走看看