GGitee11
5f9938d9创建于 2025年2月27日历史提交

@arkts.math.Decimal (高精度数学库Decimal)

Decimal用于提供高精度数学库,主要用于提供高精度浮点运算能力。

说明:

本模块首批接口从API version 12开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。

此模块仅支持在ArkTS文件(文件后缀为.ets)中导入使用。

导入模块

import { Decimal } from '@kit.ArkTS';

Value

type Value = string | number | Decimal

表示用于构建Decimal的参数类型。

取值类型为下列类型中的并集。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

类型 说明
string 表示值类型为字符,可取任意值。
number 表示值类型为数字,可取任意值。
Decimal 表示值类型为Decimal类型。

Rounding

type Rounding = 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8

表示可设置的舍入类型。

取值类型为下列类型中的并集。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

类型 说明
0 向远离零的方向舍入。与Decimal.ROUND_UP一致。
1 向靠近零的方向舍入。与Decimal.ROUND_DOWN一致。
2 向正无穷方向舍入。与Decimal.ROUND_CEILING一致。
3 向负无穷方向舍入。与Decimal.ROUND_FLOOR一致。
4 向最近的邻值舍入。如果距离相等,则远离零方向舍入。与Decimal.ROUND_HALF_UP一致。
5 向最近的邻值舍入。如果距离相等,则靠近零方向舍入。与Decimal.ROUND_HALF_DOWN一致。
6 向最近的邻值舍入。如果距离相等,则向偶数邻值舍入。与Decimal.ROUND_HALF_EVEN一致。
7 向最近的邻值舍入。如果距离相等,则向正无穷方向舍入。与Decimal.ROUND_HALF_CEILING一致。
8 向最近的邻值舍入。如果距离相等,则向负无穷方向舍入。与Decimal.ROUND_HALF_FLOOR一致。

Modulo

type Modulo = Rounding | 9

表示可设置的取模方法舍入类型。

取值类型为下列类型中的并集。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

类型 说明
Rounding 模运算下的舍入类型。与Rounding表示的舍入模式相同。
9 余模运算下,余数始终为正。欧几里得除法。与Decimal.EUCLID一致。

DecimalConfig

用于设置Decimal的配置属性,可使用Decimal.set方法进行配置。

属性

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

名称 类型 只读 必填 说明
precision number 运算结果的最大有效位数,取值范围为[1, 1e9],默认值为20。
rounding Rounding 舍入模式,取值范围为0到8的整数,默认值为4。
toExpNeg number 指数表示法的负指数值的极限值,若Decimal的负指数小于等于该值时,使用科学计数法表示,toString方法中使用,取值范围为[-9e15, 0],默认值为-7。
toExpPos number 指数表示法的正指数值的极限值,若Decimal的正指数大于等于该值时,使用科学计数法表示,toString方法中使用,取值范围为[0, 9e15],默认值为21。
minE number 负指数极限,若Decimal的指数值小于该值,会下溢到零,取值范围为[-9e15, 0],默认值为-9e15。
maxE number 正指数极限,若Decimal的指数值大于该值,会溢出至无穷大,取值范围为[0, 9e15],默认值为9e15。
crypto boolean 确定是否使用加密安全伪随机数生成的值,默认值为false。该能力不支持使用,报错的错误码为:10200061。
modulo Modulo 模计算时使用的舍入模式,取值范围为0到9的整数,默认值为1。
defaults boolean 表示未指定的属性是否被设置为默认值,true表示使用默认值,false表示不使用默认值,默认值为true。

Decimal

任意精度的Decimal类型。

属性

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

名称 类型 只读 必填 说明
d number[] digits:表示Decimal数整数部分和小数部分。
e number exponent:表示Decimal数十进制指数的数目。
s number sign:表示Decimal数的符号位。

常量

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

名称 类型 说明
ROUND_UP number 0 向远离零的方向舍入。模运算下,如果被除数为负,则余数为正,否则为负。
ROUND_DOWN number 1 向靠近零的方向舍入。模运算下,余数与被除数的符号相同,使用截断除法。
ROUND_CEILING number 2 向正无穷方向舍入。
ROUND_FLOOR number 3 向负无穷方向舍入。模运算下,余数与除数的符号相同。
ROUND_HALF_UP number 4 向最近的邻值舍入。如果距离相等,则远离零方向舍入。
ROUND_HALF_DOWN number 5 向最近的邻值舍入。如果距离相等,则靠近零方向舍入。
ROUND_HALF_EVEN number 6 向最近的邻值舍入。如果距离相等,则向偶数邻值舍入。模运算下,IEEE 754 求余函数。
ROUND_HALF_CEILING number 7 向最近的邻值舍入。如果距离相等,则向正无穷方向舍入。
ROUND_HALF_FLOOR number 8 向最近的邻值舍入。如果距离相等,则向负无穷方向舍入。
EUCLID number 9 模运算下,余数始终为正。使用欧几里得除法:q = sign(x) * floor(a / abs(x))。

constructor

constructor(n: Value)

Decimal的构造函数。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 构造Decimal时的初始值。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = new Decimal(5);
console.info("test Decimal constructor:" + data.toString()); // 'test Decimal constructor:5'

abs

abs(): Decimal

返回一个新的Decimal对象,其值为该Decimal的绝对值。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
Decimal 返回绝对值运算后的Decimal对象实例。

示例:

let data: Decimal = new Decimal(-0.5).abs();
console.info("test Decimal abs:" + data.toString()); // 'test Decimal abs:0.5'

floor

floor(): Decimal

返回一个新的Decimal对象,其值为该Decimal向负无穷方向舍入得到的结果。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
Decimal 返回舍入之后的Decimal对象实例。

示例:

let data: Decimal = new Decimal(1.8).floor();
console.info("test Decimal floor:" + data.toString()); // 'test Decimal floor:1'

ceil

ceil(): Decimal

返回一个新的Decimal对象,其值为该Decimal向正无穷方向舍入得到的结果。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
Decimal 返回舍入之后的Decimal对象实例。

示例:

let data: Decimal = new Decimal(1.8).ceil();
console.info("test Decimal ceil:" + data.toString()); // 'test Decimal ceil:2'

trunc

trunc(): Decimal

返回一个新的Decimal,其值是将此Decimal截断为整数部分。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
Decimal 返回截断之后的Decimal对象实例。

示例:

let data: Decimal = new Decimal(2.5).trunc();
console.info("test Decimal trunc:" + data.toString()); // 'test Decimal trunc:2'

clamp

clamp(min: Value, max: Value): Decimal

返回一个值为将该Decimal的值限制在min到max范围内的Decimal对象。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
min Value 限制的最小值。包含该值。
max Value 限制的最大值。包含该值。

返回值:

类型 说明
Decimal 返回符合范围内的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码语言基础类库错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.
10200001 The value of 'min' is out of range.

示例:

let data: Decimal = new Decimal(10.1).clamp(0, 10);
console.info("test Decimal clamp:" + data.toString()); // 'test Decimal clamp:10'

add

add(n: Value): Decimal

返回一个新的Decimal,其值为该Decimal的值加上n。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 加法运算的加数。

返回值

类型 说明
Decimal 返回加法运算后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = new Decimal(0.5).add(0.5);
console.info("test Decimal add:" + data.toString()); // 'test Decimal add:1'

sub

sub(n: Value): Decimal

返回一个新的Decimal,其值为此Decimal的值减去n。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 减法运算的减数。

返回值:

类型 说明
Decimal 返回减法运算后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = new Decimal(1).sub(0.5);
console.info("test Decimal sub:" + data.toString()); // 'test Decimal sub:0.5'

mul

mul(n: Value): Decimal

返回一个新的Decimal,其值为Decimal乘以n。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 乘法运算的乘数。

返回值:

类型 说明
Decimal 返回乘法运算后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = new Decimal(1).mul(0.5);
console.info("test Decimal mul:" + data.toString()); // 'test Decimal mul:0.5'

div

div(n: Value): Decimal

返回一个新的Decimal,其值是此Decimal的值除以n。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 除法运算的除数。

返回值:

类型 说明
Decimal 返回除法运算后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = new Decimal(1).div(0.5);
console.info("test Decimal div:" + data.toString()); // 'test Decimal div:2'

mod

mod(n: Value): Decimal

返回一个新的Decimal,其值是该Decimal除以n的模。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 取模运算的除数。

返回值:

类型 说明
Decimal 返回取模运算后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = new Decimal(2).mod(1);
console.info("test Decimal mod:" + data.toString()); // 'test Decimal mod:0'

sqrt

sqrt(): Decimal

返回一个新的Decimal,其值为该Decimal的平方根。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
Decimal 返回平方根运算后的Decimal对象实例。

示例:

let data: Decimal = new Decimal(3).sqrt();
console.info("test Decimal sqrt:" + data.toString()); // 'test Decimal sqrt:1.7320508075688772935'

cbrt

cbrt(): Decimal

返回一个新的Decimal,其值是此Decimal值的立方根。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
Decimal 返回立方根运算后的Decimal对象实例。

示例:

let data: Decimal = new Decimal(3).cbrt();
console.info("test Decimal cbrt:" + data.toString()); // 'test Decimal cbrt:1.4422495703074083823'

pow

pow(n: Value): Decimal

返回一个新的Decimal,它的值是这个Decimal的值的n次幂。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 幂运算的幂的值。

返回值:

类型 说明
Decimal 返回幂运算后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码语言基础类库错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.
10200060 Precision limit exceeded.

示例:

let data: Decimal = new Decimal(3).pow(-2);
console.info("test Decimal pow:" + data.toString()); // 'test Decimal pow:0.11111111111111111111'

exp

exp(): Decimal

返回一个新的Decimal,其值是该Decimal值的自然指数。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 返回值
Decimal 返回自然指数运算后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200060 Precision limit exceeded.

示例:

let data: Decimal = new Decimal(2).exp();
console.info("test Decimal exp:" + data.toString()); // 'test Decimal exp:7.3890560989306502272'

log

log(n: Value): Decimal

返回一个值,以n为底的指定的对数运算的Decimal对象。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 对数计算的底数值。

返回值:

类型 说明
Decimal 返回对数运算后的Decimal对象实例。

错误码

以下错误码的详细介绍请参见通用错误码语言基础类库错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.
10200060 Precision limit exceeded.

示例:

let data: Decimal = new Decimal(2).log(256);
console.info("test Decimal log:" + data.toString()); // 'test Decimal log:0.125'

ln

ln(): Decimal

返回一个新的Decimal,其值是此Decimal值的自然对数。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
Decimal 返回自然对数运算后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200060 Precision limit exceeded.

示例:

let data: Decimal = new Decimal(1.23e+30).ln();
console.info("test Decimal ln:" + data.toString()); // 'test Decimal ln:69.284566959205696648'

cos

cos(): Decimal

返回一个新的Decimal,其值是此Decimal的余弦值。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
Decimal 返回计算余弦值的Decimal对象实例。

示例:

let data: Decimal = new Decimal(-0.25).cos();
console.info("test Decimal cos:" + data.toString()); // 'test Decimal cos:0.96891242171064478414'

sin

sin(): Decimal

返回一个新的Decimal,其值是此Decimal的正弦值。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
Decimal 返回计算正弦值的Decimal对象实例。

示例:

let data: Decimal = new Decimal(0.75).sin();
console.info("test Decimal sin:" + data.toString()); // 'test Decimal sin:0.68163876002333416673'

tan

tan(): Decimal

返回一个新的Decimal,其值是此Decimal的正切值。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
Decimal 返回计算正切值的Decimal对象实例。

示例:

let data: Decimal = new Decimal(0.75).tan();
console.info("test Decimal tan:" + data.toString()); // 'test Decimal tan:0.93159645994407246117'

cosh

cosh(): Decimal

返回一个新的Decimal,其值是此Decimal的双曲余弦值。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
Decimal 返回计算双曲余弦值的Decimal对象实例。

示例:

let data: Decimal = new Decimal(0.5).cosh();
console.info("test Decimal cosh:" + data.toString()); // 'test Decimal cosh:1.1276259652063807852'

sinh

sinh(): Decimal

返回一个新的Decimal,其值是此Decimal的双曲正弦值。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
Decimal 返回计算双曲正弦值的Decimal对象实例。

示例:

let data: Decimal = new Decimal(0.5).sinh();
console.info("test Decimal sinh:" + data.toString()); // 'test Decimal sinh:0.52109530549374736162'

tanh

tanh(): Decimal

返回一个新的Decimal,其值是此Decimal的双曲正切值。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
Decimal 返回计算双曲正切值的Decimal对象实例。

示例:

let data: Decimal = new Decimal(0.5).tanh();
console.info("test Decimal tanh:" + data.toString()); // 'test Decimal tanh:0.4621171572600097585'

acos

acos(): Decimal

返回一个新的Decimal,其值是此Decimal的反余弦值。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
Decimal 返回计算反余弦值的Decimal对象实例。

错误码

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200060 Precision limit exceeded.

示例:

let data: Decimal = new Decimal(0.5).acos();
console.info("test Decimal acos:" + data.toString()); // 'test Decimal acos:1.0471975511965977462'

asin

asin(): Decimal

返回一个新的Decimal,其值为此Decimal的反正弦值。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
Decimal 返回计算反正弦值的Decimal对象实例。

错误码

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200060 Precision limit exceeded.

示例:

let data: Decimal = new Decimal(0.75).asin();
console.info("test Decimal asin:" + data.toString()); // 'test Decimal asin:0.84806207898148100805'

atan

atan(): Decimal

返回一个新的Decimal,其值是此Decimal的反正切值。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
Decimal 返回计算反正切值的Decimal对象实例。

错误码

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200060 Precision limit exceeded.

示例:

let data: Decimal = new Decimal(0.75).atan();
console.info("test Decimal atan:" + data.toString()); // 'test Decimal atan:0.6435011087932843868'

acosh

acosh(): Decimal

返回一个新的Decimal,其值是此Decimal值的双曲余弦的倒数。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
Decimal 返回计算双曲余弦的倒数值的Decimal对象实例。

错误码

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200060 Precision limit exceeded.

示例:

let data: Decimal = new Decimal(50).acosh();
console.info("test Decimal acosh:" + data.toString()); // 'test Decimal acosh:4.6050701709847571595'

asinh

asinh(): Decimal

返回一个新的Decimal,其值是此Decimal值的双曲正弦的倒数。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
Decimal 返回计算双曲正弦的倒数值的Decimal对象实例。

错误码

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200060 Precision limit exceeded.

示例:

let data: Decimal = new Decimal(50).asinh();
console.info("test Decimal asinh:" + data.toString()); // 'test Decimal asinh:4.6052701709914238266'

atanh

atanh(): Decimal

返回一个新的Decimal,其值是此Decimal值的双曲正切的倒数。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
Decimal 返回计算双曲正切的倒数值的Decimal对象实例。

错误码

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200060 Precision limit exceeded.

示例:

