uint和int的区别_int32和uint32

uint和int的区别_int32和uint32本次测试的环境是Mac系统下,CPU64位。注意:go语言中的int的大小是和操作系统位数相关的;如果是32位操作系统,int类型的大小就是4字节;如果是64位操作系统,int类型的大小就是8个字节1、测试不同int类型占用字节数大小1.1、测试有符号int类型import( “testing” “unsafe” “math” “fmt”)funcTestIntSize(t*testing.T){ fmt.Println(“不同int类型占用的字节数大小:”)

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

================================
go grpc-go 相关技术专栏 总入口

go语言基础知识总结、整理、收藏

================================

本次测试的环境是Mac系统下,CPU 64位。

注意:
go语言中的int的大小是和操作系统位数相关的;

  • 如果是32位操作系统,int类型的大小就是4字节;
  • 如果是64位操作系统,int类型的大小就是8个字节

1、测试不同int类型占用字节数大小

1.1、测试有符号int类型

import (
	"testing"
	"unsafe"
	"math"
	"fmt"
)

func TestIntSize(t *testing.T) { 
   
	fmt.Println("不同int类型占用的字节数大小:")
	var i1 int = 1
	var i2 int8 = 2
	var i3 int16 = 3
	var i4 int32 = 4
	var i5 int64 = 5
	fmt.Printf("int : %v\n", unsafe.Sizeof(i1))
	fmt.Printf("int8 : %v\n", unsafe.Sizeof(i2))
	fmt.Printf("int16 : %v\n", unsafe.Sizeof(i3))
	fmt.Printf("int32 : %v\n", unsafe.Sizeof(i4))
	fmt.Printf("int64 : %v\n", unsafe.Sizeof(i5))
}

测试结果:

int    : 8
int8   : 1
int16  : 2
int32  : 4
int64  : 8

1.2、测试无符号int类型

func TestUIntSize(t *testing.T) { 
   
	fmt.Println("不同无符号int类型占用的字节数大小:")
	var i1 uint = 1
	var i2 uint8 = 2
	var i3 uint16 = 3
	var i4 uint32 = 4
	var i5 uint64 = 5
	fmt.Printf("uint : %v\n", unsafe.Sizeof(i1))
	fmt.Printf("uint8 : %v\n", unsafe.Sizeof(i2))
	fmt.Printf("uint16 : %v\n", unsafe.Sizeof(i3))
	fmt.Printf("uint32 : %v\n", unsafe.Sizeof(i4))
	fmt.Printf("uint64 : %v\n", unsafe.Sizeof(i5))
}

测试结果:

uint    : 8
uint8   : 1
uint16  : 2
uint32  : 4
uint64  : 8

2、测试不同int类型的取值范围

2.1、测试有符号int情况

func TestIntRange(t *testing.T) { 
   
	// 不同int类型的取值范围
	fmt.Println("不同int类型的取值范围:")
	//fmt.Println("int:", math.MinInt, "~", math.MaxInt) 报错,没有 math.MinInt math.MaxInt
	fmt.Println("int8:", math.MinInt8, "~", math.MaxInt8)
	fmt.Println("int16:", math.MinInt16, "~", math.MaxInt16)
	fmt.Println("int32:", math.MinInt32, "~", math.MaxInt32)
	fmt.Println("int64:", math.MinInt64, "~", math.MaxInt64)
	fmt.Println()
}

测试结果:

不同int类型的取值范围:
int8: -128 ~ 127
int16: -32768 ~ 32767
int32: -2147483648 ~ 2147483647
int64: -9223372036854775808 ~ 9223372036854775807

2.2、 测试无符号不同int类型的取值范围

func TestUintRange(t *testing.T) { 
   
	fmt.Println("uint8:", 0, "~", math.MaxUint8)
	fmt.Println("uint16:", 0, "~", math.MaxUint16)
	fmt.Println("uint32:", 0, "~", math.MaxUint32)
	//fmt.Println("uint64:", 0, "~", math.MaxUint64)
	fmt.Println()
}

测试结果

=== RUN   TestUintRange
uint8: 0 ~ 255
uint16: 0 ~ 65535
uint32: 0 ~ 4294967295

--- PASS: TestUintRange (0.00s)
PASS
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/170552.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • MATLAB(2)–MATLAB矩阵的表示

    MATLAB(2)–MATLAB矩阵的表示MATLAB–MATLAB矩阵的表示矩阵的建立冒号表达式linspace结构矩阵单元矩阵最后矩阵的建立利用直接输入法建立矩阵:将矩阵的元素用中括号括起来,按矩阵的顺序输入各元素,同一行的各元素之间用逗号或者空格分隔,不同的元素之间用分号分隔。利用已建好的矩阵建立更大的矩阵:一个大矩阵可以由已经建立好的小矩阵拼接而成。可以用实部矩阵和虚部矩阵构成复数矩阵。冒号表达式冒号是一个重要的运算符,利用它可以产生行向量。冒号表达式的一般格式为:e1:e2:e3其中,e1为初始值,e2为步长,e3为终

  • RestFul风格详解

    RestFul风格详解文章目录一、前言二、什么是RestFul风格三、传统风格与RestFul风格对比1.传统方式操作资源2.RestFul方式操作资源四、RestFul代码演示1.代码展示2.拓展情景五、使用method属性指定请求类型六、总结一、前言该技术博客总结与狂神说SpringMVC课程二、什么是RestFul风格Restful就是一个资源定位、资源操作的风格。不是标准也不是协议,只是一种风格。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。资源:互联网所有的事物都可以被抽象为资源资源

  • 功率放大器和匹配网络学习

    功率放大器PA学习导通角:在一个周期内,由电力电子器件(如晶闸管)控制其导通的角度。交流电一般为正弦波,正半周占180°,负半周占180°。当交流电通过可控硅时,可以让交流电电流通过控制使其在0-180度的任一角度处开始导通,即所谓可控整流,当正半周加到可控硅的阳极,在180度的某一角度时,在可控硅的控制极加一触发脉冲,例如在30度加一脉冲,可控硅只能通过余下的150度的电流。这种使可控硅导电…

  • 程序心形曲线绘制_java输出心形图案

    程序心形曲线绘制_java输出心形图案代码如下:importjava.awt.Color;importjava.awt.Graphics;importjava.awt.Image;importjava.awt.Toolkit;importjavax.swing.JFrame;@SuppressWarnings(“serial”)publicclassDemoextendsJFrameimplementsRunna…

    2022年10月16日
  • 权重衰减(weight decay)与学习率衰减(learning rate decay)

    权重衰减(weight decay)与学习率衰减(learning rate decay)“微信公众号”1.权重衰减(weightdecay)L2正则化的目的就是为了让权重衰减到更小的值,在一定程度上减少模型过拟合的问题,所以权重衰减也叫L2正则化。1.1L2正则化与权重衰减系数L2正则化就是在代价函数后面再加上一个正则化项:其中C0代表原始的代价函数,后面那一项就是L2正则化项,它是这样来的:所有参数w的平方的和,除以训练集的样本大小n。λ就是正则项系数,权衡正则项与C0项的比…

  • bytebuffer是什么_byte与bit

    bytebuffer是什么_byte与bit一.ByteBuffer   ByteBuffer是JDKNIO中提供的Java.nio.Buffer,在内存中预留指定大小的存储空间来存放临时数据,其他Buffer的子类有:CharBuffer、DoubleBuffer、FloatBuffer、IntBuffer、LongBuffer和ShortBuffer 1.Buffer   ByteBuffer继承…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号