整数和浮点数(1)
1、介绍
- 整数和浮点值是算术和计算的基础。这些数值的内置表示被称作原始数值类型(numeric primitive)。
- 整数和浮点数在代码中作为立即数时称作数值字面量(numeric literal)。例如,1 是个整型字面量,1.0是个浮点型字面量,它们在内存中作为对象的二进制表示就是原始数值类型(numeric primitive)。
- Julia提供了很丰富的原始数值类型,并基于它们定义了一整套算术操作,还提供按位运算符以及一些标准数学函数。这些函数能够直接映射到现代计算机原生支持的数值类型及运算上,因此Julia 可以充分地利用运算资源。
- 此外,Julia 还为任意精度算术提供了软件支持,对于无法使用原生硬件表示的数值类型,Julia也能够高效地处理其数值运算。当然,这需要相对的牺牲一些性能。
2、Julia 的原始数值类型:
- 整数类型:
- 浮点类型:
注:对复数和有理数的完整支持是在这些原始数据类型之上建立起来的。
3、整数
-
整数字面量以标准形式表示:
-
整型字面量的默认类型取决于目标系统是 32 位还是 64 位架构:(64位如下)
-
Julia 的内置变量 Sys.WORD_SIZE 表明了目标系统是 32 位还是 64 位架构:(64位如下)
-
Julia 也定义了 Int 与 UInt 类型,它们分别是系统有符号和无符号的原生整数类型的别名。
-
超过 32 位表示范围的大整数,如果能用 64 位表示,那么无论是什么系统都会用 64 位表示:
-
无符号整数会通过 0x 前缀以及十六进制数 0-9a-f 来输入和输出(输入也可以使用大写的A-F)。无符号值的位数取决于十六进制数字使用的数量:
注意:ans 变量,交互式会话中上一个表达式的运算结果,但以其他方式运行的 Julia 代码中没有这个变量。 -
二进制和八进制字面量也是支持的:
二进制、八进制和十六进制的字面量都会产生无符号的整数类型。当字面量不是开头全是 0 时,它们二进制数据项的位数会是最少需要的位数。当开头都是 0 时,位数取决于一个字面量需要的最少位数,这里的字面量指的是一个有着同样长度但开头都为 1 的数。这样用户就可以控制位数了。那些无法使用 UInt128 类型存储下的值无法写成这样的字面量。 -
二进制、八进制和十六进制的字面量可以在前面紧接着加一个负号 -,这样可以产生一个和原字面量有着同样位数而值为原数的补码的数(二补数):
-
整型等原始数值类型的最小和最大可表示的值可用 typemin 和 typemax 函数得到:
1、溢出行为
- Julia 中,超出一个类型可表示的最大值会导致循环行为:
因此,Julia 的整数算术实际上是模算数的一种形式,它反映了现代计算机实现底层算术的特点。在可能有溢出产生的程序中,对最值边界出现循环进行显式检查是必要的。否则,推荐使用任意精度算术中的 BigInt 类型作为替代。
2、除法错误
div 函数的整数除法有两种异常情况:除以零,以及使用 -1 去除最小的负数(typemin)。
这两种情况都会抛出一个 DivideError 错误。 rem 取余函数和 mod 取模函数在除零时抛出 DivideError 错误。