let data: Decimal = new Decimal(0.75).atanh();
console.info("test Decimal atanh:" + data.toString()); // 'test Decimal atanh:0.97295507452765665255'

comparedTo

comparedTo(n: Value): number

Decimal的比较方法。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 待比较的值或Decimal。

返回值:

类型 说明
number 返回该Decimal与n的比较结果:
1:该Decimal大于比较值。
-1:该Decimal小于比较值。
0:该Decimal等于比较值。
NaN:该Decimal与比较值有一个值为NaN。

错误码

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = new Decimal(Infinity);
let data1: Decimal = new Decimal(5);
let data2: number = data.comparedTo(data1);
console.info("test Decimal comparedTo:" + data2); // 'test Decimal comparedTo:1'

let data3: number = data1.comparedTo(10.5);
console.info("test Decimal comparedTo:" + data3); // 'test Decimal comparedTo:-1'

equals

equals(n: Value): boolean

返回该Decimal是否等于比较值。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 待比较的值或Decimal。

返回值:

类型 说明
boolean true表示该Decimal与比较值相等,其余情况为false。

错误码

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = new Decimal(0);
let data1: boolean = data.equals('1e-324');
console.info("test Decimal equals:" + data1); // 'test Decimal equals:false'

greaterThan

greaterThan(n: Value): boolean

返回该Decimal是否大于比较值。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 待比较的值或Decimal。

返回值:

类型 说明
boolean true表示该Decimal大于比较值,其余情况为false。

错误码

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = new Decimal(0.1);
let data1: boolean = data.greaterThan(new Decimal(0.3).sub(0.2)); 
console.info("test Decimal greaterThan:" + data1); // 'test Decimal greaterThan:false'

greaterThanOrEqualTo

greaterThanOrEqualTo(n: Value): boolean

返回该Decimal是否大于等于比较值。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 待比较的值或Decimal。

返回值:

类型 说明
boolean true表示该Decimal大于等于比较值,其余情况为false。

错误码

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = new Decimal(0.3).sub(0.2);
let data1: boolean = data.greaterThanOrEqualTo(0.1);
console.info("test Decimal greaterThanOrEqualTo:" + data1); // 'test Decimal greaterThanOrEqualTo:true'

lessThan

lessThan(n: Value): boolean

返回该Decimal是否小于比较值。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 待比较的值或Decimal。

返回值:

类型 说明
boolean true表示该Decimal小于比较值,其余情况为false。

错误码

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = new Decimal(0.3).sub(0.2);
let data1: boolean = data.lessThan(0.1)
console.info("test Decimal lessThan:" + data1); // 'test Decimal lessThan:false'

lessThanOrEqualTo

lessThanOrEqualTo(n: Value): boolean

返回该Decimal是否小于等于比较值。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 待比较的值或Decimal。

返回值:

类型 说明
boolean true表示该Decimal小于等于比较值,其余情况为false。

错误码

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = new Decimal(0.1);
let data1: boolean = data.lessThanOrEqualTo(new Decimal(0.3).sub(0.2))
console.info("test Decimal lessThanOrEqualTo:" + data1); // 'test Decimal lessThanOrEqualTo:true'

isFinite

isFinite(): boolean

返回该Decimal是否为有限值。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
boolean true表示该Decimal为有限值,其余情况为false。

示例:

let data: Decimal = new Decimal(1);
let data1: boolean = data.isFinite();
console.info("test Decimal isFinite:" + data1); // 'test Decimal isFinite:true'

isInteger

isInteger(): boolean

返回该Decimal是否为整数。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
boolean true表示该Decimal为整数,其余情况为false。

示例:

let data: Decimal = new Decimal(123.456);
let data1: boolean = data.isInteger();
console.info("test Decimal isInteger:" + data1); // 'test Decimal isInteger:false'

isNaN

isNaN(): boolean

返回该Decimal是否为无效值。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
boolean true表示该Decimal为NaN,其余情况为false。

示例:

let data: Decimal = new Decimal(NaN);
let data1: boolean = data.isNaN();
console.info("test Decimal isNaN:" + data1); // 'test Decimal isNaN:true'

isNegative

isNegative(): boolean

返回该Decimal是否为负数。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
boolean true表示该Decimal为负数,其余情况为false。

示例:

let data: Decimal = new Decimal(-5);
let data1: boolean = data.isNegative();
console.info("test Decimal isNegative:" + data1); // 'test Decimal isNegative:true'

let data2: Decimal = new Decimal(-0);
let data3: boolean = data.isNegative();
console.info("test Decimal isNegative:" + data3); // 'test Decimal isNegative:true'

isPositive

isPositive(): boolean

返回该Decimal是否为正数。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
boolean true表示该Decimal为正数,其余情况为false。

示例:

let data: Decimal = new Decimal(5);
let data1: boolean = data.isPositive();
console.info("test Decimal isPositive:" + data1); // 'test Decimal isPositive:true'

let data2: Decimal = new Decimal(0);
let data3: boolean = data.isPositive();
console.info("test Decimal isPositive:" + data3); // 'test Decimal isPositive:true'

isZero

isZero(): boolean

返回该Decimal是否为0或是-0。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
boolean true表示该Decimal为0或是-0,其余情况为false。

示例:

let data: Decimal = new Decimal(0);
let data1: boolean = data.isZero();
console.info("test Decimal isZero:" + data1.toString()); // 'test Decimal isZero:true'

dividedToIntegerBy

dividedToIntegerBy(n: Value): Decimal

返回该Decimal除以n后获得的整数部分。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 除法的除数值。

返回值:

类型 说明
Decimal 返回一个新的Decimal,其值是将该Decimal的值除以n值的整数部分。

错误码

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = new Decimal(5);
let data1: Decimal = new Decimal(3);
let data2: Decimal = data.dividedToIntegerBy(data1);
console.info("test Decimal dividedToIntegerBy:" + data2.toString()); // 'test Decimal dividedToIntegerBy:1'

negate

negate(): Decimal

Decimal取反。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
Decimal 返回一个新的Decimal,其值为该Decimal的值乘以-1。

示例:

let data: Decimal = new Decimal(1.8);
let data1: Decimal = data.negate();
console.info("test Decimal negate:" + data1.toString()); // 'test Decimal negate:-1.8'

toBinary

toBinary(): string

转换为二进制表示的字符串。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
string 返回二进制表示的字符串。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200001 The value of 'significantDigits' is out of range.

示例:

let data: Decimal = new Decimal(256);
let data1: string = data.toBinary();
console.info("test Decimal toBinary:" + data1); // 'test Decimal toBinary:0b100000000'

toBinary

toBinary(significantDigits: number): string

转换为二进制表示的字符串,可按照significantDigits设置有效数字。

使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
significantDigits number 转换时保留的有效数字,取值范围为[1, 1e9]的整数。

返回值:

类型 说明
string 返回二进制表示的字符串。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200001 The value of 'significantDigits' is out of range.

示例:

let data: Decimal = new Decimal(256);
let data1: string = data.toBinary(1);
console.info("test Decimal toBinary:" + data1); // 'test Decimal toBinary:0b1p+8'

toBinary

toBinary(significantDigits: number, rounding: Rounding): string

转换为二进制表示的字符串,可按照significantDigits设置有效数字,可按照rounding设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
significantDigits number 转换时保留的有效数字,取值范围为[1, 1e9]的整数。
rounding Rounding 转换时使用的舍入模式,取值范围参考Rounding

返回值:

类型 说明
string 返回二进制表示的字符串。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200001 The value of 'significantDigits | rounding' is out of range.

示例:

let data: Decimal = new Decimal(256);
let data1: string = data.toBinary(1, Decimal.ROUND_HALF_UP);
console.info("test Decimal toBinary:" + data1); // 'test Decimal toBinary:0b1p+8'

toOctal

toOctal(): string

转换为八进制表示的字符串。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
string 返回八进制表示的字符串。

示例:

let data: Decimal = new Decimal(256);
let data1: string = data.toOctal();
console.info("test Decimal toOctal:" + data1); // 'test Decimal toOctal:0o400'

toOctal

toOctal(significantDigits: number): string

转换为八进制表示的字符串,可按照significantDigits设置有效数字。

使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
significantDigits number 转换时保留的有效数字,取值范围为[1, 1e9]的整数。

返回值:

类型 说明
string 返回八进制表示的字符串。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200001 The value of 'significantDigits' is out of range.

示例:

let data: Decimal = new Decimal(256);
let data1: string = data.toOctal(1);
console.info("test Decimal toOctal:" + data1); // 'test Decimal toOctal:0o1p+8'

toOctal

toOctal(significantDigits: number, rounding: Rounding): string

转换为八进制表示的字符串,可按照significantDigits设置有效数字,可按照rounding设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
significantDigits number 转换时保留的有效数字,取值范围为[1, 1e9]的整数。
rounding Rounding 转换时使用的舍入模式,取值范围参考Rounding

返回值:

类型 说明
string 返回八进制表示的字符串。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200001 The value of 'significantDigits | rounding' is out of range.

示例:

let data: Decimal = new Decimal(256);
let data1: string = data.toOctal(1, Decimal.ROUND_HALF_UP);
console.info("test Decimal toOctal:" + data1); // 'test Decimal toOctal:0o1p+8'

toHexadecimal

toHexadecimal(): string

转换为十六进制表示的字符串。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
string 返回十六进制表示的字符串。

示例:

let data: Decimal = new Decimal(256);
let data1: string = data.toHexadecimal();
console.info("test Decimal toHexadecimal:" + data1); // 'test Decimal toHexadecimal:0x100'

toHexadecimal

toHexadecimal(significantDigits: number): string

转换为十六进制表示的字符串,可按照significantDigits设置有效数字。

使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
significantDigits number 转换时保留的有效数字,取值范围为[1, 1e9]的整数。

返回值:

类型 说明
string 返回十六进制表示的字符串。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200001 The value of 'significantDigits' is out of range.

示例:

let data: Decimal = new Decimal(256);
let data1: string = data.toHexadecimal(1);
console.info("test Decimal toHexadecimal:" + data1); // 'test Decimal toHexadecimal:0x1p+8'

toHexadecimal

toHexadecimal(significantDigits: number, rounding: Rounding): string

转换为十六进制表示的字符串,可按照significantDigits设置有效数字,可按照rounding设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
significantDigits number 转换时保留的有效数字,取值范围为[1, 1e9]的整数。
rounding Rounding 转换时使用的舍入模式,取值范围参考Rounding

返回值:

类型 说明
string 返回十六进制表示的字符串。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200001 The value of 'significantDigits | rounding' is out of range.

示例:

let data: Decimal = new Decimal(256);
let data1: string = data.toHexadecimal(1, Decimal.ROUND_HALF_UP);
console.info("test Decimal toHexadecimal:" + data1); // 'test Decimal toHexadecimal:0x1p+8'

toDecimalPlaces

toDecimalPlaces(): Decimal

返回一个保留小数点后指定位数的Decimal对象,不进行小数的取舍。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
Decimal 返回一个新的Decimal,保留小数点后指定位数。

示例:

let data: Decimal = new Decimal(12.34567);
let data1: Decimal = data.toDecimalPlaces();
console.info("test Decimal toDecimalPlaces:" + data1.toString()); // 'test Decimal toDecimalPlaces:12.34567'

toDecimalPlaces

toDecimalPlaces(decimalPlaces: number): Decimal

返回一个保留小数点后指定位数的Decimal对象,可按照decimalPlaces设置小数位数。

使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
decimalPlaces number 转换时保留的小数点后有效位数,取值范围为[0, 1e9]的整数。

返回值:

类型 说明
Decimal 返回一个新的Decimal,保留小数点后指定位数。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200001 The value of 'decimalPlaces' is out of range.

示例:

let data: Decimal = new Decimal(9876.54321);
let data1: Decimal = data.toDecimalPlaces(3);
console.info("test Decimal toDecimalPlaces:" + data1.toString()); // 'test Decimal toDecimalPlaces:9876.543'

toDecimalPlaces

toDecimalPlaces(decimalPlaces: number, rounding: Rounding): Decimal

返回一个保留小数点后指定位数的Decimal对象,可按照decimalPlaces设置小数位数,可按照rounding设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
decimalPlaces number 转换时保留的小数点后有效位数,取值范围为[0, 1e9]的整数。
rounding Rounding 转换时使用的舍入模式。取值范围参考Rounding

返回值:

类型 说明
Decimal 返回一个新的Decimal,保留小数点后指定位数。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200001 The value of 'decimalPlaces | rounding' is out of range.

示例:

let data: Decimal = new Decimal(9876.54321);
let data1: Decimal = data.toDecimalPlaces(1, 0);
console.info("test Decimal toDecimalPlaces:" + data1.toString()); // 'test Decimal toDecimalPlaces:9876.6'
data1 = data.toDecimalPlaces(1, Decimal.ROUND_DOWN) // data1:'9876.5'

toExponential

toExponential(): string

转换为按照指数表示法显示的字符串,不进行小数的取舍。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
string 返回按照指数表示法显示的字符串。

示例:

let data: Decimal = new Decimal(45.6);
let data1: string = data.toExponential();
console.info("test Decimal toExponential:" + data1); // 'test Decimal toExponential:4.56e+1'

toExponential

toExponential(decimalPlaces: number): string

转换为按照指数表示法显示的字符串,可按照decimalPlaces设置小数位数。

使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
decimalPlaces number 转换时保留的小数点后有效位数,取值范围为[0, 1e9]的整数。

返回值:

类型 说明
string 返回按照指数表示法显示的字符串。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200001 The value of 'decimalPlaces' is out of range.

示例:

let data: Decimal = new Decimal(45.6);
let data1: string = data.toExponential(0);
console.info("test Decimal toExponential:" + data1); // 'test Decimal toExponential:5e+1'
data1 = data.toExponential(1) // data1:'4.6e+1'
data1 = data.toExponential(3) // data1:'4.560e+1'

toExponential

toExponential(decimalPlaces: number, rounding: Rounding): string

转换为按照指数表示法显示的字符串,可按照decimalPlaces设置小数位数,可按照rounding设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
decimalPlaces number 转换时保留的小数点后有效位数,取值范围为[0, 1e9]的整数。
rounding Rounding 转换时使用的舍入模式,取值范围参考Rounding

返回值:

类型 说明
string 返回按照指数表示法显示的字符串。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200001 The value of 'decimalPlaces | rounding' is out of range.

示例:

let data: Decimal = new Decimal(45.6);
let data1 = data.toExponential(1, Decimal.ROUND_DOWN)
console.info("test Decimal toExponential:" + data1); // 'test Decimal toExponential:4.5e+1'

toFixed

toFixed(): string

转换为十进制定点模式表示的字符串,不进行小数的取舍。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
Decimal 返回按照正常模式(十进制定点模式)表示的字符串。

示例:

let data: Decimal = new Decimal(3.456);
let data1: string = data.toFixed();
console.info("test Decimal toFixed:" + data1); // 'test Decimal toFixed:3.456'

