当前位置: 首页 > news >正文

Golang数据类型(数字型)

Go数据类型(数字型)

Go中数字型数据类型大致分为整数(integer)、浮点数(floating point )和复数(Complex)三种

整数重要概念

整数在Go和Python中有较大区别,主要体现在Go对整数的划分更细。Go中同时提供了 有符号(signed)无符号(unsigned) 的整数类型,其中有符号整数按二进制位又可以分为int8(对应8bit大小的有符号整数),int16(对应16bit大小的有符号整数),int32(对应32bit大小的有符号整数),int64(对应64bit大小的有符号整数),以及int(与CPU相关)五种类型。无符号整数按二进制位又可以分为uint8, uint16, uint32, uint64以及uint五种类型。

根据二进制大小的不同,每种有符号整数和无符号整数类型所代表的整数范围也不尽相同,如下表所示:

  • 有符号整数和无符号整数的最大的区别是前者支持负数,后者不支持。另外int这个整数类型我们在前面讲解变量时所举的例子中已经提及并使用过了,它的大小与所代表的整数范围和运行Go程序的机器的编译器和CPU相关(既可能是32bit也可能是64bit,uint同理)。实际开发中int类型的应用最为广泛,它既可用于数组和切片的索引,也可用于for循环中空值循环次数的计数器,而且一般来说int类型的处理速度也是最快的
  • 除int和uint之外,还有一个大小及所代表的整数范围和编译器及CPU相关的整数数据类型叫做uintptr,它只在Go语言和C语言之间互动的底层编程中才会用到

整数使用举例

整数支持加减乘除、取模等操作,但前提是变量的整数类型必须一致,并且数字不能超出该类型的整数范围,举例如下:
func main() {var a, b int = 7, 2fmt.Println(a + b)fmt.Println(a - b)fmt.Println(a * b)fmt.Println(a / b)
}

 

注意Go中当两个整数不能整除时,只保留商数,因此7/2返回的值为3

如果变量的整数类型不一致,则系统会返回异常,举例如下:

func main() {var a int8 = 1var b uint8 = 1fmt.Println(a + b)
}

 

 

这里变量a的数据类型为int8,而b的数据类型为uint8,两者无法做任何运算。

如果数字超出了数据类型对应的整数范围,则系统也会返回异常,举例如下:

func main() {var a int8 = 256fmt.Println(a)
}

 

这里变量a的值256超出了int8对应的支持范围(-128到127)。

如果使用简短格式声明整数变量,则该整数变量的类型为int,大小视CPU的类型为32bits或者64bits。举例如下:

func main() {a := 10fmt.Printf("%T\n", a)
}

 

另外也可以使用整数类型相关的函数将一个类型的整数转换成另一个类型的整数,如下所示:

func main() {a := 10        //此时a为int类型的整数b := uint32(a) //将a转换为uint32类型的整数c := int8(a)   //将a转换为int8类型的整数fmt.Println(b, c)fmt.Printf("%T\n", a)fmt.Printf("%T\n", b)fmt.Printf("%T\n", c)
}

输出:

 

浮点数

浮点数用来表示带有小数点的数字,比如1.0,-45.332。在Go中浮点数分为float32和float64两种类型,两种类型代表了两种精度

float32 vs float64

float32类型的浮点数和float64类型的浮点数两者区别在于前者为单精度浮点数,可以提供约6个十进制数的精度,在内存中占用32个bits,而后者为双精度浮点数,可以提供约15个十进制数的精度,在内存中占用64个bits
func main() {var f1 float32 = 16777216fmt.Println(f1 == f1+1)var f2 float64 = 16777216fmt.Println(f2 == f2+1)
}
输出:

 

这里我们用float32和float64分别创建了两个变量f1和f2,它们的值都为16777216(整数同样可以赋值给浮点数类型的变量),但是如果给它们各自加上1后再用==做判断,可以看到类型为float32的变量f1 == f1+1返回了布尔值true,类型为float64的变量f2 == f2+1返回了布尔值false。其原因是因为在IEEE 754标准中,32位的浮点数其构成为:

Value = (sign ? -1 : +1) * 2^exponent * (1.0 + mantissa)

  • Value即为浮点数的值
  • 1个bit用于符号位 (sign bit),符号位用来判断判断正数或负数(+1表示正数,-1表示负数)
  • 8个bit用于指数(exponent,带有-127的偏移)
  • 23个bit用于尾数 (mantissa)

可以看到16777216对应的是224,如果用float32来表示的话:

  • 符号位(sign bit) = +1 (表示正数)
  • 指数 = 24 (保存在内存中的二进制为10010111,这个10010111是从24 + 127(指数偏移) = 151=10010111得来的)
  • 尾数 = .0(即小数点后的小数为0)

因此Value = (+1) x 224 x (1.0 + .0) = 16777216

再来看16777217,也就是224+1:

  • 符号位和指数不变
  • 尾数必须为2-24因为只有这样Value才会= (+1) x 224 x (1.0 + 2-24) = 16777217
  • 但是因为尾数位只有23bit,因此用float32是无法表示16777217的。在float32中,16777217会以16777216表示,不会以16777218表示,这涉及到向最近的值舍入(round to nearest)的知识点,该知识点不在本书的讨论范围内。

由此可以看出float32能精确表示的正整数并不是很大,所以通常我们用float64来声明浮点数变量。不过使用float64也就意味着程序会占用更大的内存,在深度学习这种需要大使用数据集的领域,占用内存的多少会对系统运行效率有较为明显的影响。

整数和字符串互相转换

整数转换为字符串

整数转换为字符串大致有三种方法:

  1. 使用string()
  2. 使用strconv.ItoA()
  3. 使用strconv.Format()
第一种使用string()的方法和后面两种使用strconv包的方法有本质上的区别。对整数使用string()函数的话,其返回的值不是字符串形式的整数,而是该整数对应的字符rune,举例如下:
func main() {num := 100fmt.Println(string(num))
}
输出:

 

可以看到对整数100使用string()并未将其转化为字符串形式的整数"100",而是该整数对应的字符"d"。

然后编辑器里面已经明显的提示我需要使用哪个函数去实现转换了

如果你的目的是将一个整数转换为该整数的字符串形式,则需要使用strconv.ItoA()或者strconv.Format(),举例如下:

func main() {num := 100fmt.Println(strconv.Itoa(num))fmt.Println(strconv.FormatInt(int64(num), 10))
}

输出:

 

其中strconv.Itoa()函数里的Itoa是Integer to ASCII的缩写,

strconv包下的Itoa()是最简易也最常用的将整数转换为字符串的函数,推荐使用

而与strconv.Itoa()相对应的则是strconv.Atoi(),即ASCII to Integer,表示将字符串转换为整数

strconv.FormatInt()函数比较严格,要使用的话必须传入两个参数

第一个参数必须为int64的有符号整数,因为我们创建的变量的数据类型为int,不是int64,因此需要用int64(num)将其转化为int64才能作为合法的参数传入。

第二个参数为进制,这里的10表示十进制,如果想用十六进制表达的话,则将10改为16即可

字符串转换为整数:

字符串转换为整数大致两种方法,除了前面提到的strconv.Atoi()外,也可以用strconv.ParseInt()来完成。

先举例讲讲strconv.Atoi()

func main() {str := "100"fmt.Println(strconv.Atoi(str))
}

输出:

这里可以看到,对字符串变量str使用strconv.Atoi()后,返回的值为100 <nil>,为什么会有两个值?这是因为strconv.Atoi()函数本身默认会返回两个值,第一个值的数据类型为整数,第二个值的数据类型为error,我在讲字符串一章中提到了错误类型在Go中也属于一种数据类型,如果调用该函数时存在错误的话,比如被strconv.Atoi()转换的数据为非字符串,那么strconv.Atoi()会返回具体的错误类型,如果函数运行后不存在错误的话,则返回nil。在Go中类似strconv.Atoi()这种同时返回两种值(一种为函数本身因返回的值,另一种为错误类型的值)的函数还有很多

再看一下strconv.Atoi()的语法:

再来看strconv.ParseInt()的使用:

func main() {str := "100"fmt.Println(strconv.ParseInt(str, 10, 64))
}

输出:

可以看到,strconv.ParseInt()需要传入三个参数,

一个参数为要被转换为整数的字符串

第二个参数为进制,这里的10代表十进制,

