golang中基础数据类型介绍
2024-01-09 07:35:08
前言
golang中基础数据类型介绍
一、基础类型介绍
Go语言中的基础类型包括数值类型、字符串类型、布尔类型和错误类型。以下是它们的主要介绍:
-
整数类型(int):
int
:平台相关的有符号整数类型。大小在不同平台上可能是32位或64位。int8
、int16
、int32
、int64
:有符号整数类型,分别为8、16、32和64位。
-
无符号整数类型(uint):
uint
:平台相关的无符号整数类型。大小在不同平台上可能是32位或64位。uint8
、uint16
、uint32
、uint64
:无符号整数类型,分别为8、16、32和64位。
-
浮点数类型(float):
float32
:32位浮点数类型。float64
:64位浮点数类型。
-
复数类型(complex):
complex64
:由两个float32
组成的复数类型。complex128
:由两个float64
组成的复数类型。
-
布尔类型(bool):
bool
:表示真(true)或假(false)的布尔类型。
-
字符串类型(string):
string
:由字符组成的字符串类型。
-
字符类型(rune):
rune
:表示Unicode代码点的整数类型。通常用于处理字符。
-
错误类型(error):
error
:是Go语言中表示错误的接口类型。常用于函数返回值,用于指示函数是否执行成功以及如果失败的话,返回的错误信息。
这些基础类型构成了Go语言的基本数据类型,它们用于声明变量、函数参数和返回值等。注意,Go语言的类型系统是静态类型的,变量一旦声明就不能改变其类型。
二、基础类型在内存中的存储方式
Go语言的基础类型在内存中的存储方式主要受到底层硬件平台的影响,不同的平台可能有不同的存储规则。然而,Go语言对于基础类型的内存布局提供了一些保证,以下是一些常见的基础类型在内存中的存储方式的概括:
-
整数类型(int、uint、int8、uint8等):
- 整数类型通常按照硬件平台的自然字节顺序存储。
- 大小为8位的整数类型(如
int8
、uint8
)会占用一个字节,16位整数类型占用两个字节,32位整数类型占用四个字节,64位整数类型占用八个字节。 - 整数类型的存储是按照补码表示的,正数和负数在内存中的存储方式相同。
-
浮点数类型(float32、float64):
- 浮点数类型的存储方式也按照硬件平台的自然字节顺序存储。
float32
占用四个字节,float64
占用八个字节。- 浮点数类型的存储遵循IEEE 754浮点数标准。
-
复数类型(complex64、complex128):
- 复数类型的存储方式与浮点数类型类似,按照硬件平台的自然字节顺序存储。
complex64
占用八个字节,由两个float32
组成,complex128
占用十六个字节,由两个float64
组成。
-
布尔类型(bool):
- 布尔类型通常占用一个字节,值为
true
时为1,值为false
时为0。
- 布尔类型通常占用一个字节,值为
-
字符类型(rune):
- 字符类型
rune
是int32
的别名,占用四个字节,按照硬件平台的自然字节顺序存储。 - 存储的是Unicode码点,因此可以表示各种字符。
- 字符类型
-
字符串类型(string):
- 字符串是不定长的,由一个指向底层字节数组的指针和一个长度字段组成。
- 字符串的内容以UTF-8编码方式存储。
在实际开发中,Go语言的这些内存存储规则使得开发者不需要过于关心底层的内存细节,从而更加方便和安全地进行编程。
三、基础类型的简单演示
package main
import (
"fmt"
"math"
)
func main() {
// 整数类型
var integer int = 42
fmt.Println("Integer:", integer)
// 浮点数类型
var floatNumber float64 = 3.14
fmt.Println("Float Number:", floatNumber)
// 复数类型
var complexNumber complex128 = complex(1, 2)
fmt.Println("Complex Number:", complexNumber)
// 布尔类型
var isTrue bool = true
fmt.Println("Boolean:", isTrue)
// 字符串类型
var str string = "Hello, Go!"
fmt.Println("String:", str)
// 字符类型(Unicode)
var char rune = 'A'
fmt.Println("Character:", char)
// 错误类型
var err error = fmt.Errorf("This is an error")
fmt.Println("Error:", err)
// 使用常量和math包
const pi = math.Pi
fmt.Println("Value of Pi:", pi)
}
这个示例演示了整数、浮点数、复数、布尔、字符串、字符、错误等基础类型的声明和使用。这只是一个简单的入门示例,实际的应用中可能涉及更复杂的操作和类型转换。
文章来源:https://blog.csdn.net/u010844836/article/details/135422901
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!