本文由 - 翻译自 。欢迎加入。转载请参见文章末尾处的要求。
我对用户的输入做加密,以生成密码字符串。但是其中一行代码在不同的框架下给出了不同的结果。这是含有用户按键的值的部分代码。
按键:1。变量ascii码是49。计算后’e’和’n’的值:
1 2 3 4 | e = 103, n = 143, Math.Pow(ascii, e) % n |
上述代码的结果:
在.NET3.5(C#)
1 | Math.Pow(ascii, e) % n |
值是9.0
在.NET4(C#)
1 | Math.Pow(ascii, e) % n |
值是77.0
Math.Pow()在两个版本中给出了正确的(相同的)的结果。
这是什么原因造成的,或者有解决办法吗?
最佳回答:
是针对双精度浮点型数值的;因此,你不应期望超过结果是准确无误的:
所有的浮点型数值也有一个有限的有效位数,这个位数也决定了浮点型值是如何如实地接近真实值。一个双精度值有多达15位的十进制精度,但内部支持最多17位数。
但是,模运算需要所有的数位都是精确的。在你的程序中,你计算了49103,这个结果由175位数组成,使得模运算在你的答案中都没有意义。
为了计算出正确的值,你应该使用高精度计算,这由类提供(.NET 4.0引入)。
编辑修正:正如下面评论中Mark Peters指出的,你应该使用方法, 它正是用来处理这类运算的:
1 | int val = ( int )BigInteger.ModPow(49, 103, 143); // gives 114 |
原文链接: 翻译: -
译文链接: