Go——二、变量和数据类型

Go

  • 一、Go语言中的变量和常量
    • 1、Go语言中变量的声明
    • 2、如何定义变量
      • 方式1:
      • 方式2:带类型
      • 方式3:类型推导方式定义变量
      • 方式4:声明多个变量
      • 总结
    • 3、如何定义常量
    • 4、Const常量结合iota的使用
  • 二、Golang的数据类型
    • 1、概述
    • 2、整型
      • 2.1 类型转换
      • 2.2 数字字面量语法
      • 2.3 进制转换
    • 3、浮点型
      • Golang中精度丢失的问题
    • 4、布尔类型
    • 5、字符串类型
      • 字符串常见操作
    • 6、byte 和 rune类型
      • 修改字符串
    • 7、基本数据类型转换
      • 7.1 数值类型转换
      • 7.2 转换成字符串类型
      • 7.3 字符串转换成int 和 float类型

一、Go语言中的变量和常量

1、Go语言中变量的声明

Go语言变量是由字母、数字、下划线组成,其中首个字符不能为数字。Go语言中关键字和保留字都不能用作变量名。
Go语言中变量需要声明后才能使用,同一作用域内不支持重复声明。并且Go语言的变量声明后必须使用。
变量声明后,没有初始化,打印出来的是空

2、如何定义变量

方式1:

var name = "zhangsan"

在这里插入图片描述

方式2:带类型

var name string = "zhangsan"

在这里插入图片描述

方式3:类型推导方式定义变量

a在函数内部,可以使用更简略的 := 方式声明并初始化变量。
注意: 短变量只能用于声明局部变量,不能用于全局变量声明

变量名 := 表达式

在这里插入图片描述

方式4:声明多个变量

类型都是一样的变量

var 变量名称, 变量名称 类型

类型不一样的变量

var (变量名称 类型变量名称 类型
)

案例

package mainimport "fmt"func main() {var a1, a2 stringa1 = "123"a2 = "123"fmt.Printf(a1)fmt.Printf(a2)
}

在这里插入图片描述

总结

全部的定义方式

package mainimport "fmt"func main() {fmt.Println("hello")fmt.Print("A", "B", "C")fmt.Println()var a = 10fmt.Printf("%d", a)var name = "zhangsan1"var name2 = "zhangsan2"name3 := "zhangsan3"fmt.Println(name)fmt.Println(name2)fmt.Println(name3)fmt.Printf("name1=%v name2=%v name3=%v \n", name, name2, name3)
}

在这里插入图片描述

3、如何定义常量

相对于变量,常量是恒定不变的值,多用于定义程序运行期间不会改变的那些值。常量的声明和变量声明非常类似,只是把var换成了const,常量在定义的时候必须赋值。

// 定义了常量,可以不用立即使用
const pi = 3.14// 定义两个常量
const(A = "A"B = "B"
)// const同时声明多个常量时,如果省略了值表示和上面一行的值相同
const(A = "A"BC
)

4、Const常量结合iota的使用

iota是golang 语言的常量计数器,只能在常量的表达式中使用
iota在const关键字出现时将被重置为0(const内部的第一行之前),const中每新增一行常量声明将使iota计数一次(iota可理解为const语句块中的行索引)。
每次const出现,都会让iota初始化为0【自增长】

const a = iota // a = 0
const (b = iota // b=0c        // c = 1d        // d = 2
)

const iota使用_跳过某些值

const (b = iota // b=0_d        // d = 2
)

二、Golang的数据类型

1、概述

Go 语言中数据类型分为:基本数据类型和复合数

  • 据类型基本数据类型有:
    整型、浮点型、布尔型、字符串
  • 复合数据类型有:
    数组、切片、结构体、函数、map、通道(channel)、接口等。

2、整型

