C# float 与零比较(南京某公司面试题)
2007-09-01 02:48
381 查看
写出float类型与零比较的判断语句
float x=0.111F;
if(x>=-float.Epsilon&&x<=float.Epsilon)
return "0";
else
return "不等于零";
c#中浮点变量的赋值
在C#里面给float变量赋值时,有一种特殊情况;语句
float y = 5.2; // 不会被编译!
将产生一个编译器错误,因为类似3.5这样带有小数部分的数字常量会被C#认为是拥有更高精度的double值,所以编译器将因精度损失而拒绝执行。要进行这样的赋值,必须显式地把浮点常量转换为float值:
float y = (float) 3.5; // 没问题;进行了转换。
或者,也可以使用后缀F,强制编译器把赋值语句右边的常量看作浮点值:
float y = 3.5F; // 可以,我们指示了该常量
// 应被当作浮点值处理。
还有一种选择是直接使用double变量而不用float变量来表示浮点数。在SRS应用中,无论何时要声明浮点变量,我们都会使用double来代替,这样可以避免类型转换操作。
一个好方法:声明浮点变量就用double
float x=0.111F;
if(x>=-float.Epsilon&&x<=float.Epsilon)
return "0";
else
return "不等于零";
c#中浮点变量的赋值
在C#里面给float变量赋值时,有一种特殊情况;语句
float y = 5.2; // 不会被编译!
将产生一个编译器错误,因为类似3.5这样带有小数部分的数字常量会被C#认为是拥有更高精度的double值,所以编译器将因精度损失而拒绝执行。要进行这样的赋值,必须显式地把浮点常量转换为float值:
float y = (float) 3.5; // 没问题;进行了转换。
或者,也可以使用后缀F,强制编译器把赋值语句右边的常量看作浮点值:
float y = 3.5F; // 可以,我们指示了该常量
// 应被当作浮点值处理。
还有一种选择是直接使用double变量而不用float变量来表示浮点数。在SRS应用中,无论何时要声明浮点变量,我们都会使用double来代替,这样可以避免类型转换操作。
一个好方法:声明浮点变量就用double
相关文章推荐
- C# float 与零比较(南京某公司面试题)
- 某软件公司部分面试题c#
- 全国排名前20的一家软件公司的C#面试题
- C#面试题
- BAT及各大互联网公司2014前端笔试面试题
- 关于ThreadLocal的一道面试题(酷我公司)
- C#基础知识面试题
- C#常见面试题
- 各大IT公司校园招聘程序猿笔试、面试题集锦
- 慧咨南京公司简介
- 微软、google、雅虎、百度等各大著名公司的经典面试题!保证搞晕你!!
- 2017下半年,一二线互联网公司JAVA面试题汇总
- 微软、google、雅虎、百度等各大著名公司的经典面试题
- 加强网站安全、重构公司的门户网站项目(C# VS2003)
- C#基础知识面试题
- 各大IT公司校园招聘程序猿笔试、面试题集锦
- 微软、google、雅虎、百度等各大著名公司的经典面试题
- BAT及各大互联网公司2014前端笔试面试题--Html,Css篇
- C#面试题
- NET面试题:C#中的lock关键字有何作用