热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

govar一个整数_Go语言数据类型

Go语言是一种静态类型的编程语言,在Go编程语言中,数据类型用于声明函数和变量。数据类型的出现是为了把数据分成所需内存大小不同的数据,编程

Go 语言是一种静态类型的编程语言,在 Go 编程语言中,数据类型用于声明函数和变量。数据类型的出现是为了把数据分成所需内存大小不同的数据,编程的时候需要用大数据的时候才需要申请大内存,就可以充分利用内存。编译器在进行编译的时候,就要知道每个值的类型,这样编译器就知道要为这个值分配多少内存,并且知道这段分配的内存表示什么。

基本数据类型说明类型描述uint32位或64位

uint8无符号 8 位整型 (0 到 255)

uint16无符号 16 位整型 (0 到 65535)

uint32无符号 32 位整型 (0 到 4294967295)

uint64无符号 64 位整型 (0 到 18446744073709551615)

int32位或64位

int8有符号 8 位整型 (-128 到 127)

int16有符号 16 位整型 (-32768 到 32767)

int32有符号 32 位整型 (-2147483648 到 2147483647)

int64有符号 64 位整型 (-9223372036854775808 到 9223372036854775807)

byteuint8的别名(type byte = uint8)

runeint32的别名(type rune = int32),表示一个unicode码

uintptr无符号整型,用于存放一个指针是一种无符号的整数类型,没有指定具体的bit大小但是足以容纳指针。

uintptr类型只有在底层编程是才需要,特别是Go语言和C语言函数库或操作系统接口相交互的地方。

float32IEEE-754 32位浮点型数

float64IEEE-754 64位浮点型数

complex6432 位实数和虚数

complex12864 位实数和虚数

整型

整型数据分为两类,有符号和无符号两种类型

有符号: int, int8, int16, int32, int64

无符号: uint, uint8, uint16, uint32, uint64, byte

不同位数的整型区别在于能保存整型数字范围的大小;

有符号类型可以存储任何整数,无符号类型只能存储自然数

int和uint的大小和系统有关,32位系统表示int32和uint32,如果是64位系统则表示int64和uint64

byte与uint8类似,一般用来存储单个字符

在保证程序正确运行下,尽量使用占用空间小的数据类型

fmt.Printf("%T", var_name)输出变量类型

unsafe.Sizeof(var_name)查看变量占用字节

浮点型

浮点型也就是小数类型,可以存放小数。比如6.6,-12.34关于浮点数在机器中存放形式的简单说明,浮点数=符号位+指数位+尾数位

尾数部分可能丢失,造成精度损失。-123.0000901package main

import "fmt"

func main() {

var num1 float32 = -123.0000901

var num2 float64 = -123.0000901

fmt.Println("num1 = ", num1, "num2 = ", num2);

}

说明:float64的精度要比float32的要准确

说明:如果我们要保存一个精度高的数,则应该选择float64

浮点型的存储分为三部分:符号位+指数位+尾数位,在存储过程中,精度会有丢失

golang的浮点型默认为float64类型

通常情况下,应该使用float64,因为它比float32更精确

0.123可以简写成.123,也支持科学计数法表示:5.1234e2 等价于512.34

字符

Golang中没有专门的字符类型,如果要存储单个字符(字母),一般使用byte来保存。

字符串就是一串固定长度的字符连接起来的字符序列。Go的字符串是由单个字节连接起来的,也就是说对于传统的字符串是由字符组成的,而Go的字符串不同,它是由字节组成的。字符只能被单引号包裹,不能用双引号,双引号包裹的是字符串

当我们直接输出type值时,就是输出了对应字符的ASCII码值

当我们希望输出对应字符,需要使用格式化输出

Go语言的字符使用UTF-8编码,英文字母占一个字符,汉字占三个字符

在Go中,字符的本质是一个整数,直接输出时,是该字符对应的UTF-8编码的码值。

可以直接给某个变量赋一个数字,然后按格式化输出时%c,会输出该数字对应的unicode字符

字符类型是可以运算的,相当于一个整数,因为它们都有对应的unicode码package main

import "fmt"