整型的类型有很多中,包括 int8,int16,int32,int64。我们可以根据具体的情况来进行定义
如果我们直接写 int也是可以的,它在不同的操作系统中,int的大小是不一样的

  • 32位操作系统:int -> int32
  • 64位操作系统:int -> int64

可以通过unsafe.Sizeof 查看不同长度的整型,在内存里面的存储空间

var num2 = 12
fmt.Println(unsafe.Sizeof(num2))

2.1 类型转换

通过在变量前面添加指定类型,就可以进行强制类型转换

package mainimport "fmt"func main() {var a1 int16 = 10var a2 int32 = 12var a3 = int32(a1) + a2fmt.Println(a3)
}

在这里插入图片描述
注意,高位转低位的时候,需要注意,会存在精度丢失,比如上述16转8位的时候,就丢失了

var n1 int16 = 130
fmt.Println(int8(n1)) // 变成 -126

在这里插入图片描述

2.2 数字字面量语法

Go1.13版本之后,引入了数字字面量语法,这样便于开发者以二进制、八进制或十六进制浮点数的格式定义数字,例如:

v := 0b00101101  // 代表二进制的101101
v:= Oo377       // 代表八进制的377

2.3 进制转换

package mainimport "fmt"func main() {var number = 17// 原样输出fmt.Printf("%v\n", number)// 十进制输出fmt.Printf("%d\n", number)// 以八进制输出fmt.Printf("%o\n", number)// 以二进制输出fmt.Printf("%b\n", number)// 以十六进制输出fmt.Printf("%x\n", number)
}

在这里插入图片描述

3、浮点型

Go语言支持两种浮点型数:float32和float64。这两种浮点型数据格式遵循IEEE754标准:
float32的浮点数的最大范围约为3.4e38,可以使用常量定义:math.MaxFloat32。float64的浮点数的最大范围约为1.8e308,可以使用一个常量定义:math.MaxFloat64。
打印浮点数时,可以使用fmt包配合动词%f,代码如下:

package mainimport ("fmt""math"
)func main() {var pi = math.Pi// 打印浮点类型,默认小数点6位fmt.Printf("%f\n", pi)// 打印浮点类型,打印小数点后2位fmt.Printf("%.2f\n", pi)
}

在这里插入图片描述

Golang中精度丢失的问题

几乎所有的编程语言都有精度丢失的问题,这是典型的二进制浮点数精度损失问题,在定长条件下,二进制小数和十进制小数互转可能有精度丢失。

package mainimport ("fmt"
)func main() {d := 1129.6fmt.Println(d * 100)
}

在这里插入图片描述
解决方法,使用第三方包来解决精度损失的问题
http://github.com/shopspring/decimal

4、布尔类型

定义:

package mainimport "fmt"func main() {var fl = falseif fl {fmt.Println("true")} else {fmt.Println("false")}
}

在这里插入图片描述

5、字符串类型

