Go Web编程实战(3)----数据类型(二)

简介: Go Web编程实战(3)----数据类型(二)

复合类型


数组类型

数组在任何编程语言中,都是高频使用的类型,所以学习时也要重点掌握。首先,就是掌握如何声明数组与实例化数组,示例如下:

var name[SZIE] type
//创建数组,但不初始化
var num[10] int
//创建数组,并初始化
var num = [10]int{0, 1, 2, 3, 4, 5, 6, 7, 8, 9}


数组可以直接通过num[i]去修改访问值,这里不再赘述。


结构体介绍

学过C语言的,对结构体应该并不陌生。其实Go语言的结构体与C基本差不多,下面,我们来看看如何定义以及使用:

//语法
type 类型名 struct{
  字段1 类型1
  字段2 类型2
  //.....
}
//定义
type User struct {
  name string
  age int
}


接着,我们再来看看定义并赋值后,如何使用结构体。


示例如下:


type User struct {
  name string
  age int
}
func main() {
  var lyj User=User{name:"liyuanjing",age:29}
  var fxy User=User{name:"fengxinyao",age:31}
  fmt.Println(lyj)
  fmt.Println(fxy)
  fmt.Println(lyj.age)
  fmt.Println(fxy.name)
}


运行之后,效果如下:


可以发现,我们可以直接把结构体当作一个类型来使用。也就是说,在Go语言中,我们可以自己通过结构体定义数据类型。


而使用结构体,可以直接输出,也可以通过[变量.属性]的方式,获取结构体中的单个值。同样的,结构体也可以时指针变量,这一点与C语言一样。


切片类型

切片(slice)是对数组的一个连续“片段”的引用,所以切片也可以看作一个引用类型,或者相当于Python中的list。


切片的内部结构包含内存地址、大小以及内容,一般用于快速地操作一块数据集合。如下图所示:


其中,切片的指针指向数组,长度代表当前切片的长度,容量是当前切片的容量。容量总是大于或等于切片的长度,而且切片默认指向一段连续的内存区域。


从指定范围生成切片

切片与数组密不可分,如果将数组理解为一栋火车厢,那么切片就是把不同连续车厢出租给使用者。在出租的过程中,需要选择开始车厢与结束车厢,这个过程就会生成切片。示例如下:

var sliceBuilder [10]int
for i :=0;i<10;i++{
  sliceBuilder[i]=i+1
}
fmt.Println(sliceBuilder[5:7])
fmt.Println(sliceBuilder[8:])
fmt.Println(sliceBuilder[:5])


运行之后,控制台输出如下:

看过前面字符串获取子字符串的用户,肯定会问,切片有何区别?


怎么说呢?切片有点像C语言的指针。指针可以做运算,但代价是内存操作越界。切片在指针的基础上增加了大小,约束了切片对应的内存区域。


在切片的使用过程中,无法对切片内部的地址和大小进行手动调整,因此切片比指针更安全强大。


重置切片

如果把切片开始与结束位置都设置为0,则生成的切片将变空,代码如下:

var sliceBuilder [10]int
for i :=0;i<10;i++{
  sliceBuilder[i]=i+1
}
fmt.Println(sliceBuilder[0:0])


记住是清空,不是全部赋值为0,也就是说充值的切片没有任何元素。运行之后,效果如下:



直接声明切片

切片也是可以直接被声明的,并不一定需要从数组操作。其语法如下:

var name []Type

注意,这个看上去与数组声明的方式差不多,但有本质区别,不信的读者回头看看上面的数组。数组定义必须给定你需要创建一个多少元素的数组,而切片不需要。


示例:

var sliceInt []int
var sliceString []string
var emptySlice =[]int{}
fmt.Println(sliceInt,sliceString,emptySlice)
fmt.Println(len(sliceInt),len(sliceString),len(emptySlice))
fmt.Println(sliceString==nil)
fmt.Println(sliceInt==nil)
fmt.Println(emptySlice==nil)


运行之后,效果如下:


需要注意的是,切片是动态结构,只能与nil判定相等,不能互相判定相等。在声明了切片之后,可以使用append()方法向切片中添加元素。如果需要创建一个指定长度的切片,则可以使用make()方法创建。

sliceInt :=make([]int,6,10)
fmt.Println(sliceInt)


上面声明了一个长度为6,容量为10的切片,控制台会输出6个0的切片。


用make()函数生成的切片会发生内存分配操作。但如果给定了开始与结束位置(包括切片复位)的切片,则只是将新的切片结构指向已经分配的内存区域。设置开始与结束位置,不会发生内存分配操作。


