zoukankan      html  css  js  c++  java
  • Golang的基础数据类型-整型

             Golang的基础数据类型-整型

                                作者:尹正杰

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

     

     

     

    一.整型概述

      Go语言的整数类型一共有10个。
        int:
          默认是有符号(signed)整形,占用空间大小取决于操作系统设定数据的值,初始值为0。
        uint:
          无符号整形,前面的字符u表示无符号("unsigned"),即二进制最高位的符号位不在表示正负数了。下面只要前面加u的都是这个意思,我就不一一赘述啦。
          占用空间大小取决于操作系统设定数据的值,初始值为0。
        int8:
          占用一个字节大小,取值范围为-128~127,初始值为0。
        uint8:
          占用一个字节大小,取值范围为0~255,初始值为0。
        int16:
          占用两个字节,取值范围为-32768~32767,初始值为0。
        uint16:
          占用两个字节,取值范围为0~65535,初始化值为0。
        int32:
          占用四个字节,取值范围为-2147483648 ~ 2147483647,初始值为0。
        uint32:
          占用四个字节,取值范围为0 ~ 4294967295(42亿),初始化为0。
        int64:
          占用八个字节,取值范围为-9223372036854775808 ~9223372036854775807,初始化为0。
        uint64:
          占用八个字节,取值范围为0 ~ 18446744073709551615(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 := -128 //表示int8的最小值
        b := 255  //表示uint8的最小值
        fmt.Printf("a的类型为:[%T],a的值为:[%d]
    ", a, a)
        fmt.Printf("b的类型为:[%T],b的值为:[%d]
    ", b, b)
    
        c := -32768 //表示int16的最小值
        d := 65535  //表示uint16的最大值
        fmt.Printf("c的类型为:[%T],c的值为:[%d]
    ", c, c)
        fmt.Printf("d的类型为:[%T],d的值为:[%d]
    ", d, d)
    
        e := -2147483648 //表示int32的最小值
        f := 4294967295  //表示uint32的最大值
        fmt.Printf("e的类型为:[%T],e的值为:[%d]
    ", e, e)
        fmt.Printf("f的类型为:[%T],f的值为:[%d]
    ", f, f)
    
        g := -9223372036854775808 //表示int64的最小值
        /*
            温馨提示:
                下面这条注释语句会编译报错的,由于默认使用自动推导类型创建整数型均为int类型,因此无法表示uint64类型的最大值
        */
        //h := 18446744073709551615
        var h uint = 18446744073709551615 //我们想要使用uint64最大值需要声明数据类型为uint
        fmt.Printf("g的类型为:[%T],g的值为:[%d]
    ", g, g)
        fmt.Printf("h的类型为:[%T],h的值为:[%d]
    ", h, h)
    }

    2>.int8/uint8使用案例

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

    3>.int16/uint16使用案例

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

    4>.int32/uint32使用案例

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

    5>.int64/uint64使用案例

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

  • 相关阅读:
    利用javabean完成注册效果
    DAO设计模式例子
    SmartUpload使用和简介
    js和jquery通过this获取html标签中的属性值
    细说引用类型string StringBuilder class的特点
    WinForm控件自动提示你定义相似的项值
    利用Assembly动态加载程序集
    C# 数据结构与算法系列(五) 队列
    ASP.NET最简单的用户权限管理
    C# 数据结构与算法系列(三) 线性表之链表
  • 原文地址:https://www.cnblogs.com/yinzhengjie2020/p/12246804.html
Copyright © 2011-2022 走看看