func main() {

//字符只能被单引号包裹,不能用双引号,双引号包裹的是字符串

var c1 byte = 'a'

var c2 byte = '0'

//当我们直接输出type值时,就是输出了对应字符的ASCII码值

//'a' ==> 97

fmt.Println(c1, "--", c2)

//如果我们希望输出对应字符,需要使用格式化输出

fmt.Printf("c2 = %c c2 = %c", c1, c2)

}

但是如果我们保存的字符大于255,比如存储汉字,这时byte类型就无法保存,此时可以使用uint或int类型保存

字符类型本质探讨字符型存储到计算机中,需要将字符对应的码值(整数)找出来

存储:字符 --> 码值 --> 二进制 --> 存储

读取: 二进制 -->码值 --> 字符 --> 读取

字符和码值的对应关系是通过字符编码表决定的(是规定好的)

Go语言的编码都统一成了UTF-8。非常的方便,很统一,再也没有编码乱码的困扰了

布尔型

布尔类型也叫做bool类型,bool类型数据只允许取值true或false

bool类型占1个字节

bool类型适用于逻辑运算,一般用于流程控制

字符串

字符串就是一串固定长度的字符连接起来的字符序列。Go的字符串是由单个字节连接起来的。Go语言的字符串的字节使用UTF-8编码标识Unicode文本字符串一旦赋值了,就不能修改了:在Go中字符串是不可变的。

字符串的两种标识形式双引号,会识别转义字符var str = "abc\nabc" //输出时会换行

反引号,以字符串的原生形式输出,包括换行和特殊字符,可以实现防止攻击、输出源代码等效果var str string = `abc\nabc` //输出时原样输出,不会转义

字符串拼接方式"+"var str string = "hello " + "world"

str += "!"

当一行字符串太长时,需要使用到多行字符串,可以使用如下处理//正确写法

str := "hello" +

" world!"

fmt.Println(str)

//错误写法

str := "hello "

+ "world!"

fmt.Println(str)

指针基本数据类型,变量存的就是值,也叫值类型

获取变量的地址,用&,比如var num int,获取num的地址:&num

指针类型,指针变量存的是一个地址,这个地址指向的空间存的才是值,比如:var ptr *int = &num

获取指针类型所指向的值,使用:*,比如,var ptr *int,使用*ptr获取ptr指向的值

指针细节说明:值类型,都有对应的指针类型,形式为*数据类型,比如int对应的指针就是*int,float64对应的指针类型就是*float64,依此类推。

值类型包括:基本数据类型、数组和结构体struct

值类型与引用类型

值类型和引用类型使用特点:

值类型:变量直接存储值,内存通常在栈中分配

引用类型:变量存储的是一个地址,这个地址对应的空间才真正存储数据(值),内存通常在堆上分配,当没有任何变量应用这个地址时,该地址对应的数据空间就成为一个垃圾,由GC来回收。

Golang中值类型和引用类型的区分值类型:基本数据类型(int系列、float系列、bool、string)、数组和结构体

引用类型:指针、slice切片、map、管道chan、interface等都是引用类型

基本数据类型默认值

在Golang中,数据类型都有一个默认值,当程序员没有赋值时,就会保留默认值,在Golang中,默认值也叫做零值。

基本数据类型默认值如下:数据类型默认值整型0

浮点型0

字符串""

布尔类型falsepackage main

import "fmt"

func main() {

var a int

var b float32

var isTrue bool

var str string

//这里的%v,表示按照变量的值输出

fmt.Printf("a = %v, b = %v, isTrue = %v, str = %v", a, b, isTrue, str)

fmt.Println("")

}

基本数据类型相互转换

Golang和Java/C不同,Golang在不同类型的变量之间赋值时需要显式转换。也就是Golang中数据类型不能自动转换。

基本语法:

表达式var_type(var_name) 将值v转换为类型var_type

var_type:就是数据类型,比如int32, int64, float32等等

var_name:就是需要转换的变量var num int = 42

var float float64 = float64(num)

var ui uint8 = uint8(float)

fmt.Println(num, float, ui)

注意事项Go中,数据类型的转换可以是从表示范围小-->表示范围大,也可以 范围大—>范围小

