Go学习笔记06-内建容器

Go语言

数组

定义数组:

  1. //这样定义数组编译器自动初始化每个元素为0 

  2. var arr1 [5]int 


  3. //这样定义数组需要手动初始化数组 

  4. arr2 := [3]int{1, 3, 5} 


  5. //这样可以让编译器自动计算数组长度 

  6. arr3 := [...]int{2, 4, 6, 8, 10} 


  7. //定义二维数组 

  8. var grid [4][5]bool 

·数量写在类型前面

遍历数组可用 for 循环语句,如:

  1. //用len()函数获取数组长度 

  2. for i := 0;i < len(arr3); i++{ 

  3. fmt.Println(arr3[i]) 



可以用range关键字获取数组的下标和值

  1. //用 range 关键字获取数组的下标和值 

  2. for i, v := range arr3{ 

  3. //i为数组下标,v为值 

  4. fmt.Println(i, v) 




  5. //只获取数值,下标值用 _ 代替 

  6. for _, v := range arr3{ 

  7. 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]。

  1. arr := [...]int{0, 1, 2, 3, 4, 5, 6, 7} 


  2. //获取数组arr下标从2~5的元素,不包括下标为6的元素 

  3. fmt.Println("arr[2:6] =", arr[2:6]) 

  4. //获取从第一个元素到下标为5的元素 

  5. fmt.Println("arr[:6] =", arr[:6]) 

  6. //获取从下标为2的元素及其后所有的元素 

  7. fmt.Println("arr[2:] =", arr[2:]) 

  8. //获取整个数组的元素 

  9. fmt.Println("arr[:] =", arr[:]) 

slice即切片不是值类型,切片是底层数组的一个视图(view),对切片做的变更会影响到原数组。

切片可以再对其进行reslice操作。

切片的扩展



Slice的操作

Slice添加元素

  1. arr := [...]int{0, 1, 2, 3, 4, 5, 6, 7} 

  2. //s1 = [2, 3, 4, 5] 

  3. s1 := arr[2:6] 

  4. //s2 = [5, 6] 

  5. s2 := s1[3:5] 

  6. //s3 = [5, 6, 10] 

  7. s3 := append(s2, 10) 

  8. //s4 = [5, 6, 10, 11] 

  9. s4 := append(s3, 11) 

  10. //s5 = [5, 6, 10, 11, 12] 

  11. s5 := append(s4, 12) 


  12. //s4, s5是不同的数组的视图 

  • 添加元素时如果超越cap,系统会重新分配一个更大的底层数组
  • 由于是值传递,必须接收append的返回值

创建Slice

  1. //未初始化的Slice缺省值是 nil 

  2. var s []int 


  3. //用make创建Slice,slice长度为6 

  4. s2 := make([]int, 6) 

  5. //用make创建Slice,slice长度为10,底层数组长度为32 

  6. s3 := make([]int, 10, 32) 

复制Slice

  1. //复制s1,并存储到s2中 

  2. copy(s2, s1) 

Map

创建map

  1. //创建map,m := map[Key_Type]Value_Type 

  2. m := map[string]string{ 

  3. "name": "Bob", 

  4. "course": "golang", 

  5. "site": "imooc", 

  6. "quality": "not bad" 




  7. //用make创建map,缺省值为 empty map 

  8. m2 := make(map[string]int) 


  9. //这样创建map,缺省值为nil 

  10. var m3 := map[string]int 

遍历Map

  1. //map的遍历同数组遍历操作 

  2. for k, v := range m{ 

  3. fmt.Println(k, v) 



获取元素

  1. courseName := m["course"] 


  2. //用此方法可以判断map中是否含有key为cause的值 

  3. if causeName, isOk := m["cause"]; isOk{ 

  4. fmt.Println(causeName) 

  5. }else { 

  6. fmt.Println("Key does not exisit.") 



删除元素

  1. //用delete删除map元素 

  2. delete(m, "name") 

map小结





map示例

题干:寻找最长不含有重复字符的子串的长度

如:abcabcbb -> abc

bbb -> b

pwwkew -> wke

  1. package main 


  2. import "fmt" 


  3. func lengthOfNoneRepeatSubStr(s string) int{ 

  4. last := make(map[byte]int) 

  5. start := 0 

  6. maxLength := 0 


  7. for i, ch := range []byte(s){ 

  8. if lastI, isOk := last[ch]; isOk && lastI >= start { 

  9. start = lastI + 1 



  10. if i - start + 1 > maxLength{ 

  11. maxLength = i - start + 1 



  12. last[ch] = i 




  13. return maxLength 




  14. func main() { 

  15. fmt.Println(lengthOfNoneRepeatSubStr("abcabcbb")) 

  16. fmt.Println(lengthOfNoneRepeatSubStr("kkkkkkkkk")) 

  17. fmt.Println(lengthOfNoneRepeatSubStr("pwwkew")) 

  18. fmt.Println(lengthOfNoneRepeatSubStr("0123456789")) 



字符处理

在Go语言中,rune相当于char类型

  1. package main 


  2. import "fmt" 


  3. func main(){ 

  4. s := "Yes青青子衿悠悠我心" 

  5. for _, b := range []byte(s){ 

  6. fmt.Printf("%X ", b) 




  7. for i, ch := range s{ 

  8. fmt.Printf("(%d, %X) ", i, ch) 




  9. fmt.Println() 



  • 使用utf8.RuneCountInString获取字符数量
  • 使用len获取字节长度
  • 使用[]byte获取字节

寻找最长不含有重复字符的子串的长度支持中文字符版本

  1. package main 


  2. import "fmt" 


  3. func lengthOfNoneRepeatSubStr(s string) int{ 

  4. last := make(map[rune]int) 

  5. start := 0 

  6. maxLength := 0 


  7. for i, ch := range []rune(s){ 

  8. if lastI, isOk := last[ch]; isOk && lastI >= start { 

  9. start = lastI + 1 



  10. if i - start + 1 > maxLength{ 

  11. maxLength = i - start + 1 



  12. last[ch] = i 




  13. return maxLength 




  14. func main() { 

  15. fmt.Println(lengthOfNoneRepeatSubStr("abcabcbb")) 

  16. fmt.Println(lengthOfNoneRepeatSubStr("kkkkkkkkk")) 

  17. fmt.Println(lengthOfNoneRepeatSubStr("pwwkew")) 

  18. fmt.Println(lengthOfNoneRepeatSubStr("0123456789")) 



有关字符的操作在包 strings 中。

Go学习笔记06-内建容器的更多相关文章

  1. 机器学习实战(Machine Learning in Action)学习笔记————06.k-均值聚类算法(kMeans)学习笔记

    机器学习实战(Machine Learning in Action)学习笔记————06.k-均值聚类算法(kMeans)学习笔记 关键字:k-均值.kMeans.聚类.非监督学习作者:米仓山下时间: ...

  2. Flutter学习笔记(10)--容器组件、图片组件

    如需转载,请注明出处:Flutter学习笔记(10)--容器组件.图片组件 上一篇Flutter学习笔记(9)--组件Widget我们说到了在Flutter中一个非常重要的理念"一切皆为组件 ...

  3. iOS学习笔记06—Category和Extension

    iOS学习笔记06—Category和Extension 一.概述 类别是一种为现有的类添加新方法的方式. 利用Objective-C的动态运行时分配机制,Category提供了一种比继承(inher ...

  4. [Golang学习笔记] 06 程序实体3 类型断言和类型转换

    类型断言: 语法:<目标类型的值>,<布尔参数> := <表达式>.( 目标类型 ) // 安全类型断言<目标类型的值> := <表达式>. ...

  5. C++学习笔记之——内联函数,引用

    本文为原创作品,转载请注明出处 欢迎关注我的博客:http://blog.csdn.net/hit2015spring和http://www.cnblogs.com/xujianqing/ 作者:晨凫 ...

  6. stm32寄存器版学习笔记06 输入捕获(ETR脉冲计数)

    STM32外部脉冲ETR引脚:TIM1-->PA12;TIMER2-->PA0:TIMER3-->PD2;TIMER4-->PE0… 1.TIM2 PA0计数 配置步骤 ①开启 ...

  7. [原创]java WEB学习笔记06:ServletContext接口

    本博客为原创:综合 尚硅谷(http://www.atguigu.com)的系统教程(深表感谢)和 网络上的现有资源(博客,文档,图书等),资源的出处我会标明 本博客的目的:①总结自己的学习过程,相当 ...

  8. Bash脚本编程学习笔记06:条件结构体

    简介 在bash脚本编程中,条件结构体使用if语句和case语句两种句式. if语句 单分支if语句 if TEST; then CMD fi TEST:条件判断,多数情况下可使用test命令来实现, ...

  9. Docker 与 K8S学习笔记(二)—— 容器核心知识梳理

    本篇主要对容器相关核心知识进行梳理,通过本篇的学习,我们可以对容器相关的概念有一个全面的了解,这样有利于后面的学习. 一.什么是容器? 容器是一种轻量级.可移植.自包含的软件打包技术,使应用程序可以在 ...

  10. laravel 学习笔记 — 神奇的服务容器

     2015-05-05 14:24 来自于分类 笔记 Laravel PHP开发 竟然有人认为我是抄 Laravel 学院的,心塞.世界观已崩塌. 容器,字面上理解就是装东西的东西.常见的变量.对象属 ...

随机推荐

  1. 《C#并发编程经典实例》学习笔记-关于并发编程的几个误解

    误解一:并发就是多线程 实际上多线程只是并发编程的一种形式,在C#中还有很多更实用.更方便的并发编程技术,包括异步编程.并行编程.TPL 数据流.响应式编程等. 误解二:只有大型服务器程序才需要考虑并 ...

  2. [转]mysql优化——show processlist命令详解

    本文转自:https://blog.csdn.net/sunqingzhong44/article/details/70570728 版权声明:本文为博主原创文章,未经博主允许不得转载. https: ...

  3. Maven私服 Nexus使用一例

    一.背景 本次搭建Nexus的私服是为了解决两件事 1.公司网络限制,部分项目组同事无法直接访问互联网,不能直接下载一些依赖的jar文件; 2.一些独立的jar无法通过Maven添加依赖的方式引入到项 ...

  4. log4.net 自定义日志文件名称

    插件化项目中,遇到这样一个需求,每个插件 或者每个方法 一个日志文件,方便后期错误排查 源码地址: https://github.com/xlb378917466/SharpHttpServerCas ...

  5. [angularjs] angularjs系列笔记(二)指令

    重复HTML元素 ng-repeat指令可以重复HTML元素 <body> <div ng-app="Home" ng-controller="inde ...

  6. 通过DFS求解有向图(邻接表存储)中所有简单回路

    前言 查阅了网上许多关于通过DFS算法对有向图中所有简单回路的查找,发现有很多关于使用DFS求解有向回路中所有简单回路的帖子,(在按照节点编号情况下)但大多数仅仅寻找了编号递增的回路.又或者未对结果去 ...

  7. Go开发之路 -- Go语言基本语法

    一. 变量 1.1 变量的声明 Go 语言的每一个变量都拥有自己的类型,必须经过声明才能开始用. 标准格式: var 变量名 变量类型 变量的声明以关键字 var 开头,行尾不需要写分号 常见变量的数 ...

  8. @RequestMapping 详解

    RequestMapping是一个用来处理请求地址映射的注解,可用于类或方法上.用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径.RequestMapping注解有六个属性,下面我们把她分 ...

  9. 洛谷P2866 [USACO06NOV]糟糕的一天Bad Hair Day(单调栈)

    题目描述 Some of Farmer John's N cows (1 ≤ N ≤ 80,000) are having a bad hair day! Since each cow is self ...

  10. Activiti实现流程自由跳转

    import org.activiti.engine.ProcessEngine; import org.activiti.engine.TaskService; import org.activit ...