Go学习笔记06-内建容器
Go学习笔记06-内建容器
数组
定义数组:
- //这样定义数组编译器自动初始化每个元素为0
- var arr1 [5]int
- //这样定义数组需要手动初始化数组
- arr2 := [3]int{1, 3, 5}
- //这样可以让编译器自动计算数组长度
- arr3 := [...]int{2, 4, 6, 8, 10}
- //定义二维数组
- var grid [4][5]bool
·数量写在类型前面
遍历数组可用 for 循环语句,如:
- //用len()函数获取数组长度
- for i := 0;i < len(arr3); i++{
- fmt.Println(arr3[i])
- }
可以用range关键字获取数组的下标和值
- //用 range 关键字获取数组的下标和值
- for i, v := range arr3{
- //i为数组下标,v为值
- fmt.Println(i, v)
- }
- //只获取数值,下标值用 _ 代替
- for _, v := range arr3{
- fmt.Println(v)
- }
Go语言中数组是值类型
- [10]int和[20]int被视为不同的类型
- 函数调用时会拷贝数组
- Go语言中一般不直接使用数组
*切片(Slice)
定义一个数组 arr := […]int{0, 1, 2, 3, 4, 5, 6, 7}
那么 s := arr[2:6]就叫做数组arr的一个切片,其值为[2, 3, 4, 5]。
- arr := [...]int{0, 1, 2, 3, 4, 5, 6, 7}
- //获取数组arr下标从2~5的元素,不包括下标为6的元素
- fmt.Println("arr[2:6] =", arr[2:6])
- //获取从第一个元素到下标为5的元素
- fmt.Println("arr[:6] =", arr[:6])
- //获取从下标为2的元素及其后所有的元素
- fmt.Println("arr[2:] =", arr[2:])
- //获取整个数组的元素
- fmt.Println("arr[:] =", arr[:])
slice即切片不是值类型,切片是底层数组的一个视图(view),对切片做的变更会影响到原数组。
切片可以再对其进行reslice操作。
切片的扩展


Slice的操作
Slice添加元素
- arr := [...]int{0, 1, 2, 3, 4, 5, 6, 7}
- //s1 = [2, 3, 4, 5]
- s1 := arr[2:6]
- //s2 = [5, 6]
- s2 := s1[3:5]
- //s3 = [5, 6, 10]
- s3 := append(s2, 10)
- //s4 = [5, 6, 10, 11]
- s4 := append(s3, 11)
- //s5 = [5, 6, 10, 11, 12]
- s5 := append(s4, 12)
- //s4, s5是不同的数组的视图
- 添加元素时如果超越cap,系统会重新分配一个更大的底层数组
- 由于是值传递,必须接收append的返回值
创建Slice
- //未初始化的Slice缺省值是 nil
- var s []int
- //用make创建Slice,slice长度为6
- s2 := make([]int, 6)
- //用make创建Slice,slice长度为10,底层数组长度为32
- s3 := make([]int, 10, 32)
复制Slice
- //复制s1,并存储到s2中
- copy(s2, s1)
Map
创建map
- //创建map,m := map[Key_Type]Value_Type
- m := map[string]string{
- "name": "Bob",
- "course": "golang",
- "site": "imooc",
- "quality": "not bad"
- }
- //用make创建map,缺省值为 empty map
- m2 := make(map[string]int)
- //这样创建map,缺省值为nil
- var m3 := map[string]int
遍历Map
- //map的遍历同数组遍历操作
- for k, v := range m{
- fmt.Println(k, v)
- }
获取元素
- courseName := m["course"]
- //用此方法可以判断map中是否含有key为cause的值
- if causeName, isOk := m["cause"]; isOk{
- fmt.Println(causeName)
- }else {
- fmt.Println("Key does not exisit.")
- }
删除元素
- //用delete删除map元素
- delete(m, "name")
map小结