toFixed

toFixed(decimalPlaces: number): string

转换为十进制定点模式表示的字符串,可按照decimalPlaces设置小数位数。

使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
decimalPlaces number 转换时保留的小数点后有效位数,取值范围为[0, 1e9]的整数。

返回值:

类型 说明
Decimal 返回按照正常模式(十进制定点模式)表示的字符串。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200001 The value of 'decimalPlaces' is out of range.

示例:

let data: Decimal = new Decimal(3.456);
let data1: string = data.toFixed(0)
console.info("test Decimal toFixed:" + data1); // 'test Decimal toFixed:3'
data1 = data.toFixed(2) // data1:'3.46'
data1 = data.toFixed(5) // data1:'3.45600'

toFixed

toFixed(decimalPlaces: number, rounding: Rounding): string

转换为十进制定点模式表示的字符串,可按照decimalPlaces设置小数位数,可按照rounding设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
decimalPlaces number 转换时保留的小数点后有效位数,取值范围为[0, 1e9]的整数。
rounding Rounding 转换时使用的舍入模式,取值范围参考Rounding

返回值:

类型 说明
Decimal 返回按照正常模式(十进制定点模式)表示的字符串。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200001 The value of 'decimalPlaces | rounding' is out of range.

示例:

let data: Decimal = new Decimal(3.456);
let data1: string = data.toFixed(2, Decimal.ROUND_DOWN);
console.info("test Decimal toFixed:" + data1); // b:'test Decimal toFixed:3.45'

toFraction

toFraction(): Decimal[]

转换为分数表示的数。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
Decimal[] 返回一个Decimal数组,该数组长度固定为2,其值表示为具有整数分子和整数分母的简单分数。且分子在前,分母在后。

示例:

let data: Decimal = new Decimal(1.75);
let data1: Decimal[] = data.toFraction();
console.info("test Decimal toFraction:" + data1.toString()); // 'test Decimal toFraction:7,4'

toFraction

toFraction(max_denominator: Value): Decimal[]

转换为分数表示的数,可以通过max_denominator设置最大分母值。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
max_denominator Value 分母的最大值。包含该值。

返回值:

类型 说明
Decimal[] 返回一个Decimal数组,该数组长度固定为2,其值表示为具有整数分子和整数分母的简单分数。且分子在前,分母在后。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let pi: Decimal = new Decimal('3.14159265358')
let data1 = pi.toFraction() // data1:'157079632679,50000000000'
data1 = pi.toFraction(100000) // data1:'312689, 99532'
data1 = pi.toFraction(10000) // data1:'355, 113'
data1 = pi.toFraction(100) // data1:'311, 99'
data1 = pi.toFraction(10) // data1:'22, 7'
data1 = pi.toFraction(1) // data1:'3, 1'

toNearest

toNearest(n: Value): Decimal

返回一个新的Decimal,该Decimal为指定值乘以一个倍数后与原Decimal最接近的值。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 参考的指定值。

返回值:

类型 说明
Decimal 返回一个新的Decimal,指定值最接近的倍数值。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200001 The value of 'rounding' is out of range.

示例:

let data: Decimal = new Decimal(1.39);
let data1: Decimal = data.toNearest(0.25);
console.info("test Decimal toNearest:" + data1.toString()); // 'test Decimal toNearest:1.5'

toNearest

toNearest(n: Value, rounding: Rounding): Decimal

返回一个新的Decimal,该Decimal为指定值乘以一个倍数后与原Decimal最接近的值,可按照rounding设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 参考的指定值。
rounding Rounding 转换时使用的舍入模式,取值范围参考Rounding

返回值:

类型 说明
Decimal 返回一个新的Decimal,指定值最接近的倍数值。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200001 The value of 'rounding' is out of range.

示例:

let data: Decimal = new Decimal(9.499)
let data1 = data.toNearest(0.5, Decimal.ROUND_UP) // data1:'9.5'
data1 = data.toNearest(0.5, Decimal.ROUND_DOWN) // data1:'9'

toPrecision

toPrecision(): string

转换为字符串。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
string 返回一个表示Decimal对象的字符串。

示例:

let data: Decimal = new Decimal(45.6);
let data1: string = data.toPrecision();
console.info("test Decimal toPrecision:" + data1); // 'test Decimal toPrecision:45.6'

toPrecision

toPrecision(significantDigits: number): string

转换为字符串,可按照significantDigits设置有效数字。

使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
significantDigits number 转换时保留的有效数字。

返回值:

类型 说明
string 返回一个表示Decimal对象的字符串。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200001 The value of 'significantDigits' is out of range.

示例:

let data: Decimal = new Decimal(45.6);
let data1: string = data.toPrecision(1);
console.info("test Decimal toPrecision:" + data1); // 'test Decimal toPrecision:5e+1'
data1 = data.toPrecision(5); // data1:'45.600'

toPrecision

toPrecision(significantDigits: number, rounding: Rounding): string

转换为字符串,可按照significantDigits设置有效数字,可按照rounding设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
significantDigits number 转换时保留的有效数字,取值范围为[1, 1e9]的整数。
rounding Rounding 转换时使用的舍入模式,取值范围参考Rounding

返回值:

类型 说明
string 返回一个表示Decimal对象的字符串。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200001 The value of 'significantDigits | rounding' is out of range.

示例:

let data: Decimal = new Decimal(45.6);
let data1: string = data.toPrecision(2, Decimal.ROUND_UP) // data1:'46'
data1 = data.toPrecision(2, Decimal.ROUND_DOWN) // data1:'45'

toSignificantDigits

toSignificantDigits(): Decimal

返回一个按照保留有效数字的转换的Decimal对象。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
Decimal 返回一个保留有效数字后的Decimal对象实例。

示例:

let data: Decimal = new Decimal(987.654321);
let data1: Decimal = data.toSignificantDigits();
console.info("test Decimal toSignificantDigits:" + data1.toString()); // 'test Decimal toSignificantDigits:987.654321'

toSignificantDigits

toSignificantDigits(significantDigits: number): Decimal

返回一个按照保留有效数字的转换的Decimal对象,可按照significantDigits设置有效数字。

使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
significantDigits number 转换时保留的有效数字。

返回值:

类型 说明
Decimal 返回一个保留有效数字后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200001 The value of 'significantDigits' is out of range.

示例:

let data: Decimal = new Decimal(987.654321);
let data1: Decimal = data.toSignificantDigits(6);
console.info("test Decimal toSignificantDigits:" + data1.toString()); // 'test Decimal toSignificantDigits:987.654'

toSignificantDigits

toSignificantDigits(significantDigits: number, rounding: Rounding): Decimal

返回一个按照保留有效数字的转换的Decimal对象,可按照significantDigits设置有效数字,可按照rounding设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
significantDigits number 转换时保留的有效数字,取值范围为[1, 1e9]的整数。
rounding Rounding 转换时使用的舍入模式,取值范围参考Rounding

返回值:

类型 说明
Decimal 返回一个保留有效数字后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200001 The value of 'significantDigits | rounding' is out of range.

示例:

let data: Decimal = new Decimal(987.654321);
let data1: Decimal = data.toSignificantDigits(6, Decimal.ROUND_UP);
console.info("test Decimal toSignificantDigits:" + data1.toString()); // 'test Decimal toSignificantDigits:987.655'

toNumber

toNumber(): number

转换为number类型的值。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
number 返回一个表示Decimal的number值。

示例:

let data: Decimal = new Decimal(456.789);
let data1: number = data.toNumber();
console.info("test Decimal toNumber:" + data1.toString()); // 'test Decimal toNumber:456.789'

