Golang的基础数据类型-整型

                            作者:尹正杰

版权声明:原创作品,谢绝转载!否则将追究法律责任。

一.整型概述

  Go语言的整数类型一共有10个。
    int:
      默认是有符号(signed)整形,占用空间大小取决于操作系统设定数据的值,初始值为0。
    uint:
      无符号整形,前面的字符u表示无符号("unsigned"),即二进制最高位的符号位不在表示正负数了。下面只要前面加u的都是这个意思,我就不一一赘述啦。
      占用空间大小取决于操作系统设定数据的值,初始值为0。
    int8:
      占用一个字节大小,取值范围为-~,初始值为0。
    uint8:
      占用一个字节大小,取值范围为0~,初始值为0。
    int16:
      占用两个字节,取值范围为-~,初始值为0。
    uint16:
      占用两个字节,取值范围为0~,初始化值为0。
    int32:
      占用四个字节,取值范围为- ~ ,初始值为0。
    uint32:
      占用四个字节,取值范围为0 ~ (42亿),初始化为0。
    int64:
      占用八个字节,取值范围为- ~,初始化为0。
    uint64:
      占用八个字节,取值范围为0 ~ (1844京),初始化为0。   大多数情况下,我们只需要 int 一种整型即可,它可以用于循环计数器、数组和切片的索引,以及任何通用目的的整型运算符,通常int类型的处理速度也是最快的。因为这是操纵系统根据字节的计算架构自动调整最佳的int类型。

二.整型简单应用案例

1>.int/uint使用案例

package main

import (
"fmt"
) func main() {
/*
int:
默认是有符号(signed)整形,其宽度与操作系统有关,因此占用空间大小取决于操作系统设定数据的值,初始值为0。
uint:
无符号整形,前面的字符u表示无符号("unsigned"),即二进制最高位的符号位不在表示正负数了。
其宽度与操作系统有关,因此占用空间大小取决于操作系统设定数据的值,初始值为0。 温馨提示:
(1)默认使用自动推导类型创建的整数均为int;
(2)int和uint在内存中占的大小和操作系统相关,如下所示:
1>.在32为操作系统下int相当于int32,uint相当于uint32
2>.在64位操作系统下int相当于int64,uint相当于uint64
(3)int和int64是不同的数据类型,操作时需要类型转换;
(4)如果超出整数数据类型的表示范围我们称之为数据溢出,计算机处理的机制就是高位截断,只截取低位运算,感兴趣的小伙伴可自行阅读原码,反码和补码,我在下面有推荐链接;
(5)整数的补码才是在计算机中的存储形式,举个例子:
var a int 8 = 127
a = a + 2 //0111 1111 + 0000 0010 = 1000 0001
fmt.Println(a) //我们看到a是有符号int类型,由于计算机以补码的形式存储,因此输出结果为-127, 关于原码反码补码的基础知识扫盲,博主推荐阅读:
https://www.cnblogs.com/yinzhengjie/p/8666354.html
*/
a := - //表示int8的最小值
b := //表示uint8的最小值
fmt.Printf("a的类型为:[%T],a的值为:[%d]\n", a, a)
fmt.Printf("b的类型为:[%T],b的值为:[%d]\n", b, b) c := - //表示int16的最小值
d := //表示uint16的最大值
fmt.Printf("c的类型为:[%T],c的值为:[%d]\n", c, c)
fmt.Printf("d的类型为:[%T],d的值为:[%d]\n", d, d) e := - //表示int32的最小值
f := //表示uint32的最大值
fmt.Printf("e的类型为:[%T],e的值为:[%d]\n", e, e)
fmt.Printf("f的类型为:[%T],f的值为:[%d]\n", f, f) g := - //表示int64的最小值
/*
温馨提示:
下面这条注释语句会编译报错的,由于默认使用自动推导类型创建整数型均为int类型,因此无法表示uint64类型的最大值
*/
//h := 18446744073709551615
var h uint = //我们想要使用uint64最大值需要声明数据类型为uint
fmt.Printf("g的类型为:[%T],g的值为:[%d]\n", g, g)
fmt.Printf("h的类型为:[%T],h的值为:[%d]\n", h, h)
}

2>.int8/uint8使用案例

package main

import (
"fmt"
) func main() { /*
int8:
    占用一个字节大小,取值范围为-128~127,初始值为0。
  uint8:
    占用一个字节大小,取值范围为0~255,初始值为0。
*/
var a int8 = -
var b uint8 = fmt.Printf("a的类型为:[%T],a的值为:[%d]\n", a, a)
fmt.Printf("b的类型为:[%T],b的值为:[%d]\n", b, b)
}

3>.int16/uint16使用案例

package main

import "fmt"

func main() {

    /*
int16:
    占用两个字节,取值范围为-32768~32767,初始值为0。
uint16:
    占用两个字节,取值范围为0~65535,初始化值为0。
*/
var a int16 = -
var b uint16 = fmt.Printf("a的类型为:[%T],a的值为:[%d]\n", a, a)
fmt.Printf("b的类型为:[%T],b的值为:[%d]\n", b, b)
}

4>.int32/uint32使用案例

package main

import "fmt"

func main() {

    /*
int32:
  占用四个字节,取值范围为-2147483648 ~ 2147483647,初始值为0。
uint32:
  占用四个字节,取值范围为0 ~ 4294967295(42亿),初始化为0。
*/
var a int32 = -
var b uint32 = fmt.Printf("a的类型为:[%T],a的值为:[%d]\n", a, a)
fmt.Printf("a的类型为:[%T],b的值为:[%d]\n", b, b)
}

5>.int64/uint64使用案例

package main

import "fmt"

