我有一个包含整数的字符串(已从文件中读取)。
我正在尝试使用string
将int
转换为strconv.ParseInt()
。 ParseInt
要求我提供一个bitsize(位大小0,8,16,32和64对应于int,int8,int16,int32和int64)。
从文件读取的整数很小(即它应该适合普通的int)。但是,如果我传递0的bitsize,我得到类型int64
的结果(可能是因为我在64位操作系统上运行)。
为什么会这样?我如何获得正常的int? (如果有人对我何时以及为什么要使用不同的int类型进行快速入门,那就太棒了!)
编辑:我可以使用int([i64_var])
将int64转换为普通的int。但我仍然不明白为什么ParseInt()
在我请求0的位数时给我一个int64。
答案 0 :(得分:50)
func ParseInt(s string, base int, bitSize int) (i int64, err error)
ParseInt始终返回int64
bitSize
定义了值的范围。如果对应于s的值不能用给定大小的有符号整数表示,则err.Err = ErrRange。
http://golang.org/pkg/strconv/#ParseInt
type int int
int是一个有符号整数类型,其大小至少为32位。但是,它是一种独特的类型,而不是int32。
的别名http://golang.org/pkg/builtin/#int
因此,int
将来可能会超过32位,或者在某些系统中会大于int
。
我猜某些系统int64
可能比int32
更快,因为该系统仅适用于64位整数。
以下是bitSize
为8
http://play.golang.org/p/_osjMqL6Nj
package main
import (
"fmt"
"strconv"
)
func main() {
i, err := strconv.ParseInt("123456", 10, 8)
fmt.Println(i, err)
}
答案 1 :(得分:23)
func ParseInt(s string, base int, bitSize int) (i int64, err error)
ParseInt解释给定基数(2到36)中的字符串s并返回 相应的值i。如果base == 0,则表示基数 字符串的前缀:“0x”的基数为16,“0”的基数为8,基数为10 否则。
bitSize参数指定结果必须的整数类型 适合。位大小0,8,16,32和64对应于int,int8, int16,int32和int64。
ParseInt返回的错误具有具体类型* NumError和 包括err.Num = s。如果s为空或包含无效数字,则为err.Err = ErrSyntax;如果对应于s的值不能用给定大小的有符号整数表示,则err.Err = ErrRange。
ParseInt
始终返回int64
值。根据{{1}},此值将适合bitSize
,int
,int8
,int16
或int32
。如果值无法由int64
给出的有符号整数表示,则为bitSize
。
The Go Programming Language Specification
n位整数的值是n位宽并使用表示 二进制补码算法。
err.Err = ErrRange
还有一组预先声明的数字类型 特定于实现的大小:
int8 the set of all signed 8-bit integers (-128 to 127) int16 the set of all signed 16-bit integers (-32768 to 32767) int32 the set of all signed 32-bit integers (-2147483648 to 2147483647) int64 the set of all signed 64-bit integers (-9223372036854775808 to 9223372036854775807)
uint either 32 or 64 bits
int same size as uint
是32位或64位,具体取决于实现。通常,32位编译器为32位,64位编译器为64位。
要查找int
或int
的尺寸,请使用uint
。
strconv.IntSize
const IntSize = intSize
是IntSize
或int
值的大小。
例如,
uint
输出:
package main
import (
"fmt"
"runtime"
"strconv"
)
func main() {
fmt.Println(runtime.Compiler, runtime.GOARCH, runtime.GOOS)
fmt.Println(strconv.IntSize)
}
答案 2 :(得分:5)
strconv.ParseInt
和朋友返回64位版本以保持API干净简单。
否则,必须为每种可能的返回类型创建单独的版本。或者返回interface{}
,然后必须通过类型断言。这些都不是理想的。
int64
,因为它可以保持任何整数大小,包括支持的64位。传递给函数的位大小可确保将值正确钳位到正确的范围。因此,您只需对返回的值进行类型转换,即可将其转换为您需要的任何整数类型。
至于int
和int64
之间的差异,这取决于架构。 int
只是32位或64位整数的别名,具体取决于您要编译的体系结构。
对于挑剔的眼睛:返回的值是有符号整数。对于无符号整数,有一个单独的strconv.ParseUint
函数,它返回uint64
并遵循与上述相同的推理。
答案 3 :(得分:5)
为了您的目的,我认为strconv.Atoi()
会更方便。
关于解释int
类型的其他答案非常详尽,但我认为这里有一个指向Go语言规范的链接:http://golang.org/ref/spec#Numeric_types
答案 4 :(得分:0)
在Go lang中,每种类型都被视为单独的数据类型,不能与基本类型互换使用。例如,
type CustomInt64 int64
在上面的声明中,CustomInt64和内置的int64是两个单独的数据类型,不能互换使用。
int,int32和int64的情况相同,所有这些都是单独的数据类型,不能互换使用。其中int32是32的整数类型,int64是64位,并且通用int类型的大小取决于平台。在32位系统上,它的宽度为32位,在64位系统上,它的宽度为64位。因此,在指定通用数据类型(如int,uint和float)时,我们必须小心谨慎。这可能会在代码中的某处引起问题,并使其他平台上的应用程序崩溃。