toString

toString(): string

返回一个字符串,表示此 Decimal 的值,如果此 Decimal 的正指数等于或大于toExpPos,或负指数等于或小于toExpNeg,则将返回指数表示法。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
string 返回一个表示Decimal的字符串。

示例:

let data: Decimal = new Decimal(750000);
let data1: string = data.toString();
console.info("test Decimal toString:" + data1); // 'test Decimal toString:750000'

Decimal.set({ toExpPos: 5 })
data1 = data.toString() // data1:'7.5e+5'

let data2: Decimal = new Decimal(0.000000123)
console.info("test Decimal toString:" + data2.toString()); // 'test Decimal toString:1.23e-7'

Decimal.set({ toExpNeg: -7 })
data1 = data2.toString() // data1:'1.23e-7'

valueOf

valueOf(): string

返回一个字符串,表示此 Decimal 的值,负零包含减号。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
string 返回一个表示Decimal的字符串。

示例:

let data: Decimal = new Decimal(-0);
let data1: string = data.valueOf();
console.info("test Decimal valueOf:" + data1); // 'test Decimal valueOf:-0'

decimalPlaces

decimalPlaces(): number

返回Decimal对象的小数位数。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
number 返回Decimal对象的小数位数。

示例:

let data: Decimal = new Decimal(1.234);
let data1: number = data.decimalPlaces();
console.info("test Decimal decimalPlaces:" + data1); // 'test Decimal decimalPlaces:3'

precision

precision(): number

返回Decimal对象的有效数字位数。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
number 返回Decimal对象的有效位数。

示例:

let data: Decimal = new Decimal(1.234);
let data1: number = data.precision();
console.info("test Decimal precision:" + data1); // 'test Decimal precision:4'

precision

precision(includeZeros: boolean | number): number

返回Decimal对象的有效数字位数,通过includeZeros判断是否计算整数部分的尾随零。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
includeZeros boolean 是否计算整数部分尾随零。true表示计算整数部分尾随零,false表示不计算整数部分尾随零。

返回值:

类型 说明
number 返回Decimal对象的有效位数。

错误码:

以下错误码的详细介绍请参见语言基础类库错误码

错误码ID 错误信息
10200001 The value of includeZeros is out of range.

示例:

let data: Decimal = new Decimal(987000);
let data1: number = data.precision();
console.info("test Decimal precision:" + data1); // 'test Decimal precision:3'
data1 = data.precision(true) // data1:'6'

abs

static abs(n: Value): Decimal

返回一个新的Decimal对象,Decimal的值为参数n的绝对值。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 取绝对值的参数。

返回值:

类型 说明
Decimal 返回一个值为参数n的绝对值的Decimal。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = Decimal.abs(-0.5);
console.info("test Decimal abs:" + data.toString()); // 'test Decimal abs:0.5'

floor

static floor(n: Value): Decimal

返回一个新的Decimal对象,其值为该Decimal向负无穷方向舍入得到的结果。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 需要舍入的值。

返回值:

类型 说明
Decimal 返回舍入之后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = Decimal.floor(1.8);
console.info("test Decimal floor:" + data.toString()); // 'test Decimal floor:1'

ceil

static ceil(n: Value): Decimal

返回一个新的Decimal对象,其值为该Decimal向正无穷方向舍入得到的结果。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 需要舍入的值。

返回值:

类型 说明
Decimal 返回舍入之后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = Decimal.ceil(1.8);
console.info("test Decimal ceil:" + data.toString()); // 'test Decimal ceil:2'

trunc

static trunc(n: Value): Decimal

返回一个新的Decimal,其值是将此Decimal截断为整数部分。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 需要截断的值。

返回值:

类型 说明
Decimal 返回截断之后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = Decimal.trunc(2.5);
console.info("test Decimal trunc:" + data.toString()); // 'test Decimal trunc:2'

clamp

static clamp(n: Value, min: Value, max: Value): Decimal

返回一个值为将该Decimal的值限制在min到max范围内的Decimal对象。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 需要被限制的值。
min Value 限制的最小值。包含该值。
max Value 限制的最大值。包含该值。

返回值:

类型 说明
Decimal 返回符合范围的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码语言基础类库错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.
10200001 The value of 'min' is out of range.

示例:

let data: Decimal = Decimal.clamp(10.1, 0, 10);
console.info("test Decimal clamp:" + data.toString()); // 'test Decimal clamp:10'

add

static add(x: Value, y: Value): Decimal

返回一个值为x加y的和的Decimal对象。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
x Value 加法的一个加数。
y Value 加法的另一个加数。

返回值:

类型 说明
Decimal 返回加法运算后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = Decimal.add(0.5, 0.5);
console.info("test Decimal add:" + data.toString()); // 'test Decimal add:1'

sum

static sum(...n: Value[]): Decimal

返回一个值为数组的和的Decimal对象。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value[] 加数的序列。

返回值:

类型 说明
Decimal 返回加法运算后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = Decimal.sum(0.5, 0.5);
console.info("test Decimal sum:" + data.toString()); // 'test Decimal sum:1'

sub

static sub(x: Value, y: Value): Decimal

返回一个值为x减y的差的Decimal对象。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
x Value 减法的被减数。
y Value 减法的减数。

返回值:

类型 说明
Decimal 返回减法运算后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = Decimal.sub(1, 0.5);
console.info("test Decimal sub:" + data.toString()); // 'test Decimal sub:0.5'

mul

static mul(x: Value, y: Value): Decimal

返回一个值为x乘以y的积的Decimal对象。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
x Value 乘法的被乘数。
y Value 乘法的乘数。

返回值:

类型 说明
Decimal 返回乘法运算后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = Decimal.mul(1, 0.5);
console.info("test Decimal mul:" + data.toString()); // 'test Decimal mul:0.5'

div

static div(x: Value, y: Value): Decimal

返回一个值为x除以y的商的Decimal对象。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
x Value 除法的被除数。
y Value 除法的除数。

返回值:

类型 说明
Decimal 返回除法运算后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = Decimal.div(1, 0.5);
console.info("test Decimal div:" + data.toString()); // 'test Decimal div:2'

mod

static mod(x: Value, y: Value): Decimal

返回一个新的Decimal对象,其值是x除以y的模。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
x Value 模除运算的被除数。
y Value 模除运算的除数。

返回值:

类型 说明
Decimal 返回模除运算后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = Decimal.mod(2, 1);
console.info("test Decimal mod:" + data.toString()); // 'test Decimal mod:0'

sqrt

static sqrt(n: Value): Decimal

返回一个值为n的平方根的Decimal对象。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 取平方根的值。

返回值:

类型 说明
Decimal 返回平方根运算后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = Decimal.sqrt(3);
console.info("test Decimal sqrt:" + data.toString()); // 'test Decimal sqrt:1.7320508075688772935'

cbrt

static cbrt(n: Value): Decimal

返回一个值为n的立方根的Decimal对象。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 取立方根的值。

返回值:

类型 说明
Decimal 返回立方根运算后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = Decimal.cbrt(3);
console.info("test Decimal cbrt:" + data.toString()); // 'test Decimal cbrt:1.4422495703074083823'

pow

static pow(base: Value, exponent: Value): Decimal

返回一个值为base的exponent次幂的Decimal对象,按照DecimalConfig.precision设置有效位数,按照DecimalConfig.rounding设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
base Value 幂运算的底数的值。
exponent Value 幂运算的幂的值。

返回值:

类型 说明
Decimal 返回幂运算后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码语言基础类库错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.
10200060 Precision limit exceeded.

