salesforce 零基础学习(四十三)运算取余

工作中遇到一个简单的小问题,判断两个数是否整除,如果不整除,获取相关的余数。

习惯java的我毫不犹豫的写下了代码

public Boolean isDivisibility(Integer dividend,Integer divider) {
    return dividend % divider == 0;    
}

提交代码发现竟然提交不上??

后来查看API发现apex中没有直接的%取余运算,所以如果想要取余以及判断是否整除需要其他方式,代码如下:

public without sharing class MathHelper {
    
    /*
        是否整除
        @param dividend 被除数
        @param divider  除数
        @return 整除返回true,不整除返回false
    */
    public static Boolean isDivisibility(Integer dividend,Integer divider) {
        //先将被除数转换成Decimal,否则先计算整数除法结果为Integer类型,然后将整数转换成Decimal
        Decimal resultDecimal = Decimal.valueOf(dividend) / divider;
        //获取结果上线
        Integer resultSeiling = Integer.valueOf(resultDecimal.round(System.RoundingMode.CEILING));
        Integer resultDown = Integer.valueOf(resultDecimal.round(System.RoundingMode.DOWN));
        
        return resultSeiling == resultDown;
    }
    
    /*
        获取余数
        @param dividend 被除数
        @param divider  除数
        @return 返回余数
    */
    public static Integer getRemainder(Integer dividend,Integer divider) {
        Decimal resultDecimal = Decimal.valueOf(dividend) / divider;
        Integer resultDown = Integer.valueOf(resultDecimal.round(System.RoundingMode.DOWN));
        return dividend - resultDown * divider;
    } 
}

调用结果显示:

通过上述代码可以看出,我们运算的主要方式为将被除数转换成Decimal类型,除以除数得到Decimal类型的余数,通过取舍规则获取他的上限值和下限值,如果上限和下限相等,则整除,否则不整除。

这里我们主要用到的是取舍模式。System.RoundingMode包含以下常用的取值:

UP:简单的说,UP是对decimal值进行绝对值向上取,符号不变化。

    1.    5.5通过RoundingMode.UP操作以后变成了6;

    2.    -1.5通过RoundingMode.UP操作以后变成了-2;

DOWN:简单的说,DOWN是对decimal值进行绝对值向下取,符号不变化。

    1.    5.5通过RoundingMode.DOWN操作以后变成了5;

    2.    -1.5通过RoundingMode.DOWN操作以后变成了-1;

CELLING:对于正数,CELLING操作和UP操作相同,对于负数,操作和DOWN操作相同。

    1.    5.5通过RoundingMode.CELLING操作以后变成了6;

    2.    -1.5通过RoundingMode.CELLING操作以后变成了-1;

FLOOR:对于正数,FLOOR操作和DOWN操作相同,对于负数,操作和UP操作相同。

    1.    5.5通过RoundingMode.FLOOR操作以后变成了5;

    2.    -1.5通过RoundingMode.FLOOR操作以后变成了-2;

HALF_UP:小数点部分大于等于0.5,绝对值向上取,符号跟随。

1.    5.5通过RoundingMode.FLOOR操作以后变成了6;

    2.    5.1通过RoundingMode.FLOOR操作以后变成了5,因为0.1<0.5;

    3.    -1.5通过RoundingMode.FLOOR操作以后变成了-2;

    4.    -1.1通过RoundingMode.FLOOR操作以后变成了-1;

HALF_DOWN:小数点部分大于0.5,绝对值向上取,符号跟随。

    1.    5.5通过RoundingMode.FLOOR操作以后变成了5;

    2.    5.7通过RoundingMode.FLOOR操作以后变成了6,因为0.7>0.5;

    3.    -1.5通过RoundingMode.FLOOR操作以后变成了-1;

    4.    -1.7通过RoundingMode.FLOOR操作以后变成了-2;

总结:本篇主要描述两个整数是否整除并且获取余数的方法以及取舍模式的几个值得概念以及定义,详情了解请自行查看官方API文档,有错误的地方欢迎指正,有问题欢迎留言。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏菩提树下的杨过

Flash/Flex学习笔记(32):播放音乐并同步显示lyc歌词(适用于Silverlight)

题外话:个别朋友总是问我同样的问题,做为一名c#/silverlight程序员为啥还要学flash ? 回 答:看日本片时,就不能对照看欧美的么? 不体会日本的...

1787
来自专栏Hadoop实操

Hive使用十六进制分隔符异常分析

通过sqoop抽取Mysql表数据到hive表,发现hive表所有列显示为null

68611
来自专栏个人分享

Hive metastore整体代码分析及详解

  从上一篇对Hive metastore表结构的简要分析中,我再根据数据设计的实体对象,再进行整个代码结构的总结。那么我们先打开metadata的目录,其目录...

1683
来自专栏菩提树下的杨过

.NET:Entity Framework 笔记

有二年没关注EF,今天无意试了下发现跟主流的Hibernate等ORM框架越来越接近了,先看下Entity类的定义: using System; using S...

1978
来自专栏码匠的流水账

聊聊spring cloud的RequestHeaderToRequestUriGatewayFilter

本文主要研究一下spring cloud的RequestHeaderToRequestUriGatewayFilter

531
来自专栏yukong的小专栏

【ssm个人博客项目实战04】mybatis实现博客类别的增删改查分页

在前面一节我们已经完成后台管理界面的一个实现,在这一节我完成其中的博客类别管理中如果分页显示博客类别信息。

985
来自专栏向治洪

AndFix使用感想

AndFix已经使用了一段时间了,但是到AndFix上看了一下,最近2个月都没有更新代码了,有141个issues和3个pull request没人处理,其...

2006
来自专栏乐沙弥的世界

对比 PL/SQL profiler 剖析结果

      使用PL/SQL PROFILER 剖析PL/SQL代码是快速定位PL/SQL代码段最有效的方法。在上一篇文章使用PL/SQL PROFILER 定...

831
来自专栏Vamei实验室

安卓第七夜 雅典学院

我之前只使用了一种持续保存数据的方法,即SharedPreferences。然而,SharedPreferences只能存储少量松散的数据,并不适合大量数据的存...

1838
来自专栏landv

vb.net_一个半成品

1534

扫码关注云+社区