被转换的是变量存储的数据(即值),变量本身的数据类型并没有变化!

在转换中,比如将int64转成int8,编译时不会报错,只是转换的结果是按溢出处理,和我们希望的结果不一样。

数据的转换必须显式转换,不能自动转换package main

import "fmt"

func main() {

var n1 int32 = 12

var n2 int64

var n3 int8

n2 = n1 + 20 //int32 --> int64 错误

n3 = n1 + 20 //int32 --> int8 错误

n2 = int64(n1) + 20 //正确

n3 = int8(n1) + 20 //正确

}

定义一个int8类型的整数(var num int8 = 0),如果一直自加1,这个变量的值会是(0...127 -128 -127... 0 ...127)循环往复下去,而不会超过类型最大值的范围

其他基本类型转string类型

在程序开发中,我们经常需要将数值型转成string类型,或者将string类型转成数值型。

方式1:func Sprintf(format string, a ...interface{}) string

Sprintf根据format参数生成格式化的字符串并返回该字符串。package main

import "fmt"

func main() {

var num1 int = 99;

var num2 float64 = 23.456

var isTrue bool = true

var char byte = 'A'

var str string

str = fmt.Sprintf("%d", num1)

fmt.Printf("str类型为 %T str = %q\n",str, str)

str = fmt.Sprintf("%f", num2)

fmt.Printf("str类型为 %T str = %q\n",str, str)

str = fmt.Sprintf("%t", isTrue)

fmt.Printf("str类型为 %T str = %q\n",str, str)

str = fmt.Sprintf("%d", char)

fmt.Printf("str类型为 %T str = %q\n",str, str)

}

输出结果为str类型为 string str = "99"

str类型为 string str = "23.456000"

str类型为 string str = "true"

str类型为 string str = "65"

方式2:使用strconv包的函数package main

import (

"fmt"

"strconv"

)

func main() {

var num1 int = 99;

var num2 float64 = 23.456

var isTrue bool = true

var str string

str = strconv.FormatInt(int64(num1), 10)

str = strconv.Itoa(num1)

fmt.Printf("str类型为 %T str = %q\n",str, str)

str = strconv.FormatFloat(num2, 'f', 10, 64)

fmt.Printf("str类型为 %T str = %q\n",str, str)

str = strconv.FormatBool(isTrue)

fmt.Printf("str类型为 %T str = %q\n",str, str)

}

输出结果为str类型为 string str = "99"

str类型为 string str = "23.4560000000"

str类型为 string str = "true"

string类型转其他基本类型

方式1:使用strconv包的函数package main

import (

"fmt"

"strconv"

)

func main() {

var str string = "true"

var str1 string = "123456"

var str2 string = "123.456"

var isTrue bool

var num int64

var num2 float64

isTrue, _ = strconv.ParseBool(str)

fmt.Printf("str类型为 %T str = %v\n",isTrue, isTrue)

num, _ = strconv.ParseInt(str1, 10, 64)

fmt.Printf("str类型为 %T str = %v\n",num, num)

num2, _ = strconv.ParseFloat(str2, 64)

fmt.Printf("str类型为 %T str = %v\n",num2, num2)

}

数据结果为:str类型为 bool str = true

str类型为 int64 str = 123456

str类型为 float64 str = 123.456

注意:在将string类型转成其它基本数据类型时,要确保string类型能够转成有效的数据。比如,我们可以把”123“转成数字123,但是不能把”hello“转成一个整数,如果这样做,Golang直接将其转成0,其它类型也是一样的道理,float => 0, bool => false



