模块 Stdlib.Int32

module Int32: Int32

val zero : int32

32 位整数 0。

val one : int32

32 位整数 1。

val minus_one : int32

32 位整数 -1。

val neg : int32 -> int32

一元取反。

val add : int32 -> int32 -> int32

加法。

val sub : int32 -> int32 -> int32

减法。

val mul : int32 -> int32 -> int32

乘法。

val div : int32 -> int32 -> int32

整数除法。此除法将参数的实数商四舍五入到零,如 (/) 中所指定。

val unsigned_div : int32 -> int32 -> int32

Int32.div 相同,但参数和结果被解释为无符号 32 位整数。

val rem : int32 -> int32 -> int32

整数余数。如果 y 不为零,则 Int32.rem x y 的结果满足以下属性:x = Int32.add (Int32.mul (Int32.div x y) y) (Int32.rem x y)。如果 y = 0,则 Int32.rem x y 引发 Division_by_zero

val unsigned_rem : int32 -> int32 -> int32

Int32.rem 相同,但参数和结果被解释为无符号 32 位整数。

val succ : int32 -> int32

后继。 Int32.succ x 等于 Int32.add x Int32.one

val pred : int32 -> int32

前驱。 Int32.pred x 等于 Int32.sub x Int32.one

val abs : int32 -> int32

abs xx 的绝对值。在 min_int 上,这是 min_int 本身,因此仍然为负。

val max_int : int32

可表示的最大 32 位整数,231 - 1。

val min_int : int32

可表示的最小 32 位整数,-231

val logand : int32 -> int32 -> int32

按位逻辑与。

val logor : int32 -> int32 -> int32

按位逻辑或。

val logxor : int32 -> int32 -> int32

按位逻辑异或。

val lognot : int32 -> int32

按位逻辑非。

val shift_left : int32 -> int -> int32

Int32.shift_left x yx 左移 y 位。如果 y < 0y >= 32,则结果未指定。

val shift_right : int32 -> int -> int32

Int32.shift_right x yx 右移 y 位。这是一个算术移位:x 的符号位被复制并插入到空闲位中。如果 y < 0y >= 32,则结果未指定。

val shift_right_logical : int32 -> int -> int32

Int32.shift_right_logical x yx 右移 y 位。这是一个逻辑移位:无论 x 的符号如何,零都插入到空闲位中。如果 y < 0y >= 32,则结果未指定。

val of_int : int -> int32

将给定的整数(类型 int)转换为 32 位整数(类型 int32)。在 64 位平台上,参数取模 232

val to_int : int32 -> int

将给定的 32 位整数(类型 int32)转换为整数(类型 int)。在 32 位平台上,32 位整数取模 231,即在转换过程中丢失高位。

val unsigned_to_int : int32 -> int option

Int32.to_int 相同,但将参数解释为无符号整数。如果参数的无符号值不能放入 int 中,则返回 None

val of_float : float -> int32

将给定的浮点数转换为 32 位整数,丢弃小数部分(截断到 0)。如果截断的浮点数超出范围 [Int32.min_intInt32.max_int],则不会引发异常,并且会返回一个未指定的、平台相关的整数。

val to_float : int32 -> float

将给定的 32 位整数转换为浮点数。

val of_string : string -> int32

将给定的字符串转换为 32 位整数。字符串以十进制读取(默认情况下,或者如果字符串以 0u 开头)或以十六进制、八进制或二进制读取,如果字符串分别以 0x0o0b 开头。

0u 前缀将输入读取为范围 [0, 2*Int32.max_int+1] 内的无符号整数。如果输入超过 Int32.max_int,则将其转换为带符号整数 Int32.min_int + input - Int32.max_int - 1

_(下划线)字符可以出现在字符串中的任何位置,并且会被忽略。

val of_string_opt : string -> int32 option

of_string 相同,但返回 None 而不是引发异常。

val to_string : int32 -> string

返回其参数的字符串表示形式,以带符号的十进制形式表示。

val bits_of_float : float -> int32

根据 IEEE 754 浮点数“单精度格式”位布局返回给定浮点数的内部表示。结果的第 31 位表示浮点数的符号;第 30 到 23 位表示(有偏的)指数;第 22 到 0 位表示尾数。

val float_of_bits : int32 -> float

返回内部表示形式(根据 IEEE 754 浮点数“单精度格式”位布局)为给定 int32 的浮点数。

type t = int32 

32 位整数类型的别名。

val compare : t -> t -> int

32 位整数的比较函数,与 compare 的规范相同。除了类型 t 之外,此函数 compare 还允许将模块 Int32 作为参数传递给函子 Set.MakeMap.Make

val unsigned_compare : t -> t -> int

Int32.compare 相同,但参数被解释为无符号 32 位整数。

val equal : t -> t -> bool

int32 的相等函数。

val min : t -> t -> t

返回两个参数中较小的一个。

val max : t -> t -> t

返回两个参数中较大的一个。

val seeded_hash : int -> t -> int

32 位整数的带种子哈希函数,与 Hashtbl.seeded_hash 的输出值相同。此函数允许将此模块作为参数传递给函子 Hashtbl.MakeSeeded

val hash : t -> int

32 位整数的无种子哈希函数,与 Hashtbl.hash 的输出值相同。此函数允许将此模块作为参数传递给函子 Hashtbl.Make