示例:

let data: Decimal = Decimal.pow(3, -2);
console.info("test Decimal pow:" + data.toString()); // 'test Decimal pow:0.11111111111111111111'

exp

static exp(n: Value): Decimal

返回一个值为n的自然指数的Decimal对象。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 需要求自然指数的值。

返回值:

类型 说明
Decimal 返回自然指数运算后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码语言基础类库错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.
10200060 Precision limit exceeded.

示例:

let data: Decimal = Decimal.exp(2);
console.info("test Decimal exp:" + data.toString()); // 'test Decimal exp:7.3890560989306502272'

log

static log(n: Value, base: Value): Decimal

返回一个值为以base为底n的对数的Decimal对象。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 对数运算的真数。
base Value 对数运算的底。

返回值:

类型 说明
Decimal 返回对数运算后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码语言基础类库错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.
10200060 Precision limit exceeded.

示例:

let data: Decimal = Decimal.log(2, 256);
console.info("test Decimal log:" + data.toString()); // 'test Decimal log:0.125'

ln

static ln(n: Value): Decimal

返回一个值为n的自然对数的Decimal对象。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 对数运算的真数。

返回值:

类型 说明
Decimal 返回自然对数运算后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码语言基础类库错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.
10200060 Precision limit exceeded.

示例:

let data: Decimal = Decimal.ln(1.23e+30);
console.info("test Decimal ln:" + data.toString()); // 'test Decimal ln:69.284566959205696648'

log2

static log2(n: Value): Decimal

返回一个值为以2为底n的对数的Decimal对象。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 对数运算的真数。

返回值:

类型 说明
Decimal 返回以2为底的对数运算后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码语言基础类库错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.
10200060 Precision limit exceeded.

示例:

let data: Decimal = Decimal.log2(4);
console.info("test Decimal log2:" + data.toString()); // 'test Decimal log2:2'

log10

static log10(n: Value): Decimal

返回一个值为以10为底n的对数的Decimal对象。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 对数运算的真数。

返回值:

类型 说明
Decimal 返回以10为底的对数运算后的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码语言基础类库错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.
10200060 Precision limit exceeded.

示例:

let data: Decimal = Decimal.log10(10000);
console.info("test Decimal log10:" + data.toString()); // 'test Decimal log10:4'

cos

static cos(n: Value): Decimal

返回一个新的Decimal,其值是n的余弦值。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 要求余弦值的值。

返回值:

类型 说明
Decimal 返回n的余弦值对应的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = Decimal.cos(-0.25);
console.info("test Decimal cos:" + data.toString()); // 'test Decimal cos:0.96891242171064478414'

sin

static sin(n: Value): Decimal

返回一个新的Decimal,其值是n的正弦值。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 要求正弦值的值。

返回值:

类型 说明
Decimal 返回n的正弦值对应的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = Decimal.sin(0.75);
console.info("test Decimal sin:" + data.toString()); // 'test Decimal sin:0.68163876002333416673'

tan

static tan(n: Value): Decimal

返回一个新的Decimal,其值是n的正切值。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 要求正切值的值。

返回值:

类型 说明
Decimal 返回n的正切值对应的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = Decimal.tan(0.75);
console.info("test Decimal tan:" + data.toString()); // 'test Decimal tan:0.93159645994407246117'

cosh

static cosh(n: Value): Decimal

返回一个新的Decimal,其值是n的双曲余弦值。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 需要求双曲余弦值的值。

返回值:

类型 说明
Decimal 返回n的双曲余弦值对应的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = Decimal.cosh(0.5);
console.info("test Decimal cosh:" + data.toString()); // 'test Decimal cosh:1.1276259652063807852'

sinh

static sinh(n: Value): Decimal

返回一个新的Decimal,其值是n的双曲正弦值。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 需要求双曲正弦值的值。

返回值:

类型 说明
Decimal 返回n的双曲正弦值对应的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = Decimal.sinh(0.5);
console.info("test Decimal sinh:" + data.toString()); // 'test Decimal sinh:0.52109530549374736162'

tanh

static tanh(n: Value): Decimal

返回一个新的Decimal,其值是n的双曲正切值。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 需要求双曲正切值的值。

返回值:

类型 说明
Decimal 返回n的双曲正切值对应的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = Decimal.tanh(0.5);
console.info("test Decimal tanh:" + data.toString()); // 'test Decimal tanh:0.4621171572600097585'

acos

static acos(n: Value): Decimal

返回一个新的Decimal,其值是n的反余弦值。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 需要求反余弦值的值。

返回值:

类型 说明
Decimal 返回n的反余弦值对应的Decimal对象实例。

错误码

以下错误码的详细介绍请参见通用错误码语言基础类库错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.
10200060 Precision limit exceeded.

示例:

let data: Decimal = Decimal.acos(0.5);
console.info("test Decimal acos:" + data.toString()); // 'test Decimal acos:1.0471975511965977462'

asin

static asin(n: Value): Decimal

返回一个新的Decimal,其值是n的反正弦值。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 需要求反正弦值的值。

返回值:

类型 说明
Decimal 返回n的反正弦值对应的Decimal对象实例。

错误码

以下错误码的详细介绍请参见通用错误码语言基础类库错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.
10200060 Precision limit exceeded.

示例:

let data: Decimal = Decimal.asin(0.75);
console.info("test Decimal asin:" + data.toString()); // 'test Decimal asin:0.84806207898148100805'

atan

static atan(n: Value): Decimal

返回一个新的Decimal,其值是n的反正切值。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 需要求反正切值的值。

返回值:

类型 说明
Decimal 返回n的反正切值对应的Decimal对象实例。

错误码

以下错误码的详细介绍请参见通用错误码语言基础类库错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.
10200060 Precision limit exceeded.

示例:

let data: Decimal = Decimal.atan(0.75);
console.info("test Decimal atan:" + data.toString()); // 'test Decimal atan:0.6435011087932843868'

acosh

static acosh(n: Value): Decimal

返回一个新的Decimal,其值是n的双曲余弦值的倒数。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 需要求双曲余弦的倒数的值。

返回值:

类型 说明
Decimal 返回n的双曲余弦的倒数对应的Decimal对象实例。

错误码

以下错误码的详细介绍请参见通用错误码语言基础类库错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.
10200060 Precision limit exceeded.

示例:

let data: Decimal = Decimal.acosh(50);
console.info("test Decimal acosh:" + data.toString()); // 'test Decimal acosh:4.6050701709847571595'

asinh

static asinh(n: Value): Decimal

返回一个新的Decimal,其值是n的双曲正弦值的倒数。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 需要求双曲正弦的倒数的值。

返回值:

类型 说明
Decimal 返回n的双曲正弦的倒数对应的Decimal对象实例。

错误码

以下错误码的详细介绍请参见通用错误码语言基础类库错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.
10200060 Precision limit exceeded.

示例:

let data: Decimal = Decimal.asinh(50);
console.info("test Decimal asinh:" + data.toString()); // 'test Decimal asinh:4.6052701709914238266'

atanh

static atanh(n: Value): Decimal

返回一个新的Decimal,其值是n的双曲正切值的倒数。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 需要求双曲正切的倒数的值。

返回值:

类型 说明
Decimal 返回n的双曲正切的倒数对应的Decimal对象实例。

错误码

以下错误码的详细介绍请参见通用错误码语言基础类库错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.
10200060 Precision limit exceeded.

示例:

let data: Decimal = Decimal.atanh(0.75);
console.info("test Decimal atanh:" + data.toString()); // 'test Decimal atanh:0.97295507452765665255'

atan2