推荐阅读
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 先看官方文档TheJavaTutorialshavebeenwrittenforJDK8.Examplesandpracticesdescribedinthispagedontta ... [详细]
  • C++字符字符串处理及字符集编码方案
    本文介绍了C++中字符字符串处理的问题,并详细解释了字符集编码方案,包括UNICODE、Windows apps采用的UTF-16编码、ASCII、SBCS和DBCS编码方案。同时说明了ANSI C标准和Windows中的字符/字符串数据类型实现。文章还提到了在编译时需要定义UNICODE宏以支持unicode编码,否则将使用windows code page编译。最后,给出了相关的头文件和数据类型定义。 ... [详细]
  • 开发笔记:Java是如何读取和写入浏览器Cookies的
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了Java是如何读取和写入浏览器Cookies的相关的知识,希望对你有一定的参考价值。首先我 ... [详细]
  • Java中包装类的设计原因以及操作方法
    本文主要介绍了Java中设计包装类的原因以及操作方法。在Java中,除了对象类型,还有八大基本类型,为了将基本类型转换成对象,Java引入了包装类。文章通过介绍包装类的定义和实现,解答了为什么需要包装类的问题,并提供了简单易用的操作方法。通过本文的学习,读者可以更好地理解和应用Java中的包装类。 ... [详细]
  • Python爬虫中使用正则表达式的方法和注意事项
    本文介绍了在Python爬虫中使用正则表达式的方法和注意事项。首先解释了爬虫的四个主要步骤,并强调了正则表达式在数据处理中的重要性。然后详细介绍了正则表达式的概念和用法,包括检索、替换和过滤文本的功能。同时提到了re模块是Python内置的用于处理正则表达式的模块,并给出了使用正则表达式时需要注意的特殊字符转义和原始字符串的用法。通过本文的学习,读者可以掌握在Python爬虫中使用正则表达式的技巧和方法。 ... [详细]
  • 纠正网上的错误:自定义一个类叫java.lang.System/String的方法
    本文纠正了网上关于自定义一个类叫java.lang.System/String的错误答案,并详细解释了为什么这种方法是错误的。作者指出,虽然双亲委托机制确实可以阻止自定义的System类被加载,但通过自定义一个特殊的类加载器,可以绕过双亲委托机制,达到自定义System类的目的。作者呼吁读者对网上的内容持怀疑态度,并带着问题来阅读文章。 ... [详细]
  • Java SE从入门到放弃(三)的逻辑运算符详解
    本文详细介绍了Java SE中的逻辑运算符,包括逻辑运算符的操作和运算结果,以及与运算符的不同之处。通过代码演示,展示了逻辑运算符的使用方法和注意事项。文章以Java SE从入门到放弃(三)为背景,对逻辑运算符进行了深入的解析。 ... [详细]
  • 本文讨论了在VMWARE5.1的虚拟服务器Windows Server 2008R2上安装oracle 10g客户端时出现的问题,并提供了解决方法。错误日志显示了异常访问违例,通过分析日志中的问题帧,找到了解决问题的线索。文章详细介绍了解决方法,帮助读者顺利安装oracle 10g客户端。 ... [详细]
  • ***byte(字节)根据长度转成kb(千字节)和mb(兆字节)**parambytes*return*publicstaticStringbytes2kb(longbytes){ ... [详细]
  • 本文整理了Java面试中常见的问题及相关概念的解析,包括HashMap中为什么重写equals还要重写hashcode、map的分类和常见情况、final关键字的用法、Synchronized和lock的区别、volatile的介绍、Syncronized锁的作用、构造函数和构造函数重载的概念、方法覆盖和方法重载的区别、反射获取和设置对象私有字段的值的方法、通过反射创建对象的方式以及内部类的详解。 ... [详细]
  • 本文介绍了在Android开发中使用软引用和弱引用的应用。如果一个对象只具有软引用,那么只有在内存不够的情况下才会被回收,可以用来实现内存敏感的高速缓存;而如果一个对象只具有弱引用,不管内存是否足够,都会被垃圾回收器回收。软引用和弱引用还可以与引用队列联合使用,当被引用的对象被回收时,会将引用加入到关联的引用队列中。软引用和弱引用的根本区别在于生命周期的长短,弱引用的对象可能随时被回收,而软引用的对象只有在内存不够时才会被回收。 ... [详细]
  • c语言基础编写,c语言 基础
    本文目录一览:1、C语言如何编写?2、如何编写 ... [详细]
  • 查找给定字符串的所有不同回文子字符串原文:https://www ... [详细]
  • 1关于字符串相邻的两个或多个字符串字面值(引号引起来的字符)将会自动连接到一起:str_catpython!str_cat输出:python!把很长 ... [详细]
author-avatar
mobiledu2502879793
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有