【Go学习笔记】(一)通过go-by-example学Go

简介: 前言 从今天开始,打算正式入坑Go,并计划以一周为周期,初步熟悉Go语言特性、基础语法等。吸取了前面学习的教训,这次打算通过阅读分析现成代码、主动思考和探索来学习。
本文首发于稀土掘金。该平台的作者 逐光而行 也是本人。

前言

从今天开始,打算正式入坑Go,并计划以一周为周期,初步熟悉Go语言特性、基础语法等。吸取了前面学习的教训,这次打算通过阅读分析现成代码、主动思考和探索来学习。
本次参考的入门代码GitHub地址为:
go-by-example

参考书籍:《Go语言圣经》
Go语言圣经

官方权威文档:
Go Package

hello world!

package main

import (
   "fmt"
)

func main() {
   fmt.Println("hello world")
}
  • Q:明明看到它所属的包名叫01-hello,为什么package后跟的是main?而且换了别的名称后编译不通过?
    A:在Go中,main不是一个库,而是一个独立可执行的程序。main中的main函数是程序的入口。
  • import的"fmt"是什么?
  1. fmt是Go提供的100多个包里面的其中一个,是处理输入输出的,类似于C的"stdio.h"
  2. 必须告诉编译器需要哪些包,而且要做到不重不漏,因为Go是编译型语言,通过静态编译将源代码及其依赖转换成计算机的机器指令,像C/C++一样比较接近底层、讲求链接。

3.顺序不能错,package在前,import在后

  • 函数相关
  1. 包本身小写,包中的函数首字母开头要大写。比如"Println"
  2. 截至目前,只见过写main()函数,格式是 func main(),先记着这个func的表达

var

package main

import (
   "fmt"
   "math"
)

func main() {

   var a = "initial"

   var b, c int = 1, 2

   var d = true

   var e float64

   f := float32(e)

   g := a + "foo"
   fmt.Println(a, b, c, d, e, f) // initial 1 2 true 0 0
   fmt.Println(g)                // initialapple

   const s string = "constant"
   const h = 500000000
   const i = 3e20 / h
   fmt.Println(s, h, i, math.Sin(h), math.Sin(i))
}

这次导入了"math"包,可作数学处理

  • ":="是什么写法?

    短变量声明的一部分,定义一个或多个变量并根据它们的初始值为这些变量赋予适当类型的语句

(确实,看着这个变量前面并没有标注int之类)


