詳解.NET 4.0 Beta2的Complex和BigInteger類
本文將介紹的是.NET 4.0 Beta2中的Complex和BigInteger類,BigInteger類主要用途在于對不同數(shù)據(jù)的處理。希望對大家有所幫助。
.NET4.0 Beta2中提供了新的System.Numerics命名空間,對應(yīng)于System.Numerics.dll。該命名空間下就兩個類BigInteger和Complex,我們來簡單了解下這兩個類的用法。
BigInteger:任意大小的帶符號整數(shù)
1.Int64, SByte, UInt16, UInt32, and UInt64這些都有一個MinValue和MaxValue屬性。而BigInteger沒有這兩個屬性,因為它沒有大小限制。2.不可變的類型.3.由于他沒有大小限制,理論上當它足夠大的時候會出現(xiàn)OutOfMemoryException異常.
BigInteger類初始化
1.我們可以使用已有的數(shù)據(jù)類型來初始化BigInteger,如下:
- BigInteger bigIntFromDouble = new BigInteger(179032.6541);//會截取小點前的
- BigInteger bigIntFromInt64 = new BigInteger(934157136952);
2.我們也可以使用超出現(xiàn)有數(shù)據(jù)類型范圍的方式來得到BigInteger:
- byte[] bytes = { 5, 4, 3, 2, 1 };
- BigInteger number = new BigInteger(bytes);
- Console.WriteLine("The value of number is {0} (or 0x{0:x}).", number);
- //The value of number is 4328719365 (or 0x102030405).
字節(jié)數(shù)組的第一個元素為16進制的最低位,依次升高.3.可以使用Parse或 TryParse方法將string的實例化為BigInteger:
- string positiveString = "91389681247993671255432112000000";
- string negativeString = "-90315837410896312071002088037140000";
- BigInteger posBigInt = 0;
- BigInteger negBigInt = 0;
- posBigInt = BigInteger.Parse(positiveString);
- Console.WriteLine(posBigInt);
- BigInteger.TryParse(negativeString, out negBigInt);
- Console.WriteLine(negBigInt);
4. 還可以使用靜態(tài)方法Pow如下:
- BigInteger number = BigInteger.Pow(Int64.MaxValue, 3);
BigInteger支持所有的數(shù)學(xué)運算,我們可以完全象使用其他整數(shù)類型一樣使用BigInteger
Complex復(fù)數(shù)類
- 1.var z1 = new Complex(); // this creates complex zero (0, 0)
- var z2 = new Complex(2, 4);
- var z3 = new Complex(3, 5);
- Console.WriteLine("Complex zero: " + z1);
- Console.WriteLine(z2 + " + " + z3 + " = " + (z2 + z3));
- Console.WriteLine("|z2| = " + z2.Magnitude);
- Console.WriteLine("Phase of z2 = " + z2.Phase);
2.我們可以使用一個ComplexFormatter類來輔助我們做格式化輸出,如下:
- using System;
- using System.Numerics;
- public class ComplexFormatter :IFormatProvider, ICustomFormatter
- {
- public object GetFormat(Type formatType)
- {
- if (formatType == typeof(ICustomFormatter))
- return this;
- else
- return null;
- }
- public string Format(string format, object arg,
- IFormatProvider provider)
- {
- if (arg is Complex)
- {
- Complex c1 = (Complex) arg;
- // Check if the format string has a precision specifier.
- int precision;
- string fmtString = String.Empty;
- if (format.Length > 1) {
- try {
- precision = Int32.Parse(format.Substring(1));
- }
- catch (FormatException) {
- precision = 0;
- }
- fmtString = "N" + precision.ToString();
- }
- if (format.Substring(0, 1).Equals("I", StringComparison.OrdinalIgnoreCase))
- return c1.Real.ToString("N2") + " + " + c1.Imaginary.ToString("N2") + "i";
- else if (format.Substring(0, 1).Equals("J", StringComparison.OrdinalIgnoreCase))
- return c1.Real.ToString("N2") + " + " + c1.Imaginary.ToString("N2") + "j";
- else
- return c1.ToString(format, provider);
- }
- else
- {
- if (arg is IFormattable)
- return ((IFormattable) arg).ToString(format, provider);
- else if (arg != null)
- return arg.ToString();
- else
- return String.Empty;
- }
- }
- }
3.使用如下:
- Complex c1 = new Complex(12.1, 15.4);
- Console.WriteLine("Formatting with ToString():" + c1.ToString());
- Console.WriteLine("Formatting with ToString(format): " + c1.ToString("N2"));
- Console.WriteLine("Custom formatting with I0:" + String.Format(new ComplexFormatter(), "{0:I0}", c1));
- Console.WriteLine("Custom formatting with J3:" + String.Format(new ComplexFormatter(), "{0:J3}", c1));
原文標題:.NET 4.0 Beta2中的BigInteger和Complex類
鏈接:http://www.cnblogs.com/carysun/archive/2009/10/25/Numerics-BigIntegerComplex.html
【編輯推薦】