BitConverter.ToDouble()方法用於返回雙精度浮點數,該浮點數從字節數組中指定位置的八個字節轉換而來。
用法:
public static double ToDouble (byte[] value, int startIndex);
參數:
-
value:它是一個字節數組。
startIndex:它是值中的起始位置。
返回值:此方法返回一個雙精度浮點數,該數由以startIndex開始的八個字節組成。
異常:
- ArgumentException:如果startIndex大於或等於值的長度減去7,並且小於或等於值的長度減去1。
- ArgumentNullException:如果值為空。
- ArgumentOutOfRangeException:如果startIndex小於零或大於值的長度減1。
以下示例程序旨在說明BitConverter.ToDouble(Byte [],Int32)方法的用法:
示例1:
// C# program to demonstrate
// BitConverter.ToDouble(Byte[], Int32)
// Method
using System;
class GFG {
// Main Method
public static void Main()
{
try {
// Define an array of byte values.
byte[] bytes = {0,0,1,2,7,126,78,55,
255,78,45,198,200,1,
1,1,1,255,255,2,4,4,
77,77,77,77,77,0,1};
// Display the values of the myArr.
Console.WriteLine("Initial Array: ");
// calling the PrintIndexAndValues()
// method to print
PrintIndexAndValues(bytes);
// print char value
Console.WriteLine("index Array elements "+
" double values");
Console.WriteLine();
// getting double value and Display it
for (int index = 0; index < bytes.Length - 7;
index = index + 8) {
double values = BitConverter.ToDouble(bytes, index);
Console.WriteLine(" {0} {1} {2}",
index, BitConverter.ToString(bytes,
index, 8), values);
}
}
catch (ArgumentNullException e) {
Console.Write("Exception Thrown: ");
Console.Write("{0}", e.GetType(), e.Message);
}
catch (ArgumentOutOfRangeException e) {
Console.Write("Exception Thrown: ");
Console.Write("{0}", e.GetType(), e.Message);
}
catch (ArgumentException e) {
Console.Write("Exception Thrown: ");
Console.Write("{0}", e.GetType(), e.Message);
}
}
// Defining the method
// PrintIndexAndValues
public static void PrintIndexAndValues(byte[] myArr)
{
int count = 0;
for (int i = 0; i < myArr.Length; i++) {
if (count == 18) {
Console.WriteLine();
Console.Write("{0} ", myArr[i]);
count = 0;
}
else {
Console.Write("{0} ", myArr[i]);
count++;
}
}
Console.WriteLine();
Console.WriteLine();
}
}
輸出:
Initial Array: 0 0 1 2 7 126 78 55 255 78 45 198 200 1 1 1 1 255 255 2 4 4 77 77 77 77 77 0 1 index Array elements double values 0 00-00-01-02-07-7E-4E-37 2.73464354303054E-42 8 FF-4E-2D-C6-C8-01-01-01 7.74999325882041E-304 16 01-FF-FF-02-04-04-4D-4D 2.38727219494443E+64
示例2:對於ArgumentException
// C# program to demonstrate
// BitConverter.ToDouble(Byte[], Int32)
// Method
using System;
class GFG {
// Main Method
public static void Main()
{
try {
// Define an array of byte values.
byte[] bytes = {0,0,1,2,7,126,78,55,
255,78,45,198,200,1,
1,1,1,255,255,2,4,4,
77,77,77,77,77,0,1,
0,0,1,2,7,126,78,55,
255,78,45,198,200,1,
1,1,1,255,255,2,4,4,
255,255,255,255,245,
245,245,245,245,245,
245,245,245,245,0,0,
0,0,0,0,0,0,6,5,6,56,
31,31,31,54,23,253,};
// Display the values of the myArr.
Console.WriteLine("Initial Array: ");
// calling the PrintIndexAndValues()
// method to print
PrintIndexAndValues(bytes);
// print char value
Console.WriteLine("index Array elements"+
" double values");
Console.WriteLine();
// getting double value and Display it
for (int index = 4; index < bytes.Length - 6;
index = index + 8) {
if (index == bytes.Length - 7) {
Console.WriteLine();
Console.WriteLine("startIndex is equal to"+
" the length of bytes minus 7");
double values = BitConverter.ToDouble(bytes, index);
Console.WriteLine(" {0} {1} {2}",
index, BitConverter.ToString(bytes,
index, 4), values);
}
else {
double values = BitConverter.ToDouble(bytes, index);
Console.WriteLine(" {0} {1} {2}",
index, BitConverter.ToString(bytes, index,
8), values);
}
}
}
catch (ArgumentNullException e) {
Console.Write("Exception Thrown: ");
Console.Write("{0}", e.GetType(), e.Message);
}
catch (ArgumentOutOfRangeException e) {
Console.Write("Exception Thrown: ");
Console.Write("{0}", e.GetType(), e.Message);
}
catch (ArgumentException e) {
Console.Write("Exception Thrown: ");
Console.Write("{0}", e.GetType(), e.Message);
}
}
// Defining the method
// PrintIndexAndValues
public static void PrintIndexAndValues(byte[] myArr)
{
int count = 0;
for (int i = 0; i < myArr.Length; i++) {
if (count == 18) {
Console.WriteLine();
Console.Write("{0} ", myArr[i]);
count = 0;
}
else {
Console.Write("{0} ", myArr[i]);
count++;
}
}
Console.WriteLine();
Console.WriteLine();
}
}
輸出:
Initial Array: 0 0 1 2 7 126 78 55 255 78 45 198 200 1 1 1 1 255 255 2 4 4 77 77 77 77 77 0 1 0 0 1 2 7 126 78 55 255 78 45 198 200 1 1 1 1 255 255 2 4 4 255 255 255 255 245 245 245 245 245 245 245 245 245 245 0 0 0 0 0 0 0 0 6 5 6 56 31 31 31 54 23 253 index Array elements double values 4 07-7E-4E-37-FF-4E-2D-C6 -1.16103254047091E+30 12 C8-01-01-01-01-FF-FF-02 3.13113229681351E-294 20 04-04-4D-4D-4D-4D-4D-00 3.25995134720157E-307 28 01-00-00-01-02-07-7E-4E 1.29525825666467E+70 36 37-FF-4E-2D-C6-C8-01-01 8.10420695824091E-304 44 01-01-FF-FF-02-04-04-FF -6.86302832487538E+303 52 FF-FF-FF-F5-F5-F5-F5-F5 -1.68827860814431E+260 60 F5-F5-F5-F5-F5-00-00-00 5.21927749055768E-312 68 00-00-00-00-00-06-05-06 1.15818454395586E-279 startIndex is equal to the length of bytes minus 7 Exception Thrown: System.ArgumentException
示例3:對於ArgumentOutOfRangeException
// C# program to demonstrate
// BitConverter.ToDouble(Byte[], Int32)
// Method
using System;
class GFG {
// Main Method
public static void Main()
{
try {
// Define an array of byte values.
byte[] bytes = {0,0,1,2,7,126,78,55,
255,78,45,198,200,1,
1,1,1,255,255,2,4,4,
77,77,77,77,77,0,1,
0,0,1,2,7,126,78,55,
255,78,45,198,200,1,
1,1,1,255,255,2,4,4,
255,255,255,255,245,
245,245,245,245,245,
245,245,245,245,0,0,
0,0,0,0,0,0,6,5,6,56,
31,31,31,54,23,253,};
// Display the values of the myArr.
Console.WriteLine("Initial Array: ");
// calling the PrintIndexAndValues()
// method to print
PrintIndexAndValues(bytes);
// getting double value and Display it
Console.WriteLine("startIndex is less than zero");
double values = BitConverter.ToDouble(bytes, -1);
Console.WriteLine(" {0} {1} {2}", -1,
BitConverter.ToString(bytes, -1, 8),
values);
}
catch (ArgumentNullException e) {
Console.Write("Exception Thrown: ");
Console.Write("{0}", e.GetType(), e.Message);
}
catch (ArgumentOutOfRangeException e) {
Console.Write("Exception Thrown: ");
Console.Write("{0}", e.GetType(), e.Message);
}
catch (ArgumentException e) {
Console.Write("Exception Thrown: ");
Console.Write("{0}", e.GetType(), e.Message);
}
}
// Defining the method
// PrintIndexAndValues
public static void PrintIndexAndValues(byte[] myArr)
{
int count = 0;
for (int i = 0; i < myArr.Length; i++) {
if (count == 18) {
Console.WriteLine();
Console.Write("{0} ", myArr[i]);
count = 0;
}
else {
Console.Write("{0} ", myArr[i]);
count++;
}
}
Console.WriteLine();
Console.WriteLine();
}
}
輸出:
Initial Array: 0 0 1 2 7 126 78 55 255 78 45 198 200 1 1 1 1 255 255 2 4 4 77 77 77 77 77 0 1 0 0 1 2 7 126 78 55 255 78 45 198 200 1 1 1 1 255 255 2 4 4 255 255 255 255 245 245 245 245 245 245 245 245 245 245 0 0 0 0 0 0 0 0 6 5 6 56 31 31 31 54 23 253 startIndex is less than zero Exception Thrown: System.ArgumentOutOfRangeException
示例4:對於ArgumentNullException
// C# program to demonstrate
// BitConverter.ToDouble(Byte[], Int32)
// Method
using System;
class GFG {
// Main Method
public static void Main()
{
try {
// Define an array of byte values.
byte[] bytes = null;
// getting double value and Display it
Console.WriteLine("array bytes is null");
double values = BitConverter.ToDouble(bytes, 0);
Console.WriteLine(" {0} {1} {2}", 0,
BitConverter.ToString(bytes, 0, 8), values);
}
catch (ArgumentNullException e) {
Console.Write("Exception Thrown: ");
Console.Write("{0}", e.GetType(), e.Message);
}
catch (ArgumentOutOfRangeException e) {
Console.Write("Exception Thrown: ");
Console.Write("{0}", e.GetType(), e.Message);
}
catch (ArgumentException e) {
Console.Write("Exception Thrown: ");
Console.Write("{0}", e.GetType(), e.Message);
}
}
// Defining the method
// PrintIndexAndValues
public static void PrintIndexAndValues(byte[] myArr)
{
int count = 0;
for (int i = 0; i < myArr.Length; i++) {
if (count == 18) {
Console.WriteLine();
Console.Write("{0} ", myArr[i]);
count = 0;
}
else {
Console.Write("{0} ", myArr[i]);
count++;
}
}
Console.WriteLine();
Console.WriteLine();
}
}
輸出:
array bytes is null Exception Thrown: System.ArgumentNullException
參考:
相關用法
- C# DateTimeOffset.Add()用法及代碼示例
- C# String.Contains()用法及代碼示例
- C# Math.Sin()用法及代碼示例
- C# Math.Cos()用法及代碼示例
- C# Dictionary.Add()用法及代碼示例
- C# Math.Tan()用法及代碼示例
- C# Math.Abs()方法用法及代碼示例
- C# Math.Exp()用法及代碼示例
- C# Math.Abs()函數用法及代碼示例
注:本文由純淨天空篩選整理自RohitPrasad3大神的英文原創作品 C# | BitConverter.ToDouble() Method。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。