golang数据类型基本介绍与使用

数据类型

类型 表示 备注
布尔型 布尔型的值只可以是常量 true 或者 false var b bool = true
数字类型 整型int8, int16, int32, int64 和浮点型 float32、float64 byte就是int8, int就是int32
字符串类型 string一串固定长度的字符连接起来的字符序列。Go 的字符串是由单个字节连接起来的。Go 语言的字符串的字节使用 UTF-8 编码标识 Unicode 文本。 单个字符可以使用byte,var c byte = 'c'
派生类型 包括:(a) 指针类型(Pointer)(b) 数组类型(c) 结构化类型(struct)(d) Channel 类型(e) 函数类型(f) 切片类型(g) 接口类型(interface)(h) Map 类型

Go语言省去了short,long,double等类型,直接用类似int16,int64这样的方式来表示。

bool类型。

要么为true,要么为false。默认值为 false。golang 中不允许将整型强制转换为布尔型。布尔型无法参与数值运算,也无法与其他类型进行转换。

数字类型

(1)整型

整型主要有 int 、int16、int32、int64、uint、uint8、uint16、uint32、uint64。如下表格

  • uint8: 无符号 8 位整型 (0 到 255)
  • uint16: 无符号 16 位整型 (0 到 65535)
  • uint32: 无符号 32 位整型 (0 到 4294967295)
  • uint64: 无符号 64 位整型 (0 到 18446744073709551615)
  • int8: 有符号 8 位整型 (-128 到 127)
  • int16: 有符号 16 位整型 (-32768 到 32767)
  • int32: 有符号 32 位整型 (-2147483648 到 2147483647)
  • int64: 有符号 64 位整型 (-9223372036854775808 到 9223372036854775807)

Go 语言的 int/uint 类型,是不可移植的类型,其长度根据宿主机的机器字长决定。int, uint 和 uintptr 在 32 位系统上通常为 32 位宽,在 64 位系统上则为 64 位宽。

(2)浮点型

浮点数类型主要有 float32、float64、complex64、complex128

  • float32: IEEE-754 32 位浮点型数
  • float64: IEEE-754 64 位浮点型数
  • complex64: 32 位实数和虚数
  • complex128: 64 位实数和虚数
    3)其他数字类型

以下列出了其他更多的数字类型:

  • byte :类似 uint8,代表了 ASCII 码的一个字符,也可以说是 ASCII 字符类型
  • rune : 类似 int32,表示一个 Unicode 码点
  • uintptr: 无符号整型,用于存放一个指针

UTF-8 是 Unicode 的实现方式之一。UTF-8 最大的一个特点,就是它是一种变长的编码方式。它可以使用 1~4 个字节表示一个符号,根据不同的符号而变化字节长度。

字符串类型

字符串定义:var str string
字符串有两种表示方式:双引号(“”);反引号,也叫原意符号(``)。

类型强转

golang 中只有强制类型转换,没有隐式类型转换。该语法只能在两个类型之间支持相互转换的时候使用。

强制类型转换的基本语法为:type(variable),可转换的数据包括变量、表达式、函数返回值等。如下代码

var a int = 8
// 将int类型改为int64类型
var b int64 = int64(a)

fmt输出

调用包fmt的函数fmt.Printf()
通用一些表示:

%v	值的默认格式表示
%+v	类似%v,但输出结构体时会添加字段名
%#v	值的Go语法表示
%T	值的类型的Go语法表示
%%	百分号

布尔值

%t	单词true或false

整数

%b	表示为二进制
%c	该值对应的unicode码值
%d	表示为十进制
%o	表示为八进制
%q	该值对应的单引号括起来的go语法字符字面值,必要时会采用安全的转义表示
%x	表示为十六进制,使用a-f
%X	表示为十六进制,使用A-F
%U	表示为Unicode格式:U+1234,等价于"U+%04X"

浮点数与复数的两个部分

%b	无小数部分、二进制指数的科学计数法,如-123456p-78;参见strconv.FormatFloat
%e	科学计数法,如-1234.456e+78
%E	科学计数法,如-1234.456E+78
%f	有小数部分但无指数部分,如123.456
%F	等价于%f
%g	根据实际情况采用%e或%f格式(以获得更简洁、准确的输出)
%G	根据实际情况采用%E或%F格式(以获得更简洁、准确的输出)

字符串

%s	直接输出字符串或者[]byte
%q	该值对应的双引号括起来的go语法字符串字面值,必要时会采用安全的转义表示
%x	每个字节用两字符十六进制数表示(使用a-f)
%X	每个字节用两字符十六进制数表示(使用A-F)    

指针

%p	表示为十六进制,并加上前导的0x    
posted @ 2024-05-29 22:21  机械心  阅读(56)  评论(0编辑  收藏  举报