前言
取余和取模的差别就在于取整的方法,取余是向0的方向舍入,取模的时候正的向无穷小(或负的向负无穷大)的方向舍入。
一、取余
对A和B取余操作:A % B
C = A / B
R(计算结果) = A - C * B
取余时:C 值向0靠近取整,比如:
C = A / B = (float)5 / 3 = 1.666666 靠近0取整,则C取 1 ,则R = A - C * B = 2
C = A / B = (float)-7 / 2 = -3.5 ,靠近0取整,则C取-3,则R = A - C * B = -1
二、取模
取模时:C 值向无穷小(或负无穷大)处取整,比如:
C = A / B = (float)5 / 3 = 1.666666,向无穷小处取整,则C取1,则R = A - C * B = 2
C = A / B = (float)-7 / 2 = -3.5 ,向负无穷大处取整,则C取-4,则R = A - C * B = 1
总结
1.当两个数的符号相同,即同为负或者同为正时,取余和取模结果相同,因为C偏向同一个方向取值,使得C值一样。
2.符号不同时,取余结果的符号和被除数一致,取模结果的符号和除数一致。
3.%号在Java中计算负数时是取余而不是取模,如果要对负数取模,要用Math.floorMod( )方法。