Golang的基础数据类型-浮点型
Golang的基础数据类型-浮点型
作者:尹正杰
版权声明:原创作品,谢绝转载!否则将追究法律责任。
一.浮点型概述
Go语言提供两种精度的浮点数,即float32和float64,其中float32占用4个字节大小,而float64占用8个字节大小。 这些浮点数类型的取值范围极限值可以在Golang的math包中找到:
常量math.MaxFloat32表示folat32能取到的最大数值,如下图所示,Go语言定义为:3.40282346638528859811704183484516925440e+38;
常量math.SmallestNonzeroFloat32表示folat32能取到的最小数值,如下图所示,Go语言定义为:1.401298464324817070923729583289916131280e-45
常量math.MaxFloat64表示folat64能取到的最大数值,如下图所示,Go语言定义为:1.797693134862315708145274237317043567981e+308;
常量math.MaxFloat64表示folat64能取到的最小数值,如下图所示,Go语言定义为:4.940656458412465441765687928682213723651e-324; 浮点数都是相对精准的,存在一定的误差:
float32类型的浮点数可以提供约6个十进制数的精度,即按照四舍五入法默认小数点后保留六位。
float64类型的浮点数可以提供约15个十进制数的精度,即按照四舍五入法默认小数点后保留十五位。 通常应该优先使用float64类型,因为float32类型的累计祭祀按无法很容易扩散,并且float32能精确表示正整数并不是很大。

二.浮点型简单应用案例
1>.单精度浮点型float32应用案例

2>.双精度浮点型float64应用案例
package main import (
"fmt"
) func main() {
/*
温馨提示:
自动推导类型命名的浮点数类型默认为float64.
*/
a := 3.141592653589
var b float64 = 1.618033988749
/*
3.141592653589 x 1.618033988749 = 5.083203592311165 但是单精度浮点型小数点后默认保留六位,最终结果四舍五入法得到的结果为:5.083204
*/
var c float64 = a * b fmt.Printf("a的类型为:[%T],a的值为:[%f]\n", a, a)
fmt.Printf("b的类型为:[%T],b的值为:[%f]\n", b, b)
fmt.Printf("c的类型为:[%T],c的值为:[%f]\n", c, c) fmt.Printf("a x b = %f\n", c) /*
%.1f:
表示小数点后按照四舍五入法保留1位有效数字
%.2f:
表示小数点后按照四舍五入法保留2位有效数字
%.3f:
表示小数点后按照四舍五入法保留3位有效数字
...:
综上所述,依此类推即可....
*/
fmt.Printf("a x b = %.1f\n", c)
fmt.Printf("a x b = %.2f\n", c)
fmt.Printf("a x b = %.3f\n", c)
}

3>.使用浮点数的注意事项
package main import (
"fmt"
) func main() {
/*
使用浮点数注意事项:
(1)默认浮点数类型为float64;
(2)浮点数的简写形式,生产环境中并不推荐大家这样写,可读性差.
1>.如果小数部分为0,可以省略整数部分
2>.如果小数部分为0,可以省略小数部分
(3)使用科学计数法表示数据
可以使用%e占位符来表示科学计数法,了解即可,生产环境中使用相对较少。
*/ //整数部分为0可以省略不写
a := .
fmt.Printf("a的类型为:[%T],a的值为:[%f]\n", a, a) //小数部分为0可以省略不写
b := .
fmt.Printf("b的类型为:[%T],b的值为:[%f]\n", b, b) c := 50832036.9
fmt.Printf("c的类型为:[%T],c的值为:[%f]\n", c, c) //使用科学计数法表示变量c对应的值e
d := 5.08320369e7
fmt.Printf("d的类型为:[%T],d的值为:[%f]\n", d, d)
fmt.Printf("d的类型为:[%T],d的值使用科学计数法表示为:[%e]\n", d, d)
fmt.Printf("d的类型为:[%T],d的值使用科学计数法表示为:[%E]\n", d, d)
}