第三个参数代表的是bitSize, 其作用是用来指定我们想将字符串转换为哪类的有符号整数类型,其取值范围为0,8,16,32,64,分别表示int, int8, int16,int32和int64。

Strconv.FormatInt()和strconv.ParseInt()功能比较强大,但是使用起来稍微有些繁琐,明显strconv.Itoa()和strconv.Atoi()更易用。实际上strconv.Itoa()和strconv.Atoi()其实分别调用了strconv.Format()和strconv.ParseInt(),是后两者的简化版

 

另外Format和Parse其实是两组相反的方法,除了strconv.FormatInt()和strconv.ParseInt()外还有如下很多种类似的函数:

Format组:

FormatBool()

FormatFloat()

FormatInt()

FormatUint()

Parse组:

ParseBool()

ParseFloat()

ParseInt()

ParseUint()

总体来说,Format组是将其他数据类型转变成字符串,而Parse组是将字符串转为其他数据类型

  转载至: 网络工程师的Golang之路 -- Go数据类型(数字型) - 知乎 (zhihu.com)

相关文章:

Golang数据类型(数字型)

Go数据类型&#xff08;数字型&#xff09; Go中数字型数据类型大致分为整数&#xff08;integer&#xff09;、浮点数&#xff08;floating point &#xff09;和复数&#xff08;Complex&#xff09;三种 整数重要概念 整数在Go和Python中有较大区别&#xff0c;主要体现在…...

【JVM系列】- 穿插·对象的实例化与直接内存

对象的实例化与直接内存 &#x1f604;生命不息&#xff0c;写作不止 &#x1f525; 继续踏上学习之路&#xff0c;学之分享笔记 &#x1f44a; 总有一天我也能像各位大佬一样 &#x1f31d;分享学习心得&#xff0c;欢迎指正&#xff0c;大家一起学习成长&#xff01; 文章目录…...

【C++干货铺】继承 | 多继承 | 虚继承

个人主页点击直达&#xff1a;小白不是程序媛 C系列专栏&#xff1a;C干货铺 代码仓库&#xff1a;Gitee 目录 继承的概念及定义 继承的概念 继承的定义 继承基类成员访问方式的变化 基类和派生类的赋值转化 继承中的作用域 派生类的默认成员函数 构造函数 拷贝构造…...

【ARM CoreLink 系列 8.1 -- SMMU 详细介绍-STE Entry 详细介绍 1】

请阅读【ARM CoreLink 文章专栏导读】 上篇文章:【ARM CoreLink 系列 8 – SMMU 详细介绍-上半部】 文章目录 ARM SMMU STE ENTRY1.1 STE ENTRYWORD[0]1.1.1 S1ContexPtr1.1.2 S1Fmt1.1.3 Config1.1.4 V(Valid)1.2 STE ENTRY WORD[1]1.2.1 S1CDMax1.2.2 S1ContextPtr1.3 STE E…...

高防CDN与WAF防火墙的协同防护:构筑网络安全堡垒

随着互联网的不断发展&#xff0c;网络安全威胁也日益增多&#xff0c;而网站作为企业在数字领域的门户&#xff0c;面临的风险更加复杂多样。在构筑网络安全堡垒的过程中&#xff0c;高防CDN&#xff08;Content Delivery Network&#xff09;与WAF&#xff08;Web Applicatio…...

golang strings包的基本操作

文章目录 golang 的字符串函数EqualFoldHasPrefixHasSuffixContainsContainsRuneContainsAnyCountIndexIndexByteIndexRuneIndexAnyIndexFuncLastIndexLastIndexAnyLastIndexFuncTitleToLowerToLowerSpecialToUpperToUpperSpecialToTitleToTitleSpecialRepeatReplaceMapTrimTri…...

高效解决在本地打开可视化服务器端的tensorboard

文章目录 问题解决方案 问题 由于连着远程服务器构建模型&#xff0c;但是想在本地可视化却做不到&#xff0c;不要想当然天真的以为CTRLC点击链接http://localhost:6006就真能在本地打开tensorboard。你电脑都没连接服务器&#xff0c;只是pycharm连上了而已 解决方案 你需要…...

Spring Boot Actuator 2.2.5 基本使用

