iOS开发-math.h/ceil/floor/round

math.h头文件库函数的介绍:

1、每一个函数都能接受定义域内的所有参数值,对于其他所有的参数都报告定义域错误。发生定义域错误时,errno设置为EDOM。
2、如果输入的不是数字,那么函数返回一个表示非数字的特殊编码NaN(即Not a number)。
3、对于一个输入的具体的值,函数产生一个确定的结果。
4、对于所有的结果的值太小或者太大而不能表示的值,函数报告值域错误。
5、如果函数产生的结果数值太大,那么函数就返回一个表示正无穷大的特殊编码+Inf,或者负无穷大的编码-Inf;
6、如果结果太小而不能表示,就返回0。一般来说,结果不能表示为double类型值时,发生值域错误。
7、如果结果上溢,函数返回宏HUGE_VAL的值,并且errno设置为宏ERANGE,如果结果下溢,函数返回0。
8、对于任何可以表示的结果,函数都尽可能地把精度误差控制在两位以内。
9、所有math.h头文件里生命的函数的返回类型和参数值都是double类型,并且中间结果也是用double类型来表示。

#include <math.h>

-(void)mathTest{
    //----------------------------
    //ceil(double x):计算不小于x的最小整数
    NSLog(@"ceil(4.2): %f",ceil(4.2));
    //floor(double x):计算不大于x的最大整数
    NSLog(@"floor(4.2): %f",floor(4.2));
    //floor(double x):计算不大于x的最大整数
    NSLog(@"round(4.2): %f,round(4.55): %f",round(4.2),round(4.55));
    
    //-----------------------------
    CGFloat d = 180;
    //cos计算x(单位为弧度)的余弦值。函数cos返回余弦值
    NSLog(@"cos(180): %f",cos(d));
    //sin计算x(以弧度为单位)的正弦值。函数sin返回正弦值。
    NSLog(@"sin(180): %f",sin(d));
    //tan返回x(以弧度为单位)的正切值。函数返回正切值。
    NSLog(@"tan(180): %f",tan(d));
    
    //-----------------------------
    CGFloat c = 0.5;
    //acos:计算x的反余弦,取值x[-1, +1],函数返回[0, π]弧度
    NSLog(@"反余弦acos(0.5): %f",acos(c));
    //asin:计算x的反正弦,取值x[-1, +1],函数返回[-π/2, +π/2]弧度
    NSLog(@"反正弦asin(0.5): %f",asin(c));
    //atan:计算x的反正切,函数atan返回[-π/2, +π/2]弧度
    NSLog(@"x的反正切atan(0.5): %f",atan(c));
    //atan2:计算y/x的反正切,函数在[-π, +π]弧度范围内,确定返回值的象限信息
    NSLog(@"y/x的反正切atan2(3,-4): %f",atan2(3,-4));
    
    //-----------------------------
    //sinh计算x的双曲正弦,定义域(-Inf, +Inf),值域(-Inf, +Inf)。
    NSLog(@"双曲正弦sinh(0.5): %f",sinh(c));
    //cosh计算x的双曲余弦,定义域(-Inf, +Inf),值域(-Inf, +Inf)。
    NSLog(@"双曲余弦cosh(0.5): %f",cosh(c));
    //tanh计算x的双曲正切,定义域(-Inf, +Inf),值域(-1, +1)。
    NSLog(@"双曲正切tanh(0.5): %f",tanh(c));

    //log:计算x的自然对数 取值 >0;
    NSLog(@"log(4): %f",log(4));
    //log10:计算x的以10为底的对数
    NSLog(@"log10(100): %f",log10(100));
    //pow(double x, double y):x的y次幂
    NSLog(@"pow(2, 4): %f",pow(2, 4));
    //sqrt(double x):计算x的非负平方根
    NSLog(@"sqrt(4): %f",sqrt(4));
    //fmod(double x, double y):计算x/y的浮点余数
    NSLog(@"fmod(8, 3): %f",fmod(8, 3));
    
    //---------------------------------
    //double ldexp(double x, int exp); 函数ldexp计算一个浮点数和2的整数幂的乘积,有可能发生值域错误。函数ldexp返回x乘以2的exp次幂的值。注意,ldexp和frexp是互逆的操作。s = f*2n
    NSLog(@"ldexp(0.3, 3): %f",ldexp(0.3, 3));
}
/* 弧度转角度 */
#define SK_RADIANS_TO_DEGREES(radian) \
        ((radian) * (180.0 / M_PI))
/* 角度转弧度 */
#define SK_DEGREES_TO_RADIANS(angle) \
        ((angle) / 180.0 * M_PI)

打印日志:
在这里插入图片描述
补充:
HUGE_VAL——这个宏通常会展开为一个非常大的double常量,一般情况下和float.h中定义的DBL_MAX的展开值相等。
在那些对无穷大(Inf)不提供特殊编码的机器上,通常认为返回这样一个大值是警告发生了值域错误的最好方式。
将一个数学函数的返回值和HUGE_VAL或者-HUGE_VAL相比较可能会比较安全。

参考:
1、math.h

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

瓜子三百克

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值