golang数据类型二

 

 

 

 

 

 

 

字符类型

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 3.14基本数据类型的相互转换

 

 

 

 

 

3.15基本数据类型和string的转换

 

 

 

 

 

 

FormatInt

// FormatUint 将 int 型整数 i 转换为字符串形式
// base:进位制(2 进制到 36 进制)
// 大于 10 进制的数,返回值使用小写字母 'a' 到 'z'
func FormatInt(i int64, base int) string

func main(){
	var num1 int = 99
	//var num2 float64 = 23.456
	//var b bool = true
	var str string

	str = strconv.FormatInt(int64(num1),2)
	fmt.Printf("str type %T  str=%q\n",str,str)

}

  返回:

str type string  str="1100011"

  

FormatFloat 

/ FormatFloat 将浮点数 f 转换为字符串值
// f:要转换的浮点数
// fmt:格式标记(b、e、E、f、g、G)
// prec:精度(数字部分的长度,不包括指数部分)
// bitSize:指定浮点类型(32:float32、64:float64)
//
// 格式标记:
// 'b' (-ddddp±ddd,二进制指数)
// 'e' (-d.dddde±dd,十进制指数)
// 'E' (-d.ddddE±dd,十进制指数)
// 'f' (-ddd.dddd,没有指数)
// 'g' ('e':大指数,'f':其它情况)
// 'G' ('E':大指数,'f':其它情况)
//
// 如果格式标记为 'e','E'和'f',则 prec 表示小数点后的数字位数
// 如果格式标记为 'g','G',则 prec 表示总的数字位数(整数部分+小数部分)
func FormatFloat(f float64, fmt byte, prec, bitSize int) string

func main() {
	f := 100.12345678901234567890123456789
	fmt.Println(strconv.FormatFloat(f, 'b', 5, 32))
	// 13123382p-17
	fmt.Println(strconv.FormatFloat(f, 'e', 5, 32))
	// 1.00123e+02
	fmt.Println(strconv.FormatFloat(f, 'E', 5, 32))
	// 1.00123E+02
	fmt.Println(strconv.FormatFloat(f, 'f', 5, 32))
	// 100.12346
	fmt.Println(strconv.FormatFloat(f, 'g', 5, 32))
	// 100.12
	fmt.Println(strconv.FormatFloat(f, 'G', 5, 32))
	// 100.12
	fmt.Println(strconv.FormatFloat(f, 'b', 30, 32))
	// 13123382p-17
	fmt.Println(strconv.FormatFloat(f, 'e', 30, 32))
	// 1.001234588623046875000000000000e+02
	fmt.Println(strconv.FormatFloat(f, 'E', 30, 32))
	// 1.001234588623046875000000000000E+02
	fmt.Println(strconv.FormatFloat(f, 'f', 30, 32))
	// 100.123458862304687500000000000000
	fmt.Println(strconv.FormatFloat(f, 'g', 30, 32))
	// 100.1234588623046875
	fmt.Println(strconv.FormatFloat(f, 'G', 30, 32))
	// 100.1234588623046875
}

  

FormatBool 

// FormatBool 将布尔值转换为字符串 "true" 或 "false"
func FormatBool(b bool) string

func main() {
	fmt.Println(strconv.FormatBool(0 < 1)) // true
	fmt.Println(strconv.FormatBool(0 > 1)) // false
}

  

func FormatInt

func FormatInt(i int64, base int) string

返回i的base进制的字符串表示。base 必须在2到36之间,结果中会使用小写字母'a'到'z'表示大于10的数字。

// Itoa 相当于 FormatInt(i, 10)
func Itoa(i int) string

func main() {
	fmt.Println(strconv.Itoa(-2048)) // -2048
	fmt.Println(strconv.Itoa(2048))  // 2048
}

  

string类型转基本数据类型

 

转载于:https://www.cnblogs.com/sunlong88/p/10988972.html

### Golang 数据类型概述 在 Go 语言中,支持多种内置的数据类型。这些数据类型分为基本类型和复合类型。 #### 基本数据类型 Go 支持以下几种基本数据类型[^3]: - **布尔类型 (`bool`)** 表示真或假的逻辑值。 - **数值类型** - 整形: - `int8`, `int16`, `int32`, `int64`: 有符号整数 - `uint8`, `uint16`, `uint32`, `uint64`: 无符号整数 - `byte`: 同义于 `uint8` - `rune`: 同义于 `int32`,用于表示 Unicode 码点 - `int`, `uint`: 平台相关的默认整型大小 - 浮点型: - `float32`, `float64` - 复杂浮点型: - `complex64`, `complex128` - **字符串 (`string`)** 字符串是一组不可变字符序列,由双引号包围。 #### 查看变量的字节大小和数据类型 为了获取变量的具体信息,在程序运行期间可以通过特定函数来实现这一点。例如,要打印出一个变量的实际占用空间以及其具体类型,可以使用如下方式[^4]: ```go package main import ( "fmt" "unsafe" ) func main() { var i int = 100 fmt.Printf("i 的类型:%T\n", i) fmt.Printf("i 占用的空间大小:%d bytes\n", unsafe.Sizeof(i)) } ``` 这段代码展示了如何利用标准库中的 `fmt` 包来进行格式化输出,并借助 `unsafe.Sizeof()` 函数计算给定表达式的存储需求。 #### 显式类型转换 值得注意的是,在 Go 中不同类型之间的赋值操作不会发生隐含的自动转型;相反地,程序员必须通过显示的方式完成这一过程。对于简单的数值类型间转化,遵循这样的模式[^5]: ```go var a uint8 = 255 var b int = int(a) // 将 uint8 转换为 int 类型 ``` 这种设计有助于减少潜在错误并提高代码的安全性和可读性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值