C类型转换,运算符,math.h

时间:2023-01-28 21:34:30

类型转换

A.隐式转换:不同数据类型之间会进行自动类型转换

自动类型转换的规则
C类型转换,运算符,math.h
自动转换的要求:当前类型值范围<=要转换类型的值范围
Ps:
实型默认为double,且默认小数位均为6
整型默认为int

B.强制转换
(1)形式:(强制转换的类型)(表达式)
(2)从低位开始,根据自身需要截取位数
(3)溢出:最大值和最小值连接成循环,
即刚好超过最大值一个单位时,会变为最小值,
刚好小于最小值一个单位时,会变为最大值
(4)问题:
1.取值范围大的类型 向 取值范围小的类型 转换时,可能会溢出
2.实型 向 整型 转换时,会精度丢失
(5)格式控制符:
1.printf中可看作普通的强制转换
2.scanf中格式控制符只能与被赋值的类型相同
否则:
大转小
C类型转换,运算符,math.h
小转大
C类型转换,运算符,math.h

运算符

逗号运算符:值以最后一个表达式为准

C类型转换,运算符,math.h

Math.h函数里面所有的可用的函数
1 三角函数
double sin (double);
double cos (double);
double tan (double);
2 反三角函数
double asin (double); 结果介于[-PI/2, PI/2]
double acos (double); 结果介于[0, PI]
double atan (double); 反正切(主值), 结果介于[-PI/2, PI/2]
double atan2 (double, double); 反正切(整圆值), 结果介于[-PI/2, PI/2]
3 双曲三角函数
double sinh (double);
double cosh (double);
double tanh (double);
4 指数与对数
double exp (double);
double sqrt (double);
double log (double); 以e为底的对数
double log10 (double);
double pow(double x, double y)//计算以x为底数的y次幂
5 取整
double ceil (double); 取上整
double floor (double); 取下整
6 绝对值
double fabs (double);
double cabs(struct complex znum) //求复数的绝对值
7 标准化浮点数
double frexp (double f, int p); 标准化浮点数, f = x 2^p, 已知f求x, p ( x介于[0.5, 1] )
double ldexp (double x, int p); 与frexp相反, 已知x, p求f
8 取整与取余
double modf (double, double*); 将参数的整数部分通过指针回传, 返回小数部分
double fmod (double, double); 返回两参数相除的余数
9其他
double hypot(double x, double y);//已知直角三角形两个直角边长度,求斜边长度
double ldexp(double x, int exponent);//计算x*(2的exponent次幂)
double poly(double x, int degree, double coeffs [] )//计算多项式
nt matherr(struct exception *e)//数学错误计算处理程序
source: 《C & C++ Code Capsules》