Go 语言中的字符串以原生数据类型出现,使用字符串就像使用其他原生数据类型(int、bool、float32、float64等)一样。Go语言里的字符串的内部实现使用UTF-8编码。字符串的值为双引号(")中的内容,可以在Go语言的源码中直接添加非ASCll码字符,例如:

s1 := "hello"
s1 := "你好"

如果想要定义多行字符串,可以使用反引号

var str = `第一行
第二行`
fmt.Println(str)

在这里插入图片描述

字符串常见操作

  • len(str):求长度
  • +或fmt.Sprintf:拼接字符串
  • strings.Split:分割
  • strings.contains:判断是否包含
  • strings.HasPrefix,strings.HasSuffix:前缀/后缀判断
  • strings.Index(),strings.LastIndex():子串出现的位置
  • strings.Join():join操作
  • strings.Index():判断在字符串中的位置

6、byte 和 rune类型

组成每个字符串的元素叫做 “字符”,可以通过遍历字符串元素获得字符。 字符用单引号 ‘’ 包裹起来。
Go语言中的字符有以下两种类型

  • uint8类型:或者叫byte型,代表了ACII码的一个字符
  • rune类型:代表一个UTF-8字符

当需要处理中文,日文或者其他复合字符时,则需要用到rune类型,rune类型实际上是一个int32。
Go使用了特殊的rune类型来处理Unicode,让基于Unicode的文本处理更为方便,也可以使用byte型进行默认字符串处理,性能和扩展性都有照顾。
需要注意的是,在go语言中,一个汉字占用3个字节(utf-8),一个字母占用1个字节

package main
import "fmt"func main() {var a byte = 'a'// 输出的是ASCII码值,也就是说当我们直接输出byte(字符)的时候,输出的是这个字符对应的码值fmt.Println(a)// 输出的是字符fmt.Printf("%c", a)// for循环打印字符串里面的字符// 通过len来循环的,相当于打印的是ASCII码s := "你好 golang"for i := 0; i < len(s); i++ {fmt.Printf("%v(%c)\t", s[i], s[i])}// 通过rune打印的是 utf-8字符for index, v := range s {fmt.Println(index, v)}
}

在这里插入图片描述

修改字符串

要修改字符串,需要先将其转换成[]rune 或 []byte类型,完成后在转换成string,无论哪种转换都会重新分配内存,并复制字节数组
转换为 []byte 类型

// 字符串转换
s1 := "big"
byteS1 := []byte(s1)
byteS1[0] = 'p'
fmt.Println(string(byteS1))

在这里插入图片描述
转换为rune类型

// rune类型
s2 := "你好golang"
byteS2 := []rune(s2)
byteS2[0] = '我'
fmt.Println(string(byteS2))

在这里插入图片描述

7、基本数据类型转换

7.1 数值类型转换

// 整型和浮点型之间转换
var aa int8 = 20
var bb int16 = 40
fmt.Println(int16(aa) + bb)// 建议整型转换成浮点型
var cc int8 = 20
var dd float32 = 40
fmt.Println(float32(cc) + dd)

在这里插入图片描述
建议从低位转换成高位,这样可以避免。

7.2 转换成字符串类型

  • 第一种方式,就是通过 fmt.Sprintf()来转换
// 字符串类型转换
var i int = 20
var f float64 = 12.456
var t bool = true
var b byte = 'a'
str1 := fmt.Sprintf("%d", i)
fmt.Printf("类型:%v-%T \n", str1, str1)str2 := fmt.Sprintf("%f", f)
fmt.Printf("类型:%v-%T \n", str2, str2)str3 := fmt.Sprintf("%t", t)
fmt.Printf("类型:%v-%T \n", str3, str3)str4 := fmt.Sprintf("%c", b)
fmt.Printf("类型:%v-%T \n", str4, str4)

在这里插入图片描述

  • 第二种方法就是通过strconv包里面的集中转换方法进行转换
// int类型转换str类型
var num1 int64 = 20
s1 := strconv.FormatInt(num1, 10)
fmt.Printf("转换:%v - %T", s1, s1)// float类型转换成string类型
var num2 float64 = 3.1415926/*参数1:要转换的值参数2:格式化类型 'f'表示float,'b'表示二进制,‘e’表示 十进制参数3:表示保留的小数点,-1表示不对小数点格式化参数4:格式化的类型,传入64位 或者 32位*/
s2 := strconv.FormatFloat(num2, 'f', -1, 64)
fmt.Printf("转换:%v-%T", s2, s2)

在这里插入图片描述

7.3 字符串转换成int 和 float类型

str := "10"
// 第一个参数:需要转换的数,第二个参数:进制, 参数三:32位或64位
num,_ = strconv.ParseInt(str, 10, 64)// 转换成float类型
str2 := "3.141592654"
num,_ = strconv.ParseFloat(str2, 10)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/205422.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LeetCode Hot100 124.二叉树中的最大路径和

题目&#xff1a; 二叉树中的 路径 被定义为一条节点序列&#xff0c;序列中每对相邻节点之间都存在一条边。同一个节点在一条路径序列中 至多出现一次 。该路径 至少包含一个 节点&#xff0c;且不一定经过根节点。 路径和 是路径中各节点值的总和。 给你一个二叉树的根节点…

Linux基本指令总结(二)

1.man指令&#xff08;重要&#xff09; Linux的命令有很多参数&#xff0c;我们不可能全记住&#xff0c;我们可以通过查看联机手册获取帮助。访问Linux手册页的命令是 man 语法: man [选项] 命令 man指令就相当于一个精通linux的专家&#xff0c;你要查询的指令或者函数&…

linux的netstat命令和ss命令

1. 网络状态 State状态LISTENING监听中&#xff0c;服务端需要打开一个socket进行监听&#xff0c;侦听来自远方TCP端口的连接请求ESTABLISHED已连接&#xff0c;代表一个打开的连接&#xff0c;双方可以进行或已经在数据交互了SYN_SENT客户端通过应用程序调用connect发送一个…

【开源】基于Vue和SpringBoot的企业项目合同信息系统

项目编号&#xff1a; S 046 &#xff0c;文末获取源码。 \color{red}{项目编号&#xff1a;S046&#xff0c;文末获取源码。} 项目编号&#xff1a;S046&#xff0c;文末获取源码。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 数据中心模块2.2 合同审批模块2.3 合…

运维 | 四层和七层负载均衡介绍

关注: CodingTechWork 负载均衡 负载均衡介绍 概念 负载均衡是建立在现有的网络结构之上&#xff0c;提供一种廉价且透明的方式进行网络设备和服务器带宽的扩展&#xff0c;从而增加吞吐量&#xff0c;加强应用服务的数据处理能力&#xff0c;有效提高网络的灵活性和可用性。…

找不到 sun.misc.BASE64Decoder ,sun.misc.BASE64Encoder 类

找不到 sun.misc.BASE64Decoder &#xff0c;sun.misc.BASE64Encoder 类 1. 现象 idea 引用报错 找不到对应的包 import sun.misc.BASE64Decoder; import sun.misc.BASE64Encoder;2. 原因 因为sun.misc.BASE64Decoder和sun.misc.BASE64Encoder是Java的内部API&#xff0c;通…

矩阵快速幂及应用实战[C/C++]

矩阵快速幂 矩阵快速幂可以用来优化递推问题&#xff0c;如状态机DP&#xff0c;需要一丢丢线性代数里面矩阵的概念&#xff0c;只需要知道简单的矩阵乘法&#xff0c;结合我们普通的二分快速幂就能很快的掌握矩阵快速幂。 问题引入 三步问题。有个小孩正在上楼梯&#xff0c;楼…

【海思SS528 | VDEC】MPP媒体处理软件V5.0 | VDEC的使用总结

&#x1f601;博客主页&#x1f601;&#xff1a;&#x1f680;https://blog.csdn.net/wkd_007&#x1f680; &#x1f911;博客内容&#x1f911;&#xff1a;&#x1f36d;嵌入式开发、Linux、C语言、C、数据结构、音视频&#x1f36d; &#x1f923;本文内容&#x1f923;&a…

Python语言学习笔记之五(Python代码注解)

本课程对于有其它语言基础的开发人员可以参考和学习&#xff0c;同时也是记录下来&#xff0c;为个人学习使用&#xff0c;文档中有此不当之处&#xff0c;请谅解。 注解与注释是不一样的&#xff0c;注解有更广泛的应用&#xff1b; 通过注解与注释都能提高代码的可读性和规…

RabbitMQ消息模型之Work Queues

Work Queues Work Queues&#xff0c;也被称为&#xff08;Task Queues&#xff09;&#xff0c;任务模型&#xff0c;也是官网给出的第二个模型&#xff0c;使用的交换机类型是直连direct&#xff0c;也是默认的交换机类型。当消息处理比较耗时的时候&#xff0c;可能生产消息…

Altium Designer学习笔记8

创建原理图元件&#xff1a; 画出原理图&#xff1a; 根据规则书画出原理图&#xff1a; 根据规则书画出封装图&#xff1a; 参照&#xff1a; 确认下过孔的内径和外径的最小允许值。

GoLang切片

一、切片基础 1、切片的定义 切片&#xff08;Slice&#xff09;是一个拥有相同类型元素的可变长度的序列它是基于数组类型做的一层封装它非常灵活&#xff0c;支持自动扩容切片是一个引用类型&#xff0c;它的内部结构包含地址、长度和容量声明切片类型的基本语法如下&#…

关于图像识别,你不得不知的三大要点

图像识别的重要性 图像识别不仅可以加速处理繁琐的任务&#xff0c;而且还可以比人工图像检查更快速或更准确地处理图像。图像识别是应用于诸多领域的关键技术&#xff0c;也是深度学习应用的主要驱动因素&#xff0c;如&#xff1a; 视觉检查&#xff1a;在制造过程中识别零部…

初刷leetcode题目(11)——数据结构与算法

&#x1f636;‍&#x1f32b;️&#x1f636;‍&#x1f32b;️&#x1f636;‍&#x1f32b;️&#x1f636;‍&#x1f32b;️Take your time ! &#x1f636;‍&#x1f32b;️&#x1f636;‍&#x1f32b;️&#x1f636;‍&#x1f32b;️&#x1f636;‍&#x1f32b;️…

Linux:创建进程 -- fork,到底是什么?

相信大家在初学进程时&#xff0c;对fork函数创建进程一定会有很多的困惑&#xff0c;比如&#xff1a; 1.fork做了什么事情?? 2.为什么fork函数会有两个返回值?3.为什么fork的两个返回值&#xff0c;会给父进程谅回子进程pid&#xff0c;给子进程返回0?4.fork之后:父子进…

Unity 引擎宣布:自 2024 年起,开发者需支付费用!

Unity引擎宣布的新的收费模式&#xff0c;从2024年1月1日开始&#xff0c;根据游戏的安装量来对开发者进行收费。具体来说&#xff0c;每次游戏被下载时&#xff0c;UnityRuntime也会被安装&#xff0c;因此可能会产生额外的费用。对于开发者来说&#xff0c;需要注意以下几点&…

yml转properties工具

目前搜索到的大部分代码都存在以下问题&#xff1a; 复杂结构解析丢失解析后顺序错乱 所以自己写了一个&#xff0c;经过不充分测试&#xff0c;基本满足使用。可以直接在线使用 在线地址 除了yml和properties互转之外&#xff0c;还可以生成代码、sql转json等&#xff0c;可…

嵌入式Linux学习(2)——经典CAN介绍(上)

目录 一. CAN与ISO-OSI Model 二. CAN通信 2.1 接线方式 2.1.1 闭环网络 2.1.2 开环网络 2.2 收发流程 2.2.1 发送 2.2.2 接收 三. CAN BUS访问与仲裁 3.1 “线与”机制​ 3.2 仲裁机制 REF CAN&#xff08;Controller Area Network&#xff09;总线协议是由 BOSC…

【蓝桥杯选拔赛真题26】C++字符串逆序 第十三届蓝桥杯青少年创意编程大赛C++编程选拔赛真题解析

目录 C/C++字符串逆序 一、题目要求 1、编程实现 2、输入输出 二、算法分析

MySQL 中的锁(三)

8.7. 死锁和空间锁 一般来说&#xff0c;只要有并发和加锁这两种情况的共同加持下&#xff0c;都会有死锁的身影。 死锁的具体成因&#xff0c;借用我们在并发编程中的内容&#xff1a; 8.7.1. 死锁 8.7.1.1. 概念 是指两个或两个以上的进程在执行过程中&#xff0c;由于竞…