1. pom文件 &#xff0c;添加 Actuator 依赖 <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency> 2.application.properties 文件中添加以下配置 …...

字符串相似度匹配算法_莱茵斯坦距离算法

package day0330;public class LevenshteinDistanceUtil {public static void main(String[] args) {String a "WN64 F98";String b "WN64 F98 ";System.out.println("相似度:" getSimilarityRatio(a, b));}/*** 获取两字符串的相似度* * par…...

【EI会议征稿】第九届电气、电子和计算机工程研究国际学术研讨会 (ISAEECE 2024)

第九届电气、电子和计算机工程研究国际学术研讨会 (ISAEECE 2024) 2024 9th International Symposium on Advances in Electrical, Electronics and Computer Engineering 第九届电气、电子和计算机工程研究国际学术研讨会(ISAEECE 2024&#xff09;将于2024年3月1-5日在南…...

Maven Helper插件——实现一键Maven依赖冲突问题

总结/朱季谦 业余在一个SpringBoot项目集成Swagger2时&#xff0c;启动过程一直出现以下报错信息—— An attempt was made to call a method that does not exist. The attempt was made from the following location: ​ springfox.documentation.schema.DefaultModelDepe…...

理解位运算的规则

关卡名 理解位运算的规则 我会了✔️ 内容 1.理解位运算的基本规则 ✔️ 2.理解移位的原理以及与乘除的关系 ✔️ 3.掌握位运算的常用技巧 ✔️ 在学习位操作之前&#xff0c;我们先明确数据在计算机中怎么表示的。我们明确原码、反码和补码的概念和表示方法&#xff0c;之…...

Android Bitmap 使用Vukan、RenderEffect、GLSL实现模糊

文章目录 Android Bitmap 使用Vukan、RenderEffect、GLSL实现模糊使用 RenderEffect 模糊使用 Vukan 模糊使用 GLSL 模糊RS、Vukan、RenderEffect、GLSL 效率对比 Android Bitmap 使用Vukan、RenderEffect、GLSL实现模糊 本文首发地址 https://blog.csdn.net/CSqingchen/articl…...

Vue H5页面长按保存为图片

安装依赖&#xff1a;npm install html2canvas -d <template><div class"index"><div id"captureId" class"capture" v-show"firstFlag"><ul><li>1</li><li>2</li><li>3<…...

【Web】UUCTF 2022 新生赛 个人复现

目录 ①websign ②ez_rce ③ez_upload ④ez_unser ⑤ezsql ⑥ezpop ⑦funmd5 ⑧phonecode ⑨ezrce ①websign 右键打不开&#xff0c;直接抓包发包看源码 ②ez_rce “反引号” 在PHP中会被当作SHELL命令执行 ?codeprintf(l\s /); ?codeprintf(ta\c /ffffffffffl…...

设置python下载包代理

使用场景 正常网络情况下我们安装如果比较多的python包时&#xff0c;会选择使用pip install -r requirements.txt -i https://pypi.douban.com/simple --trusted-hostpypi.douban.com这种国内的镜像来加快下载速度。 但是&#xff0c;当这台被限制上网时&#xff08;公司安全…...

nginx 配置前端项目添加https

可申请阿里云免费证书 步骤省略… nginx 配置 server {listen 8050; #默认80端口 如果需要所有访问地址都是https 需要注释listen 8443 ssl; #https 访问的端口 &#xff0c;默认443server_name 192.168.128.XX; #域名 或 ip# 增加ssl#填写证书文件…...

人群计数CSRNet的pytorch实现

本文中对CSRNet: Dilated Convolutional Neural Networks for Understanding the Highly Congested Scenes&#xff08;CVPR 2018&#xff09;中的模型进行pytorch实现 import torch;import torch.nn as nn from torchvision.models import vgg16 vggvgg16(pretrained1)import…...

【HTTP协议】简述HTTP协议的概念和特点

&#x1f38a;专栏【网络编程】 &#x1f354;喜欢的诗句&#xff1a;更喜岷山千里雪 三军过后尽开颜。 &#x1f386;音乐分享【如愿】 &#x1f970;欢迎并且感谢大家指出小吉的问题 文章目录 &#x1f33a;概念&#x1f33a;特点&#x1f384;请求协议&#x1f384;响应协议…...

经典神经网络——AlexNet模型论文详解及代码复现

一、背景 AlexNet是在2012年由Alex Krizhevsky等人提出的&#xff0c;该网络在2012年的ImageNet大赛上夺得了冠军&#xff0c;并且错误率比第二名高了很多。Alexnet共有8层结构&#xff0c;前5层为卷积层&#xff0c;后三层为全连接层。 论文地址&#xff1a;ImageNet Classif…...

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…...

变量 varablie 声明- Rust 变量 let mut 声明与 C/C++ 变量声明对比分析

一、变量声明设计&#xff1a;let 与 mut 的哲学解析 Rust 采用 let 声明变量并通过 mut 显式标记可变性&#xff0c;这种设计体现了语言的核心哲学。以下是深度解析&#xff1a; 1.1 设计理念剖析 安全优先原则&#xff1a;默认不可变强制开发者明确声明意图 let x 5; …...

日语AI面试高效通关秘籍:专业解读与青柚面试智能助攻

在如今就业市场竞争日益激烈的背景下&#xff0c;越来越多的求职者将目光投向了日本及中日双语岗位。但是&#xff0c;一场日语面试往往让许多人感到步履维艰。你是否也曾因为面试官抛出的“刁钻问题”而心生畏惧&#xff1f;面对生疏的日语交流环境&#xff0c;即便提前恶补了…...

shell脚本--常见案例

1、自动备份文件或目录 2、批量重命名文件 3、查找并删除指定名称的文件&#xff1a; 4、批量删除文件 5、查找并替换文件内容 6、批量创建文件 7、创建文件夹并移动文件 8、在文件夹中查找文件...

在Ubuntu中设置开机自动运行(sudo)指令的指南

在Ubuntu系统中&#xff0c;有时需要在系统启动时自动执行某些命令&#xff0c;特别是需要 sudo权限的指令。为了实现这一功能&#xff0c;可以使用多种方法&#xff0c;包括编写Systemd服务、配置 rc.local文件或使用 cron任务计划。本文将详细介绍这些方法&#xff0c;并提供…...

新能源汽车智慧充电桩管理方案:新能源充电桩散热问题及消防安全监管方案

随着新能源汽车的快速普及&#xff0c;充电桩作为核心配套设施&#xff0c;其安全性与可靠性备受关注。然而&#xff0c;在高温、高负荷运行环境下&#xff0c;充电桩的散热问题与消防安全隐患日益凸显&#xff0c;成为制约行业发展的关键瓶颈。 如何通过智慧化管理手段优化散…...

mysql已经安装,但是通过rpm -q 没有找mysql相关的已安装包

文章目录 现象&#xff1a;mysql已经安装&#xff0c;但是通过rpm -q 没有找mysql相关的已安装包遇到 rpm 命令找不到已经安装的 MySQL 包时&#xff0c;可能是因为以下几个原因&#xff1a;1.MySQL 不是通过 RPM 包安装的2.RPM 数据库损坏3.使用了不同的包名或路径4.使用其他包…...

html-<abbr> 缩写或首字母缩略词

定义与作用 <abbr> 标签用于表示缩写或首字母缩略词&#xff0c;它可以帮助用户更好地理解缩写的含义&#xff0c;尤其是对于那些不熟悉该缩写的用户。 title 属性的内容提供了缩写的详细说明。当用户将鼠标悬停在缩写上时&#xff0c;会显示一个提示框。 示例&#x…...

深入理解Optional:处理空指针异常

1. 使用Optional处理可能为空的集合 在Java开发中&#xff0c;集合判空是一个常见但容易出错的场景。传统方式虽然可行&#xff0c;但存在一些潜在问题&#xff1a; // 传统判空方式 if (!CollectionUtils.isEmpty(userInfoList)) {for (UserInfo userInfo : userInfoList) {…...

在 Spring Boot 项目里,MYSQL中json类型字段使用

前言&#xff1a; 因为程序特殊需求导致&#xff0c;需要mysql数据库存储json类型数据&#xff0c;因此记录一下使用流程 1.java实体中新增字段 private List<User> users 2.增加mybatis-plus注解 TableField(typeHandler FastjsonTypeHandler.class) private Lis…...