Go——包管理,if,循环,switch,数组,切片

包管理

#1 包:模块的意思
#2 自定义包
	-代码必须放在gopath的src路径下
    -第三方包都是放在gopath的src路径下
    -包导入是从gopath的src路径下开始检索(开始找)
    -除了main包以外,建议包名就叫文件夹名,一个文件夹下的包名必须一致
    -同一个包下,变量,函数只能定义一次
    -同一个包下的变量和函数可以直接使用
    -包内的函数或变量,想让外部包使用,必须首字母大写
    
# 3 init函数(特殊函数)
	-不需要调用就会执行
    -可以定义多个
# 4 包导入的几种方式
	-import "kkk/mypackage"
    -给包重命名
    	-import 名字 "day02/mypackage"
        名字.变量/函数
    -包只导入,不使用
    import _ "kkk/mypackage"
 
# 5 go语言没有一个统一包管理的地址,大家都放到github上

# 6 采用go mode模式
	-两种创建方式之一
    	-命令行下输入:go mod init 项目名   在当前路径下创建出go.mod(该项目依赖go的版本,第三方包版本)
        -项目路径的cmd窗口,go get 第三方包,就会在go.mod中加入依赖
        -以后把项目copy给别人,go install
        -自己写的包,就放在自己项目路径下
        -加代理的方式:手动写,goland中配置
   	-在goland中创建项目时,直接指定modules,可以配置环境变量(加代理)

if-else语句

package main

import "fmt"

//if-else
func main() {
	//1 if else
	a := test()
	if a>10{
		fmt.Println("a大于10")
	}else {
		fmt.Println("a小于10")
	}

	//2 if --else if--- else
	if a > 10 {
		fmt.Println("dayu 10")
	} else if a == 10 {
		fmt.Println("10101010")
	} else {
		fmt.Println("xiaoyu 10")
	}
	//3 条件语句后不能回车换行
	if a > 10 {
		fmt.Println("dayu 10")
	} else if a == 10 {
		fmt.Println("10101010")
	} else {
		fmt.Println("xiaoyu 10")
	}

}

func test() int {

	return 100
}

循环

1 没有while循环,没有do while循环,只有一个for循环

package main

//for 循环
/* for 后面三部分,都可以省略
   for 变量初始化;条件;变量自增/自减 {
   	循环体内容
   }

*/
func main() {
//1 基本使用
for i:=0;i<10;i++{
	fmt.Println(i)
}

//2 省略第一部分
i:=0   //作用域范围大,不止在for内部,外部也可以用
for ;i<10;i++{
	fmt.Println(i)
}
//2 省略第三部分
i:=0   //作用域范围大,不止在for内部,外部也可以用
for ;i<10;{
	fmt.Println(i)
	i++
}

//3 省略一和三部分的简略写法(这就是while循环)  for 条件{ 循环体内容}
i:=0
for i<10{
	fmt.Println(i)
	i++
}

//4 死循环

for {
	fmt.Println("ssssss")
}

//5 只是演示开多协程
for i:=0;i<4000;i++{
	go test2()
}

//6 break :结束本次for循环,continue结束本次循环,继续下一次循环
}

func test2()  {
	for  {
		fmt.Println("sssss")
	}

}

switch语句

// switch 是一个条件语句,用于将表达式的值与可能匹配的选项列表进行比较,并根据匹配情况执行相应的代码块。它可以被认为是替代多个 if else 子句的常用方式


package main

import "fmt"

func main() {
	//1 基本使用
	num:=4
	switch num {
	case 1:
		fmt.Println("1")
	case 2:
		fmt.Println("2")
	case 3:
		fmt.Println("3")
	case 4:
		fmt.Println("4")
	}

	//2 默认情况
	num:=40
	switch num {
	case 1:
		fmt.Println("1")
	case 2:
		fmt.Println("2")
	case 3:
		fmt.Println("3")
	case 4:
		fmt.Println("4")
	default:
		fmt.Println("我没有匹配")
	}

	//3 多表达式判断
	num:=40
	switch num {
	case 1,2,3,4,5,6,7,8:
		fmt.Println("1")
	case 10,11,16:
		fmt.Println("2")
	case 30:
		fmt.Println("3")
	case 40,44,45:
		fmt.Println("4")
	default:
		fmt.Println("我没有匹配")
	}

	//4 无表达式的 switch
	num:=80
	switch  {
	case num==12,num==13:
		fmt.Println("12,13")
	case num==40,num==41:
		fmt.Println("40,41")
	default:
		fmt.Println("我没有匹配")
	}


	//5 Fallthrough
	num:=12
	switch  {
	case num==12,num==13:
		fmt.Println("12,13")
		fallthrough
	case num==40,num==41:
		fmt.Println("40,41")
		//fallthrough  //穿透,只要看到fallthrough,无条件执行下一个case或者default
	default:
		fmt.Println("我没有匹配")
	}
}


