分享
Go基础学习三
Corwien · · 1270 次点击 · · 开始浏览这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。
Go编程语言:支持并发、垃圾回收的编译型系统级编程语言!本文主要是按照无闻的《Go 编程基础》开源视频学习并记录笔记。
一、数组Array
- 定义数组的格式:
var<varName>[n]<type> (n>=0, n表示数组元素个数) -
数组长度也是类型的一部分,因此具有不同长度的数组为不同类型 - 注意区分
指向数组的指针和指针数组 - 数组在Go中为值类型
- 数组之间可以使用==或!=进行比较,但不可以使用< 或 >
- 可以使用
new来创建数组,此方法返回一个指向数组的指针 - Go支持多维数组
示例:
package main
import "fmt"
func main() {
// var a [2]int
a := [2]int{1,2}
fmt.Println(a)
}
打印结果:
[1 2]
new 创建数据
// var a [2]int
a := [10]int{}
a[1] = 2
fmt.Println(a)
p := new([10]int)
p[1] = 2
fmt.Println(p)
打印结果:
➜ run arr.go
[0 2 0 0 0 0 0 0 0 0]
&[0 2 0 0 0 0 0 0 0 0]
看一下,上边有什么不同吗?第二行结果带了一个地址符&
多维数组
a := [2][3]int{
{1, 2, 3},
{4, 5, 6}}
fmt.Println(a)
打印结果:
[[1 2 3] [4 5 6]]
冒泡排序法:
package main
import "fmt"
// 冒泡排序
func main() {
// ...可以表示不确定的元素数
a := [...]int{1, 4, 9, 2, 5, 0, 20, 13, 3}
fmt.Println(a)
// 计算数组的长度
num := len(a)
for i := 0; i < num; i++ {
// 外边的循环,每循环一次,会将最大的值排在前边
for j := i + 1; j < num; j++ {
if a[i] < a[j] {
temp := a[i]
a[i] = a[j]
a[j] = temp
}
}
}
fmt.Println(a)
}
有疑问加站长微信联系(非本文作者)
入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889
关注微信1270 次点击
添加一条新回复
(您需要 后才能回复 没有账号 ?)
- 请尽量让自己的回复能够对别人有帮助
- 支持 Markdown 格式, **粗体**、~~删除线~~、
`单行代码` - 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
- 图片支持拖拽、截图粘贴等方式上传
收入到我管理的专栏 新建专栏
Go编程语言:支持并发、垃圾回收的编译型系统级编程语言!本文主要是按照无闻的《Go 编程基础》开源视频学习并记录笔记。
一、数组Array
- 定义数组的格式:
var<varName>[n]<type> (n>=0, n表示数组元素个数) -
数组长度也是类型的一部分,因此具有不同长度的数组为不同类型 - 注意区分
指向数组的指针和指针数组 - 数组在Go中为值类型
- 数组之间可以使用==或!=进行比较,但不可以使用< 或 >
- 可以使用
new来创建数组,此方法返回一个指向数组的指针 - Go支持多维数组
示例:
package main
import "fmt"
func main() {
// var a [2]int
a := [2]int{1,2}
fmt.Println(a)
}
打印结果:
[1 2]
new 创建数据
// var a [2]int
a := [10]int{}
a[1] = 2
fmt.Println(a)
p := new([10]int)
p[1] = 2
fmt.Println(p)
打印结果:
➜ run arr.go
[0 2 0 0 0 0 0 0 0 0]
&[0 2 0 0 0 0 0 0 0 0]
看一下,上边有什么不同吗?第二行结果带了一个地址符&
多维数组
a := [2][3]int{
{1, 2, 3},
{4, 5, 6}}
fmt.Println(a)
打印结果:
[[1 2 3] [4 5 6]]
冒泡排序法:
package main
import "fmt"
// 冒泡排序
func main() {
// ...可以表示不确定的元素数
a := [...]int{1, 4, 9, 2, 5, 0, 20, 13, 3}
fmt.Println(a)
// 计算数组的长度
num := len(a)
for i := 0; i < num; i++ {
// 外边的循环,每循环一次,会将最大的值排在前边
for j := i + 1; j < num; j++ {
if a[i] < a[j] {
temp := a[i]
a[i] = a[j]
a[j] = temp
}
}
}
fmt.Println(a)
}