解析 Go 编程语言数据类型:bool、整数、浮点数和字符串详细介绍

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
Serverless 应用引擎免费试用套餐包,4320000 CU,有效期3个月
云原生网关 MSE Higress,422元/月
简介: 数据类型是编程中的重要概念。数据类型指定了变量值的大小和类型。Go是静态类型的,这意味着一旦变量类型被定义,它只能存储该类型的数据。

数据类型

数据类型是编程中的重要概念。数据类型指定了变量值的大小和类型。Go是静态类型的,这意味着一旦变量类型被定义,它只能存储该类型的数据。

基本数据类型

Go 有三种基本数据类型:

  • bool:表示布尔值,要么是true,要么是false。
  • 数值型:表示整数类型、浮点数值和复数类型。
  • string:表示字符串值。

示例

以下示例展示了Go中的一些不同数据类型:

package main
import ("fmt")

func main() {
   
  var a bool = true     // 布尔值
  var b int = 5         // 整数
  var c float32 = 3.14  // 浮点数
  var d string = "Hi!"  // 字符串

  fmt.Println("布尔值: ", a)
  fmt.Println("整数: ", b)
  fmt.Println("浮点数:   ", c)
  fmt.Println("字符串:  ", d)
}

布尔数据类型

布尔数据类型使用bool关键字声明,只能取值true或false。

布尔数据类型的默认值是false。

示例

以下示例展示了声明布尔变量的不同方式:

package main
import ("fmt")

func main() {
   
  var b1 bool = true // 有类型声明和初始值
  var b2 = true // 无类型声明但有初始值
  var b3 bool // 有类型声明但无初始值
  b4 := true // 无类型声明但有初始值

  fmt.Println(b1) // 输出 true
  fmt.Println(b2) // 输出 true
  fmt.Println(b3) // 输出 false
  fmt.Println(b4) // 输出 true
}

Go整数数据类型

整数数据类型用于存储没有小数点的整数,例如35、-50或1345000。

整数数据类型有两个类别:

  • 有符号整数 - 可以存储正数和负数
  • 无符号整数 - 只能存储非负数

提示:整数的默认类型是int。如果不指定类型,类型将为int

有符号整数

使用int关键字声明的有符号整数可以存储正数和负数:

package main
import ("fmt")

func main() {
   
  var x int = 500
  var y int = -4500
  fmt.Printf("类型: %T, 值: %v\n", x, x)
  fmt.Printf("类型: %T, 值: %v\n", y, y)
}

Go有五个有符号整数的关键字/类型:

类型 大小 范围
int 取决于平台: 在32位系统中为 -2147483648 到 2147483647,
32位系统为32位, 在64位系统中为 -9223372036854775808 到 9223372036854775807
64位系统为64位
int8 8位/1字节 -128 到 127
int16 16位/2字节 -32768 到 32767
int32 32位/4字节 -2147483648 到 2147483647
int64 64位/8字节 -9223372036854775808 到 9223372036854775807

无符号整数

使用uint关键字声明的无符号整数只能存储非负数:

package main
import ("fmt")

func main() {
   
  var x uint = 500
  var y uint = 4500
  fmt.Printf("类型: %T, 值: %v\n", x, x)
  fmt.Printf("类型: %T, 值: %v\n", y, y)
}

Go有五个无符号整数的关键字/类型:

类型 大小 范围
uint 取决于平台: 在32位系统中为 0 到 4294967295,
32位系统为32位, 在64位系统中为 0 到 18446744073709551615
64位系统为64位
uint8 8位/1字节 0 到 255
uint16 16位/2字节 0 到 65535
uint32 32位/4字节 0 到 4294967295
uint64 64位/8字节 0 到 18446744073709551615

选择整数类型取决于变量需要存储的值。

以下示例会导致错误,因为1000超出了int8的范围(范围是从-128到127):

package main
import ("fmt")

func main() {
   
  var x int8 = 1000
  fmt.Printf("类型: %T, 值: %v\n", x, x)
}

结果:

./prog.go:5:7: constant 1000 overflows int8

Go浮点数数据类型

浮点数数据类型用于存储带有小数点的正数和负数,例如35.3、-2.34或3597.34987。

浮点数数据类型有两个关键字:

  • float32 32位 -3.4e+38 到 3.4e+38。
  • float64 64位 -1.

7e+308 到 +1.7e+308。

提示:浮点数的默认类型是float64。如果不指定类型,类型将为float64

float32关键字

以下示例展示了如何声明一些float32类型的变量:

package main

import (
  "fmt"
)

func main() {
   
  var x float32 = 123.78
  var y float32 = 3.4e+38
  fmt.Printf("类型:%T,值:%v\n", x, x)
  fmt.Printf("类型:%T,值:%v\n", y, y)
}