func main() {

    /*
int64:
占用八个字节,取值范围为-9223372036854775808 ~9223372036854775807,初始化为0。
uint64:
    占用八个字节,取值范围为0 ~ 18446744073709551615(1844京),初始化为0。
*/
var a int64 = -
var b uint64 = fmt.Printf("a的类型为:[%T],a的值为:[%d]\n", a, a)
fmt.Printf("b的类型为:[%T],b的值为:[%d]\n", b, b)
}

Golang的基础数据类型-整型的更多相关文章

  1. Golang的基础数据类型-字符串型

    Golang的基础数据类型-字符串型 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.字符型概述 上一篇博客学习了使用单引号括起来的单个字符就是字符类型,在Golang中有两种表 ...

  2. Golang的基础数据类型-字符型

    Golang的基础数据类型-字符型 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.字符型概述 Go语言中的字符有两种,即uint8类型和rune类型. uint8类型: 我们也 ...

  3. Golang的基础数据类型-布尔型

    Golang的基础数据类型-布尔型 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.bool类型概述 bool类型的取值范围: bool类型的值只有两种,其值不为真即为假,可以用 ...

  4. [日常] Go语言圣经--作用域,基础数据类型,整型

    go语言圣经-作用域 1.一个声明语句将程序中的实体和一个名字关联,比如一个函数或一个变量 2.一个变量的生命周期是指程序运行时变量存在的有效时间段;声明语句的作用域对应的是一个源代码的文本区域,它是 ...

  5. GOLANG 基本数据类型 整型

    基本数据类型-整型 种类     有符号(负号)      int8 int16 int32 int64 无符号(无符号) uint8 uint16 uint32 uint64 架构特定(取决于系统位 ...

  6. Golang的基础数据类型-浮点型

    Golang的基础数据类型-浮点型 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.浮点型概述 Go语言提供两种精度的浮点数,即float32和float64,其中float32 ...

  7. GO语言学习——基本数据类型——整型、浮点型、复数、布尔值、fmt占位符

    基本数据类型 整型 整型分为以下两个大类: 按长度分为:int8.int16.int32.int64 对应的无符号整型:uint8.uint16.uint32.uint64 其中,uint8就是我们熟 ...

  8. 第一节 Python基础之数据类型(整型,布尔值,字符串)

    数据类型是每一种语言的基础,就比如说一支笔,它的墨有可能是红色,有可能是黑色,也有可能是黄色等等,这不同的颜色就会被人用在不同的场景.Python中的数据类型也是一样,比如说我们要描述一个人的年龄:小 ...

  9. python基础知识2——基本的数据类型——整型,长整型,浮点型,字符串

    磨人的小妖精们啊!终于可以归置下自己的大脑啦,在这里我要把--整型,长整型,浮点型,字符串,列表,元组,字典,集合,这几个知识点特别多的东西,统一的捯饬捯饬,不然一直脑袋里面乱乱的. 对于Python ...

随机推荐

  1. 「Luogu P5494 【模板】线段树分裂」

    (因为没有认证,所以这道题就由Froggy上传) 线段树分裂用到的地方确实并不多,luogu上以前也没有这道模板题,所以就出了一道,实在是想不出怎么出模板了,所以这道题可能可以用一些其他的算法水过去. ...

  2. Locale

    1. Locale 概述 2. Windows 区域设置 3 Linux Locale 3.1 Linux Locale 语言环境名称格式 3.2 常用区域描述(简写)日期习惯 3.3 日期显示格式 ...

  3. SICP题解

    这里用Common Lisp.Haskell等函数式语言. 1.2.请将下面表达式变换为前缀形式: $$ \frac{5 + 4 + (2 - (3 - (6 + \frac{4}{5})))}{3( ...

  4. nodejs的C++扩展中实现异步回调

    在nodejs的官方网站中有关于C++扩展的详细说明,其中包含了从"hello world"到对象封装的一系列示例.其中的“callback”节是关于回调函数的,美中不足的是,这个 ...

  5. 在PyCharm中自动添加文件头、时间日期等信息

    初次安装使用PyCharm,在新建.py文件时会发现文件头并没有什么信息,因此,使用模板会比较方便.方法如下: 1.打开PyCharm,选择File--Settings 2.依次选择Editor--- ...

  6. MySQL 之存储引擎与数据类型与数据约束

    一.存储引擎场景 1.InnoDB 用于事务处理应用程序,支持外键和行级锁.如果应用对事物的完整性有比较高的要求,在并发条件下要求数据的一致性,数据操作除了插入和查询之外,还包括很多更新和删除操作,那 ...

  7. Py西游攻关之基础数据类型(二)-列表

    Py西游攻关之基础数据类型 - Yuan先生 https://www.cnblogs.com/yuanchenqi/articles/5782764.html  五 List(列表) OK,现在我们知 ...

  8. 在idea中设置指向源代码(scala)

    1.到官网下载scala源代码 点击如下链接下载源码:http://www.scala-lang.org/download/all.html 选择需要的版本点击进行下载,我选择的是2.11.8版本,如 ...

  9. Python连载60-Tkinter布局、按钮以及属性详解

    一.Tkinter​ 1.组件的大致使用步骤 (1)创建总面板 (2)创建面板上的各种组件: i.指定组件的父组件,即依附关系:ii.利用相应的属性对组件进行设置:iii.给组件安排布局. (3)同步 ...

  10. C语言的常用的数据类型有哪些_所占字节分别是多少

    整型 整形打印使用%d short:短整型,占16位,2个字节 int:占32位,4个字节 long:长整型,占4个字节,本来意思比int更多,但是目前来看基本都是和int一样 浮点型 浮点型计算会影 ...