CGFloat和float的区别,什么时候用哪一种以及浮点数比较大小

1CGFloatfloat的区别,什么时候用哪一种


CGFloat is just a typedef for either float or double.

The basic type for all floating-point values.

 

  1. typedef float CGFloat;// 32-bit  
  2. typedef double CGFloat;// 64-bit  

 

对于需要兼容64位机器的程序而言,需要用CGFloat,当然从长远角度考虑还是推荐尽量使用CGFloat。尽管在32位上相比float增加了一些memory footprint的消耗。


2、浮点数比较大小

浮点数判断需要注意,float double 的精度范围,超过范围的数字会被忽略,

(1)  浮点数大小判断

如果没有等号关系在里面,也就必然一大一小,那么直接用  > 或者 <


(2) 浮点数相等判断(如果两个同符号浮点数之差的绝对值小于或等于某一个可接受的误差(即精度),就认为它们是相等的。计算机表示浮点数(float或double类型)都有一个精度限制,对于超出了精度限制的浮点数,计算机会把它们的精度之外的小数部分截断。因此,本来不相等的两个浮点数在计算机中可能就变成相等的了。例如:

    float a=10.222222225,b=10.222222229

    数学上a和b是不相等的,但在32位计算机中它们是相等的。

因为 浮点数在内存中存放,可能无法精确的储存,所以同一个值,可能有不同的内存数据,所以要使用以下的方法:

float 为例,32APP中精度为 6-7,所以取 1e-7

两个数字 A  B

if ( |A-B| <1e-7 )  AB相等。(e-6/e-7都是有条件的,比如你需要的是e-30/e-15 都有可能)


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值