float64关键字

float32相比,float64数据类型可以存储更大范围的数字。

以下示例展示了如何声明一个float64类型的变量:

package main

import (
  "fmt"
)

func main() {
   
  var x float64 = 1.7e+308
  fmt.Printf("类型:%T,值:%v\n", x, x)
}

选择使用哪种浮点类型取决于变量需要存储的值。

以下示例会导致错误,因为3.4e+39超出了float32的范围:

package main

import (
  "fmt"
)

func main() {
   
  var x float32 = 3.4e+39
  fmt.Println(x)
}

结果:

./prog.go:5:7: constant 3.4e+39 overflows float32

字符串数据类型

字符串数据类型用于存储字符序列(文本)。字符串值必须用双引号括起来:

package main

import (
  "fmt"
)

func main() {
   
  var txt1 string = "Hello!"
  var txt2 string
  txt3 := "World 1"

  fmt.Printf("类型:%T,值:%v\n", txt1, txt1)
  fmt.Printf("类型:%T,值:%v\n", txt2, txt2)
  fmt.Printf("类型:%T,值:%v\n", txt3, txt3)
}

结果:

类型:string, 值:Hello!
类型:string, 值:
类型:string, 值:World 1

最后

为了方便其他设备和平台的小伙伴观看往期文章:

微信公众号搜索:Let us Coding,关注后即可获取最新文章推送

看完如果觉得有帮助,欢迎 点赞、收藏、关注

相关文章
|
2月前
|
存储 Go 索引
go语言中遍历字符串
go语言中遍历字符串
67 5
|
28天前
|
存储 关系型数据库 MySQL
double ,FLOAT还是double(m,n)--深入解析MySQL数据库中双精度浮点数的使用
本文探讨了在MySQL中使用`float`和`double`时指定精度和刻度的影响。对于`float`,指定精度会影响存储大小:0-23位使用4字节单精度存储,24-53位使用8字节双精度存储。而对于`double`,指定精度和刻度对存储空间没有影响,但可以限制数值的输入范围,提高数据的规范性和业务意义。从性能角度看,`float`和`double`的区别不大,但在存储空间和数据输入方面,指定精度和刻度有助于优化和约束。
111 5
|
1月前
|
Go
go语言for 遍历字符串
go语言for 遍历字符串
35 8
|
1月前
|
存储 编译器 C语言
【C语言】数据类型全解析:编程效率提升的秘诀
在C语言中,合理选择和使用数据类型是编程的关键。通过深入理解基本数据类型和派生数据类型,掌握类型限定符和扩展技巧,可以编写出高效、稳定、可维护的代码。无论是在普通应用还是嵌入式系统中,数据类型的合理使用都能显著提升程序的性能和可靠性。
55 8
|
2月前
|
Go 索引
go语言遍历字符串
go语言遍历字符串
41 3
|
2月前
|
存储 编译器 Go
go语言中的变量、常量、数据类型
【11月更文挑战第3天】
39 9
|
2月前
|
Dart 安全 编译器
Flutter结合鸿蒙next 中数据类型转换的高级用法:dynamic 类型与其他类型的转换解析
在 Flutter 开发中,`dynamic` 类型提供了灵活性,但也带来了类型安全性问题。本文深入探讨 `dynamic` 类型及其与其他类型的转换,介绍如何使用 `as` 关键字、`is` 操作符和 `whereType<T>()` 方法进行类型转换,并提供最佳实践,包括避免过度使用 `dynamic`、使用 Null Safety 和异常处理,帮助开发者提高代码的可读性和可维护性。
104 1
|
2月前
|
存储 Go PHP
Go语言中的加解密利器:go-crypto库全解析
在软件开发中,数据安全和隐私保护至关重要。`go-crypto` 是一个专为 Golang 设计的加密解密工具库,支持 AES 和 RSA 等加密算法,帮助开发者轻松实现数据的加密和解密,保障数据传输和存储的安全性。本文将详细介绍 `go-crypto` 的安装、特性及应用实例。
122 0
|
2月前
|
机器学习/深度学习 数据采集 数据挖掘
Python编程语言的魅力:从入门到进阶的全方位解析
Python编程语言的魅力:从入门到进阶的全方位解析
|
2月前
|
安全 测试技术 Go
Go语言中的并发编程模型解析####
在当今的软件开发领域,高效的并发处理能力是提升系统性能的关键。本文深入探讨了Go语言独特的并发编程模型——goroutines和channels,通过实例解析其工作原理、优势及最佳实践,旨在为开发者提供实用的Go语言并发编程指南。 ####

推荐镜像

更多