BigInteger.ToString() returns more than 50 decimal

2019-08-10 14:11发布

I'm using .NET 4 System.Numerics.BigInteger Structure and I'm getting results different from the documentation.

In the documentation of BigInteger.ToString() Method It says:

The ToString() method supports 50 decimal digits of precision. That is, if the BigInteger value has more than 50 digits, only the 50 most significant digits are preserved in the output string; all other digits are replaced with zeros.

I have some code that takes a 60 decimal digits BigInteger and converts it to a string. The 60 significant decimal digits string didn't lose any significant digits:

const string vString = "123456789012345678901234567890123456789012345678901234567890";
Assert.AreEqual(60, vString.Length);
BigInteger v = BigInteger.Parse(vString);
Assert.AreEqual(60, v.ToString().Length);
Assert.AreEqual('9', v.ToString()[58]);
Assert.AreEqual('1', v.ToString()[0]);
Assert.AreEqual(vString, v.ToString());
Assert.AreEqual(vString, v.ToString("G"));

All the asserts pass.

What exactly does the quoted part of the documentation mean?

1条回答
何必那么认真
2楼-- · 2019-08-10 15:07

The documentation is a little unclear here, this limit only applies when formatting the string, for example:

v.ToString("0"); "123456789012345678901234567890123456789012345678900000000000"
v.ToString("n0"); "123,456,789,012,345,678,901,234,567,890,123,456,789,012,345,678,900,000,000,000"

The exception is formatting it as "R", which gives the original round-tripped value:

v.ToString("R"); "123456789012345678901234567890123456789012345678901234567891"
查看更多
登录 后发表回答