Map

Map就是“键值对”的无序集合。元素包含一个key,与一个Value。有时候也会成为字典。其定义的语法如下:

var student map[string]string
var user = map[string]string{"liyuanjing": "29", "fengxiangyao": "29"}
student =make(map[string]string)//删除这行在测试
student["liyuanjing"] = "29"
fmt.Println(student)
fmt.Println(user)


运行之后,控制台输出如下:


如上面注释一样,如果删除make函数那一样,肯定会报错。这是因为在声明student 后并未初始化它,所以它的值是nil,不指向任何内存地址。需要通过make方法分配确定的内存地址,程序修改后即可正常运行。


在我们的项目中,有时候Key并不仅仅只对应一个Value,如果要key对应多个值,那么Map应该怎么做?示例如下:

map1 := make(map[int][]int)
map1[22]=[]int{1,2,3,4,5}
fmt.Println(map1)


运行之后,效果如下:

相关文章
|
23天前
|
移动开发 开发者 HTML5
构建响应式Web界面:Flexbox与Grid的实战应用
【10月更文挑战第22天】随着互联网的普及,用户对Web界面的要求越来越高,不仅需要美观,还要具备良好的响应性和兼容性。为了满足这些需求,Web开发者需要掌握一些高级的布局技术。Flexbox和Grid是现代Web布局的两大法宝,它们分别由CSS3和HTML5引入,能够帮助开发者构建出更加灵活和易于维护的响应式Web界面。本文将深入探讨Flexbox和Grid的实战应用,并通过具体实例来展示它们在构建响应式Web界面中的强大能力。
34 3
|
1月前
|
前端开发 JavaScript Python
Python Web应用中的WebSocket实战:前后端分离时代的实时数据交换
在前后端分离的Web应用开发模式中,如何实现前后端之间的实时数据交换成为了一个重要议题。传统的轮询或长轮询方式在实时性、资源消耗和服务器压力方面存在明显不足,而WebSocket技术的出现则为这一问题提供了优雅的解决方案。本文将通过实战案例,详细介绍如何在Python Web应用中运用WebSocket技术,实现前后端之间的实时数据交换。
76 0
|
18天前
|
设计模式 前端开发 数据库
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第27天】本文介绍了Django框架在Python Web开发中的应用,涵盖了Django与Flask等框架的比较、项目结构、模型、视图、模板和URL配置等内容,并展示了实际代码示例,帮助读者快速掌握Django全栈开发的核心技术。
107 45
|
10天前
|
存储 编译器 Go
go语言中的变量、常量、数据类型
【11月更文挑战第3天】
27 9
|
13天前
|
缓存 前端开发 中间件
go语言中Web框架
【10月更文挑战第22天】
23 4
|
13天前
|
前端开发 API 开发者
Python Web开发者必看!AJAX、Fetch API实战技巧,让前后端交互如丝般顺滑!
在Web开发中,前后端的高效交互是提升用户体验的关键。本文通过一个基于Flask框架的博客系统实战案例,详细介绍了如何使用AJAX和Fetch API实现不刷新页面查看评论的功能。从后端路由设置到前端请求处理,全面展示了这两种技术的应用技巧,帮助Python Web开发者提升项目质量和开发效率。
29 1
|
16天前
|
SQL 负载均衡 安全
安全至上:Web应用防火墙技术深度剖析与实战
【10月更文挑战第29天】在数字化时代,Web应用防火墙(WAF)成为保护Web应用免受攻击的关键技术。本文深入解析WAF的工作原理和核心组件,如Envoy和Coraza,并提供实战指南,涵盖动态加载规则、集成威胁情报、高可用性配置等内容,帮助开发者和安全专家构建更安全的Web环境。
35 1
|
19天前
|
安全 数据库 开发者
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第26天】本文详细介绍了如何在Django框架下进行全栈开发,包括环境安装与配置、创建项目和应用、定义模型类、运行数据库迁移、创建视图和URL映射、编写模板以及启动开发服务器等步骤,并通过示例代码展示了具体实现过程。
31 2
|
2月前
|
JSON Rust 安全
30天拿下Rust之实战Web Server
30天拿下Rust之实战Web Server
60 7
|
1月前
|
移动开发 前端开发 JavaScript
前端开发实战:利用Web Speech API之speechSynthesis实现文字转语音功能
前端开发实战:利用Web Speech API之speechSynthesis实现文字转语音功能
155 0