Golang的基础数据类型-浮点型的更多相关文章
- Golang的基础数据类型-字符串型
Golang的基础数据类型-字符串型 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.字符型概述 上一篇博客学习了使用单引号括起来的单个字符就是字符类型,在Golang中有两种表 ...
- Golang的基础数据类型-字符型
Golang的基础数据类型-字符型 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.字符型概述 Go语言中的字符有两种,即uint8类型和rune类型. uint8类型: 我们也 ...
- Golang的基础数据类型-整型
Golang的基础数据类型-整型 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.整型概述 Go语言的整数类型一共有10个. int: 默认是有符号(signed)整形,占用空间 ...
- Golang的基础数据类型-布尔型
Golang的基础数据类型-布尔型 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.bool类型概述 bool类型的取值范围: bool类型的值只有两种,其值不为真即为假,可以用 ...
- GoLang基础数据类型--->字典(map)详解
GoLang基础数据类型--->字典(map)详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 可能大家刚刚接触Golang的小伙伴都会跟我一样,这个map是干嘛的,是 ...
- GoLang基础数据类型-切片(slice)详解
GoLang基础数据类型-切片(slice)详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 数组的长度在定义之后无法再次修改:数组是值类型,每次传递都将产生一份副本.显然这种数 ...
- GoLang基础数据类型--->数组(array)详解
GoLang基础数据类型--->数组(array)详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.Golang数组简介 数组是Go语言编程中最常用的数据结构之一.顾名 ...
- GoLang基础数据类型--->字符串处理大全
GoLang基础数据类型--->字符串处理大全 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 欢迎加入: 高级运维工程师之路 59843264 ...
- golang语言基础(一)
0.项目的组织结构: GOPATH路径下是src文件夹---->src文件夹下是项目名称---->项目名称下是该项目的各个包名---->各包名下是.go文件(一个包下,无论有多少个. ...
随机推荐
- va_list、va_start、va_arg、va_end
转载:https://www.cnblogs.com/bwangel23/p/4700496.html 这几个函数和变量是针对可变参数函数的,什么是可变参数函数呢,最经典的莫过于printf和scan ...
- Periodic-table
1. Periodic table 1.1 元素的排列 1.2 表中的行与列 1.3 元素区块 1.4 周期表中的一些趋势 1.5 元素周期律的本质 1.6 电子排布 2. 更多相关链接 2.1 维基 ...
- 前后端分离后API交互如何保证数据安全性?
一.前言 前后端分离的开发方式,我们以接口为标准来进行推动,定义好接口,各自开发自己的功能,最后进行联调整合.无论是开发原生的APP还是webapp还是PC端的软件,只要是前后端分离的模式,就避免不了 ...
- java各种面试问题
二.Java多线程相关 线程池的原理,为什么要创建线程池?创建线程池的方式: 线程的生命周期,什么时候会出现僵死进程: 说说线程安全问题,什么实现线程安全,如何实现线程安全: 创建线程池有哪几个核心参 ...
- Java日期时间API系列11-----Jdk8中java.time包中的新的日期时间API类,使用java8日期时间API重写农历LunarDate
通过Java日期时间API系列7-----Jdk8中java.time包中的新的日期时间API类的优点,java8具有很多优点,现在网上查到的农历转换工具类都是基于jdk7及以前的类写的,下面使用ja ...
- 使 Firefox 和 Vivaldi 只在新标签页显示书签栏
Firefox 新建 ~/.mozilla/firefox/rre9emvh.default/chrome/userChrome.css (大概不同人的 rre9emvh.default 目录会有不同 ...
- Docker常用命令(命令大全)
容器生命周期管理 1. docker run:创建一个新的容器并运行一个命令 2. Docker start/stop/restart - docker start:启动一个或多个已经被停止的容器 - ...
- python之对象基础
目录 面向对象 1. 面向过程编程的优缺点 2. 面向对象编程的优缺点 3. 类 类和函数的区别 什么是类 现实世界中先有对象,后有类 python中先有类,再有对象 对象 如何实例化一个对象 对象属 ...
- Python 类型转换指南
一.int型 支持转换为 int 类型的,仅有 float.str.bytes,其他类型均不支持. 1.float -> int会去掉小数点及后面的数值,仅保留整数部分. 2.str -> ...
- 二、Navicat、IDEA、nopad、eclipse、excle工具使用、问题、快捷键
1.Navicat工具: 目的:本地数据库与远程数据库之间数据导入导出 步骤1:文件--新建oracle链接/mysql的连接 步骤2:工具-选项:将本地oracle的bin\oci.dll 的路径复 ...