详解C#的数学类,Math,浮点数(中)

简介:

两种浮点数据类型--float和double,是为了与ANSI/IEEE Std 754-1985(它是一种用于二进制浮点算术的IEEE标准)相一致而定义的.

float值由24位有符号尾数和一个8位有符号指数组成。精度大于为小数点后7位。值的范围是从

-3.402823*1038到3.402823*1038 大于0的最小float值是1.401298*10-45这三个值分别对应的是

float.MinValue,float.MaxValue,float.Epsilon.

 

double值由53位有符号尾数和11位有符号指数组成,精度大约为小数点后15位到16位。值的范围从

-1.79769313486232*10308到1.79769313486232*10308.大于0的最小double值是:4.94065645841247*10-324分别对应:

double.MinValue,double.MaxValue,double.Epsilon.

 

下面的代码使一个浮点数除以0;

float f1=1;

float f2=0;

float f3=f1/f2;

 

看到上面的代码,你是否会立马想到DividedByZeroException。如果这些数是整数的话,的确会抛出异常,但是这些数是浮点数,这里不会产生异常,

事实上,浮点数运算从来不会产生异常,因为f2并不是真正意义上的0,它只是一个与0非常接近的数(具体可以看我上篇文章)。在这种情况下f3等于一个特殊的值。它是Infinity(正无穷大),

如果将f1更改为-1,那么f3的符号将是负的,它是-Infinity(负无穷大)。

你甚至可以对Infinity执行算术运算,例如,表达式1/f3等于0。

如果将f1更改为0,那么f3将等于NaN(Not a Number,未知数).

判断一个数是Infinity或者是NaN使用的是Single的静态方法:

bool IsInfinity(float fValue);                      //判断是否为无穷大

bool IsPositiveInfinity(float fValue);           //判断是否为正无穷大

bool IsNegativeInfinty(float fValue);          //判断是否为负无穷大

bool IsNaN(float fValue);                          //判断是否为NaN

 

Single结构还定义了一些常量字段。

Single.PositiveInfinity.

Single.NegativeInfinity.

Single.NaN.






本文转自LoveJenny博客园博客,原文链接:http://www.cnblogs.com/LoveJenny/archive/2010/06/06/1752291.html,如需转载请自行联系原作者

目录
相关文章
|
3天前
|
开发框架 .NET C#
C#|.net core 基础 - 删除字符串最后一个字符的七大类N种实现方式
【10月更文挑战第9天】在 C#/.NET Core 中,有多种方法可以删除字符串的最后一个字符,包括使用 `Substring` 方法、`Remove` 方法、`ToCharArray` 与 `Array.Copy`、`StringBuilder`、正则表达式、循环遍历字符数组以及使用 LINQ 的 `SkipLast` 方法。
|
1月前
|
存储 C# 索引
C# 一分钟浅谈:数组与集合类的基本操作
【9月更文挑战第1天】本文详细介绍了C#中数组和集合类的基本操作,包括创建、访问、遍历及常见问题的解决方法。数组适用于固定长度的数据存储,而集合类如`List<T>`则提供了动态扩展的能力。文章通过示例代码展示了如何处理索引越界、数组长度不可变及集合容量不足等问题,并提供了解决方案。掌握这些基础知识可使程序更加高效和清晰。
63 2
|
1月前
|
C# 数据安全/隐私保护
C# 一分钟浅谈:类与对象的概念理解
【9月更文挑战第2天】本文从零开始详细介绍了C#中的类与对象概念。类作为一种自定义数据类型,定义了对象的属性和方法;对象则是类的实例,拥有独立的状态。通过具体代码示例,如定义 `Person` 类及其实例化过程,帮助读者更好地理解和应用这两个核心概念。此外,还总结了常见的问题及解决方法,为编写高质量的面向对象程序奠定基础。
17 2
|
2月前
|
C#
C#中的类和继承
C#中的类和继承
38 6
|
2月前
|
Java C# 索引
C# 面向对象编程(一)——类
C# 面向对象编程(一)——类
30 0
|
2月前
|
开发框架 .NET 编译器
C# 中的记录(record)类型和类(class)类型对比总结
C# 中的记录(record)类型和类(class)类型对比总结
|
4月前
|
开发框架 .NET 编译器
程序与技术分享:C#基础知识梳理系列三:C#类成员:常量、字段、属性
程序与技术分享:C#基础知识梳理系列三:C#类成员:常量、字段、属性
30 2
|
4月前
|
C#
C# 版本的 计时器类 精确到微秒 秒后保留一位小数 支持年月日时分秒带单位的输出
这篇2010年的文章是从别处搬运过来的,主要包含一个C#类`TimeCount`,该类有多个方法用于处理时间相关的计算。例如,`GetMaxYearCount`计算以毫秒为单位的最大年数,`GetCurrentTimeByMiliSec`将当前时间转换为毫秒,还有`SecondsToYYMMDDhhmmss`将秒数转换为年月日时分秒的字符串。此外,类中还包括一些辅助方法,如处理小数点后保留一位数字的`RemainOneFigureAfterDot`。
|
4月前
|
存储 安全 C#
C# 类的深入指南
C# 类的深入指南
|
5月前
|
C#
C#的类和对象的概念学习案例刨析
【5月更文挑战第17天】C#是一种面向对象的语言,以类和对象为核心。类作为对象的模板,定义了属性(如Name, Age)和行为(如Greet)。对象是类的实例,可设置属性值。封装通过访问修饰符隐藏实现细节,如Customer类的私有name字段通过Name属性访问。继承允许新类(如Employee)从现有类(Person)继承并扩展。多态让不同对象(如Circle, Square)共享相同接口(Shape),实现抽象方法Area,提供灵活的代码设计。
64 1