map示例
题干:寻找最长不含有重复字符的子串的长度
如:abcabcbb -> abc
bbb -> b
pwwkew -> wke
- package main
- import "fmt"
- func lengthOfNoneRepeatSubStr(s string) int{
- last := make(map[byte]int)
- start := 0
- maxLength := 0
- for i, ch := range []byte(s){
- if lastI, isOk := last[ch]; isOk && lastI >= start {
- start = lastI + 1
- }
- if i - start + 1 > maxLength{
- maxLength = i - start + 1
- }
- last[ch] = i
- }
- return maxLength
- }
- func main() {
- fmt.Println(lengthOfNoneRepeatSubStr("abcabcbb"))
- fmt.Println(lengthOfNoneRepeatSubStr("kkkkkkkkk"))
- fmt.Println(lengthOfNoneRepeatSubStr("pwwkew"))
- fmt.Println(lengthOfNoneRepeatSubStr("0123456789"))
- }
字符处理
在Go语言中,rune相当于char类型
- package main
- import "fmt"
- func main(){
- s := "Yes青青子衿悠悠我心"
- for _, b := range []byte(s){
- fmt.Printf("%X ", b)
- }
- for i, ch := range s{
- fmt.Printf("(%d, %X) ", i, ch)
- }
- fmt.Println()
- }
- 使用utf8.RuneCountInString获取字符数量
- 使用len获取字节长度
- 使用[]byte获取字节
寻找最长不含有重复字符的子串的长度支持中文字符版本
- package main
- import "fmt"
- func lengthOfNoneRepeatSubStr(s string) int{
- last := make(map[rune]int)
- start := 0
- maxLength := 0
- for i, ch := range []rune(s){
- if lastI, isOk := last[ch]; isOk && lastI >= start {
- start = lastI + 1
- }
- if i - start + 1 > maxLength{
- maxLength = i - start + 1
- }
- last[ch] = i
- }
- return maxLength
- }
- func main() {
- fmt.Println(lengthOfNoneRepeatSubStr("abcabcbb"))
- fmt.Println(lengthOfNoneRepeatSubStr("kkkkkkkkk"))
- fmt.Println(lengthOfNoneRepeatSubStr("pwwkew"))
- fmt.Println(lengthOfNoneRepeatSubStr("0123456789"))
- }
有关字符的操作在包 strings 中。
Go学习笔记06-内建容器的更多相关文章
- 机器学习实战(Machine Learning in Action)学习笔记————06.k-均值聚类算法(kMeans)学习笔记
机器学习实战(Machine Learning in Action)学习笔记————06.k-均值聚类算法(kMeans)学习笔记 关键字:k-均值.kMeans.聚类.非监督学习作者:米仓山下时间: ...
- Flutter学习笔记(10)--容器组件、图片组件
如需转载,请注明出处:Flutter学习笔记(10)--容器组件.图片组件 上一篇Flutter学习笔记(9)--组件Widget我们说到了在Flutter中一个非常重要的理念"一切皆为组件 ...
- iOS学习笔记06—Category和Extension
iOS学习笔记06—Category和Extension 一.概述 类别是一种为现有的类添加新方法的方式. 利用Objective-C的动态运行时分配机制,Category提供了一种比继承(inher ...
- [Golang学习笔记] 06 程序实体3 类型断言和类型转换
类型断言: 语法:<目标类型的值>,<布尔参数> := <表达式>.( 目标类型 ) // 安全类型断言<目标类型的值> := <表达式>. ...
- C++学习笔记之——内联函数,引用
本文为原创作品,转载请注明出处 欢迎关注我的博客:http://blog.csdn.net/hit2015spring和http://www.cnblogs.com/xujianqing/ 作者:晨凫 ...
- stm32寄存器版学习笔记06 输入捕获(ETR脉冲计数)
STM32外部脉冲ETR引脚:TIM1-->PA12;TIMER2-->PA0:TIMER3-->PD2;TIMER4-->PE0… 1.TIM2 PA0计数 配置步骤 ①开启 ...
- [原创]java WEB学习笔记06:ServletContext接口
本博客为原创:综合 尚硅谷(http://www.atguigu.com)的系统教程(深表感谢)和 网络上的现有资源(博客,文档,图书等),资源的出处我会标明 本博客的目的:①总结自己的学习过程,相当 ...
- Bash脚本编程学习笔记06:条件结构体
简介 在bash脚本编程中,条件结构体使用if语句和case语句两种句式. if语句 单分支if语句 if TEST; then CMD fi TEST:条件判断,多数情况下可使用test命令来实现, ...
- Docker 与 K8S学习笔记(二)—— 容器核心知识梳理
本篇主要对容器相关核心知识进行梳理,通过本篇的学习,我们可以对容器相关的概念有一个全面的了解,这样有利于后面的学习. 一.什么是容器? 容器是一种轻量级.可移植.自包含的软件打包技术,使应用程序可以在 ...
- laravel 学习笔记 — 神奇的服务容器
2015-05-05 14:24 来自于分类 笔记 Laravel PHP开发 竟然有人认为我是抄 Laravel 学院的,心塞.世界观已崩塌. 容器,字面上理解就是装东西的东西.常见的变量.对象属 ...
随机推荐
- Android Studio 使用Menu
首先在res目录下创建一个文件夹名字随意 在对创建的文件夹下在创建一个菜单 名字随意 参看布局 可以看到你的菜单 可以选择添加是么样的菜单 接着要到主活动中重写 onCreateOptionsMenu ...
- [android] 服务的生命周期(混合方式)
绑定服务:可以调用服务里面的方法, 如果调用者activity销毁了,服务也会跟着销毁 单独解除绑定的时候,服务也会被销毁 开启服务:不可以调用服务里面的方法 如果调用者activity退出了,服务还 ...
- Cheating sheet for vim
- Laravel篇之Laravel的安装及使用
想搭建一个基于Lavarel和vuejs的个人网站,使用git推送到github存储,千里之行,始于足下,首先要做的用composer来下载laravel框架,并成功运行. 一.使用compose ...
- Flask 系列之 Bootstrap-Flask
说明 操作系统:Windows 10 Python 版本:3.7x 虚拟环境管理器:virtualenv 代码编辑器:VS Code 实验目标 通过使用 Bootstrap-Flask 来进行页面美化 ...
- 持续集成 自动化构建、测试、部署您的Coding代码
持续集成(Continuous Integration)指的是,频繁地(一天多次)将代码集成到主干. 持续集成的目的,就是让产品可以快速迭代,同时还能保持高质量. 它的核心措施是,代码集成到主干之前, ...
- javascript 动态修改css样式
方法一:改变外联css文件,这里不讲这个. 方法二:通过改变claaName来改变样式,语法: obj.className = "style2"; //或者 obj.setAttr ...
- js 策略模式 实现表单验证
策略模式 简单点说就是:实现目标的方式有很多种,你可以根据自己身情况选一个方法来实现目标. 所以至少有2个对象 . 一个是策略类,一个是环境类(上下文). 然后自己就可以根据上下文选择不同的策略来执 ...
- 2017-11-07 中文代码示例之Angular入门教程尝试
"中文编程"知乎专栏原址 原文: 中文代码示例教程之Angular尝试 为了检验中文命名在Angular中的支持程度, 把Angular官方入门教程的示例代码中尽量使用了中文命名. ...
- Salesforce 导入导出数据简介
导入数据的方式 有两种方式可以将数据导入Salesforce: 数据导入向导 Data Loader工具 Salesforce支持将csv文件中的数据导入系统. 数据导入向导 数据导入向导可以从设置界 ...