goto:饱受诟病  java 保留字,没有实际作用

数组

package main

import (
	"fmt"
)

//数组:数组是同一类型元素的集合。可以放多个值,但是类型一致,内存中连续存储

func main() {

	//1 数组的定义,数组的大小,在定义阶段就确定了,而且不能改
	var names [3]string
	var ages [3]int8


	//2 数组赋值
	var ages [3]int8
	ages[0]=99
	ages[2]=88

	//3 定义并初始化,
	var ages [3]int=[3]int{1,2,3}
	var ages [3]int=[3]int{1,2}
	var ages [3]int=[3]int{}
	var ages=[3]int{}
	ages:=[3]int{1,3,4,7}  //不允许多放

	//4 数组定义并初始化的其他(了解)数组只要定义,长度就固定了,。。。,后面放几个值,数组大小是多少
	var ages [9]int=[...]int{1,2,3,4,5,6,7,8}   //不支持这个
	var ages =[...]int{1,2,3,4,5,6,7,8}
	ages :=[...]int{1,2,3,4,8}

	//5 数组的大小是类型的一部分
	var a [2]int=[2]int{1,2}
	var b [2]int=[2]int{1,3}
	b=a   //如果不是同一种类型,不允许相互赋值

	//6 数组是值类型
	var a [2]int=[2]int{1,2}

	test5(a)  //因为数组是值类型,go函数传参,都是copy传递,如果是值类型,函数内改了,不会影响原来的

	//7 数组长度  len()  数组长度在定义阶段已经固定

	//8 数组循环
	var a =[...]int{7,4,3,5,6,7}
	fmt.Println(a[99])
	fmt.Println(len(a))
	//普通循环
	for i:=0;i<len(a);i++{
		fmt.Println(a[i])
	}

	//通过range来循环  (range不是内置函数,是一个关键字,for,if,else),打印出索引
	for i:=range a{
		fmt.Println(i)
	}

	//如果用一个变量来接收,这个值是可迭代的索引
	//如果用两个变量来接收,这两个变量,一个是索引,一个具体的值
	for i,value:=range a{
		fmt.Println(i)
		fmt.Println(value)
	}
	//把数组循环打印出来
	for _,value:=range a{
		fmt.Println(value)
	}

	// 9 多维数组
	var a [3][3]int  //定义
	a[0][1]=99      //使用
	fmt.Println(a)

	//定义并赋初值
	var a [3][3]int=[3][3]int{{1},{1,2,3},{4,4,4}}
	var s =[3][3]string{{"lqz","xxx","yyy"},{},{}}

	//循环多维数组
	for _,value:=range s{
		for _,in_value:=range value{
			fmt.Println(in_value)
		}
	}

	//10 数组定义并指定位置初始化
	var names [100]int=[100]int{10:99,99:99}
	var names [100]int=[100]int{10,11,2,44,99:99,45:88}


func test5(a [2]int)  {
	a[0]=99
}

切片

package main

import "fmt"

//切片:切片是由数组建立的一种方便、灵活且功能强大的包装(Wrapper)。切片本身不拥有任何数据。它们只是对现有数组的引用

func main() {
	//1 切片定义的第一种方式
	//定义一个数组
	var a =[10]int{9,8,7,6,5,4,3,2,1,0}
	//基于数组,做一个切片
	//[]int 中括号中不带东西,就是切片类型
	var b []int
	b=a[:]
	
	//2 使用切片
	fmt.Println(b[0])
	
	//3 修改切片,会影响数组
	b[0]=999

	// 5 切片只切数组一部分
	var a =[10]int{9,8,7,6,5,4,3,2,1,0}
	var b []int=a[3:5]
	fmt.Println(b)

	//6 当多个切片共用相同的底层数组时,每个切片所做的更改将反映在数组中
	var a =[10]int{9,8,7,6,5,4,3,2,1,0}
	var b []int=a[3:5]
	var c []int=a[4:6]

	//7 切片的长度和容量
	var a =[10]int{9,8,7,6,5,4,3,2,1,0}
	var b []int=a[3:5]
	var b []int=a[7:8]

	// 切片长度
	fmt.Println(len(b))
	// 切片容量(最多能存多少值)
	fmt.Println(cap(b))

	//8 切片追加值
	b=append(b,3)
	b=append(b,999)
	//到了临界点再追加,超过切片容量,会新开辟新的内存地址存,之后修改不会影响原来的数组了
	b=append(b,888)
	fmt.Println(b)
	fmt.Println(a)
}
posted @ 2020-09-11 16:37  pythoner_wl  阅读(132)  评论(0编辑  收藏  举报