(之后几个程序感觉没啥疑问,就先跳过了) # slice(切片) ``` package main import "fmt" func main() { s := make([]string, 3) s[0] = "a" s[1] = "b" s[2] = "c" fmt.Println("get:", s[2]) // c fmt.Println("len:", len(s)) // 3 s = append(s, "d") s = append(s, "e", "f") fmt.Println(s) // [a b c d e f] c := make([]string, len(s)) copy(c, s) fmt.Println(c) // [a b c d e f] fmt.Println(s[2:5]) // [c d e] fmt.Println(s[:5]) // [a b c d e] fmt.Println(s[2:]) // [c d e f] good := []string{"g", "o", "o", "d"} fmt.Println(good) // [g o o d] } ``` - make是什么?和new有什么区别? 1. make 只能用来分配及初始化类型为 slice、map、chan 的数据。new 可以分配任意类型的数据; 2. new 分配返回的是指针,即类型 *Type。make 返回引用,即 Type; 3. new 分配的空间被清零。make 分配空间后,会进行初始化; 参考资料: [Go语言make和new关键字的区别及实现原理](http://c.biancheng.net/view/5722.html) - slice操作 1. slice支持直接append(感觉这方面像Java的动态数组),而且还可以一次添加多个; ```go numbers = append(numbers, 2,3,4) printSlice(numbers) ``` 2. 支持索引取块s[2,5](这一点像python的切片) 3. 支持直接拷贝 ```go copy(numbers1,numbers) printSlice(numbers1) ``` - 稍微深挖一下slice slice的特性体现和它的底层有关。 slice像个更灵活、更轻便的数组,而实际上,它的底层指向的就是数组,并且不同的slice引用的可能是同一块内存区域。 ![image.png](https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/72930513d3b743e391620f4845b89301~tplv-k3u1fbpfcp-watermark.image?) 从上图也可以理解:slice的第一个元素不一定对应底层数组起始的第一个元素。 slice由三部分组成:指针、长度、容量。 这个概念很好理解,类似于初学数据结构时用c自定义一个栈的结构体。 ![image.png](https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/85074c78caa44e2f9dd61c83a66290ea~tplv-k3u1fbpfcp-watermark.image?) 所以Go中的len()和cap()各自返回的是什么也就可以类比了。 - 【存疑,后续跟进】对于《go语言圣经》(中文译本)中的以下一段话,我感觉有点疑惑 >另外,字符串的切片操作和[]byte字节类型切片的切片操作是类似的。都写作x[m:n],并且都是返回一个原始字节序列的子序列,底层都是共享之前的底层数组,因此这种操作都是常量时间复杂度。x[m:n]切片操作对于字符串则生成一个新字符串,如果x是[]byte的话则生成一个新的[]byte。 对此,我特意去查了一下英文原文: >As an aside, not e the similarity of the substring operation on strings to the slice operator on []byte slices. Both are written x[m:n], and both return a subsequence of the original bytes, sharing the underlying represent ation so that both operations take constant time. The expression x[m:n] yields a string if x is a string , or a []byte if x is a []byte. 原文说的是yield,和return(返回)一词差不多意思,它也没有说是生成一个新的吧? - slice操作可以直接修改底层数组。 - slice之间无法直接比较,不能使用“==”判断两个slice是否相等。 对于byte数组,官方提供了高度优化的bytes.Equal()函数,但是其他的就得自己写逐个比较的了。 不过以下语句是合法的: ``` if summer == nil { /* ... */ } ``` nil表示一个长度为0、容量为0的空切片(或者说没有切片,看首字母n->null),因为是空的,所以不指向任何底层数组。 不过判断是否为空切片,不应该使用上述==语句,应该使用`len(s) == 0`。
相关文章
|
6月前
|
监控 安全 Java
Go语言学习笔记(一)
Go语言学习笔记(一)
124 1
Go语言的条件控制语句及循环语句的学习笔记
本文是Go语言的条件控制语句和循环语句的学习笔记,涵盖了if语句、if-else语句、if嵌套语句、switch语句、select语句以及for循环和相关循环控制语句的使用方法。
Go语言的条件控制语句及循环语句的学习笔记
|
2月前
|
存储 Go
Go: struct 结构体类型和指针【学习笔记记录】
本文是Go语言中struct结构体类型和指针的学习笔记,包括结构体的定义、成员访问、使用匿名字段,以及指针变量的声明使用、指针数组定义使用和函数传参修改值的方法。
|
2月前
|
人工智能 算法 搜索推荐
Go学习笔记-代码调
近年来,人工智能技术飞速发展,Cody作为由Sourcegraph开发的一款AI驱动编码助手,应运而生。它不仅提供代码预测与补全,还能深度理解代码上下文,为开发者提供准确建议,提升编码效率和质量。Cody能识别潜在错误并提出修复建议,缩短调试时间,同时进行智能代码审查,帮助优化代码结构和风格。未来,随着AI技术进步,Cody将不断学习优化,成为开发者不可或缺的伙伴,推动编程领域的创新与发展。
33 0
|
6月前
|
存储 分布式计算 算法
GO学习笔记之表达式
GO学习笔记之表达式
51 1
|
6月前
|
存储 编译器 Go
GO语言学习笔记
GO语言学习笔记
44 1
|
Go 自然语言处理 编译器
Go 学习笔记-Go 词法解析
Go 学习笔记-Go 词法解析
80 0
Go 学习笔记-Go 词法解析
|
自然语言处理 前端开发 Java
Go 学习笔记-Go 编译器简介
Go 学习笔记-Go 编译器简介
70 0
|
自然语言处理 算法 Java
Go学习笔记-Go编译器简介
Go学习笔记-Go编译器简介
86 0
|
存储 Go
Go学习笔记-Go 浮点数设计原理
Go学习笔记-Go 浮点数设计原理
114 0