static atan2(y: Value, x: Value): Decimal

返回一个新的Decimal,其值是为-π到π范围内的y/x反正切值。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
y Value 除法的被除数。
x Value 除法的除数。

返回值:

类型 说明
Decimal 返回-pi 到 pi 范围内的"y/x"反正切值对应的Decimal对象实例。

错误码

以下错误码的详细介绍请参见通用错误码语言基础类库错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.
10200060 Precision limit exceeded.

示例:

let data: Decimal = Decimal.atan2(2, 3);
console.info("test Decimal atan2:" + data.toString()); // 'test Decimal atan2:0.58800260354756755125'

hypot

static hypot(...n: Value[]): Decimal

返回一个新的Decimal,其值为参数平方和的平方根。

使用DecimalConfig.precision的值进行有效数字的保留,使用DecimalConfig.rounding的值设置舍入模式。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value[] 需要求平方和的序列。

返回值:

类型 说明
Decimal 返回值为所有参数平方和的平方根的Decimal对象实例。

错误码

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = Decimal.hypot(2, 3, 4);
console.info("test Decimal hypot:" + data.toString()); // 'test Decimal hypot:5.3851648071345040313'

max

static max(...n: Value[]): Decimal

返回一个值为所有参数中最大值的Decimal对象。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value[] 需要求最大值的序列。

返回值:

类型 说明
Decimal 返回所有参数中的最大值的Decimal对象实例。

错误码

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = Decimal.max(2, 3, 4);
console.info("test Decimal max:" + data.toString()); // 'test Decimal max:4'

min

static min(...n: Value[]): Decimal

返回一个值为所有参数中最小值的Decimal对象。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value[] 需要求最小值的序列。

返回值:

类型 说明
Decimal 返回所有参数中的最小值的Decimal对象实例。

错误码

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: Decimal = Decimal.min(2, 3, 4);
console.info("test Decimal min:" + data.toString()); // 'test Decimal min:2'

random

static random(): Decimal

返回一个值为大于等于0小于1的随机值的Decimal对象。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

返回值:

类型 说明
Decimal 大于等于0小于1的随机值的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码语言基础类库错误码

错误码ID 错误信息
10200061 Crypto unavailable.

示例:

let data: Decimal = Decimal.random();

random

static random(significantDigits: number): Decimal

返回一个值为大于等于0小于1的随机值的Decimal对象,随机值保留significantDigits位有效数字。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
significantDigits number 随机值保留的有效数字。

返回值:

类型 说明
Decimal 大于等于0小于1的随机值的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码语言基础类库错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.
10200061 Crypto unavailable.

示例:

let data: Decimal = Decimal.random(20);

sign

static sign(n: Value): number

根据参数的值进行判断返回对应的值:当n>0返回1,当n<0返回-1,当n==0返回0,当n==-0返回-0,否则返回NaN。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 需要判断的值。

返回值:

类型 说明
number 根据参数的值进行判断返回对应的值。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let data: number = Decimal.sign(2);
console.info("test Decimal sign:" + data); // 'test Decimal sign:1'

round

static round(n: Value): Decimal

返回一个新的Decimal,其值是使用DecimalConfig.rounding模式舍入为整数的n。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
n Value 需要舍入的值。

返回值:

类型 说明
Decimal 返回舍入之后的整数对应的Decimal对象实例。

错误码:

以下错误码的详细介绍请参见通用错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.

示例:

let x = 3.3333333333333;
let data = Decimal.round(x);
console.info("test Decimal round:" + data.toString()); // 'test Decimal round:3'

set

static set(object: DecimalConfig):void

用于设置Decimal的配置属性,通过set设置的属性是全局生效的。

原子化服务API:从API version 12 开始,该接口支持在原子化服务中使用。

系统能力:SystemCapability.Utils.Lang

参数:

参数名 类型 必填 说明
object DecimalConfig 需要配置的属性集合。

错误码:

以下错误码的详细介绍请参见通用错误码语言基础类库错误码

错误码ID 错误信息
401 Parameter error. Possible causes:1. Incorrect parameter types;2. Parameter verification failed.
10200001 The value of 'DecimalConfig.properties' is out of range.
10200061 Crypto unavailable.

示例1:

let data : Decimal = new Decimal(1.2345678901234567);
Decimal.set({
    precision: 5,
    rounding: 4,
    toExpNeg: -7,
    toExpPos: 7,
    maxE: 9e15,
    minE: -9e15,
    modulo: 1,
    crypto: false
})
let data1 : Decimal = data.add(0.5);
console.info("test Decimal set:" + data1.toString()); // "test Decimal set:1.7346"
// 将配置属性全部设置为默认值
Decimal.set({ defaults: true })
let data2 : Decimal = data.add(0.5);
console.info("test Decimal set:" + data2.toString()); // "test Decimal set:1.7345678901234567"
// 最大有效位数设置为10,其余配置属性设置为默认值
Decimal.set({ precision: 10, defaults: true })
let data3 : Decimal = data.add(0.5);
console.info("test Decimal set:" + data3.toString()); // "test Decimal set:1.73456789"

// toExpNeg和toExpPos的用法
Decimal.set({ toExpNeg: -7 })
let x0 : Decimal = new Decimal(0.00000123) // x0:'0.00000123'
let x1 : Decimal = new Decimal(0.000000123) // x1:'1.23e-7'

Decimal.set({ toExpPos: 2 })
let y0 : Decimal = new Decimal(12.3) // y0:'12.3'
let y1 : Decimal = new Decimal(123) // y1:'1.23e+2'

// 所有数据均使用科学计数法表示
Decimal.set({ toExpPos: 0 })

// minE和maxE的用法
Decimal.set({ minE: -500 })
let a0 : Decimal = new Decimal('1e-500') // a0:'1e-500'
let a1 : Decimal = new Decimal('9.9e-501') // a1:'0e0'

Decimal.set({ minE: -3 })
let b0 : Decimal = new Decimal(0.001) // b0:'0.001'
let b1 : Decimal = new Decimal(0.0001) // b1:'0e0'

Decimal.set({ maxE: 500 })
let c0 : Decimal = new Decimal('9.999e500') // c0:'9.999e+500'
let c1 : Decimal = new Decimal('1e501') // c1:'Infinity'

Decimal.set({ maxE: 4 })
let d0 : Decimal = new Decimal(99999) // d0:'9.9999e+4'
let d1 : Decimal = new Decimal(100000) // d1:'Infinity'

示例2:

// /entry/src/main/ets/pages/test.ets
export function test(){
  let data : Decimal = new Decimal(1.2345678901234567);
  Decimal.set({
    precision: 5,
    rounding: 0,
    toExpNeg: -7,
    toExpPos: 7,
    maxE: 9e15,
    minE: -9e15,
    modulo: 1,
    crypto: false
  })
  let data1 : Decimal = data.add(0.5);
  console.info("test Decimal set:" + data1.toString()); // 'test Decimal set:1.7346'
}
// /entry/src/main/ets/pages/Index.ets
import {test} from './test'

let data : Decimal = new Decimal(1.2345678901234567);
Decimal.set({
  precision: 6,
  rounding: 1,
  toExpNeg: -7,
  toExpPos: 7,
  maxE: 9e15,
  minE: -9e15,
  modulo: 1,
  crypto: false
})
let data1 : Decimal = data.add(0.5);
console.info("test Decimal set:" + data1.toString()); // 'test Decimal set:1.73456'
test();
data1 = data1.add(0); // data1:'1.7346'
console.info("test Decimal set:" + data1.toString()); // 'test Decimal set:1.7346'