Julia入门(2)——整数和浮点数 Ι

整数和浮点数(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 错误。

未完待续

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

雲小妖

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值