C 语言编程 — 数据类型转换
2020-04-04 13:55 云物互联 阅读(327) 评论(0) 编辑 收藏 举报目录
前文列表
《程序编译流程与 GCC 编译器》
《C 语言编程 — 基本语法》
《C 语言编程 — 基本数据类型》
《C 语言编程 — 变量与常量》
《C 语言编程 — 运算符》
《C 语言编程 — 逻辑控制语句》
《C 语言编程 — 函数》
《C 语言编程 — 高级数据类型 — 指针》
《C 语言编程 — 高级数据类型 — 数组》
《C 语言编程 — 高级数据类型 — 字符串》
《C 语言编程 — 高级数据类型 — 枚举》
《C 语言编程 — 高级数据类型 — 结构体与位域》
《C 语言编程 — 高级数据类型 — 共用体》
《C 语言编程 — 高级数据类型 — void 类型》
《C 语言编程 — 数据类型的别名》
数据类型转换
C 语言中如果一个表达式中含有不同类型的常量和变量,在计算时,会将它们自动转换为同一种类型。此外,在 C 语言中也可以对数据类型进行强制转换。
在编程时,有需要类型转换的时候都用上强制类型转换运算符,是一种良好的编程习惯。
隐式(自动)类型转换
- 浮点数赋给整型,该浮点数小数被舍去;
- 整数赋给浮点型,数值不变,但是被存储到相应的浮点型变量中;
#include <stdio.h>
int main(){
int i = 17;
char c = 'c'; /* ascii 值是 99 */
int sum;
sum = i + c;
printf("Value of sum : %d\n", sum );
}
常用的算术转换
常用的算术转换是隐式地把值强制转换为相同的类型。编译器首先执行整数提升(把小于 int/unsigned int 的整数类型自定转换为 int/unsigned int 的过程),如果操作数类型不同,则它们会被转换为下列层次中出现的最高层次的类型:
注意,常用的算术转换不适用于赋值运算符以及逻辑运算符。
显式(强制)类型转换
强制类型转换是把变量从一种类型转换为另一种数据类型。例如,如果您想存储一个 long 类型的值到一个简单整型中,就需要把 long 类型强制转换为 int 类型。此时,就可以使用 强制类型转换运算符:(类型标识符)(表达式)
。
#include <stdio.h>
int main() {
float f, a, x=3.6, y=5.2;
int i=4, b;
a = x + y;
b = (int)(x + y);
f = 10 / i;
printf("a=%d, b=%d, f=%f, x=%f\n", a, b, f, x);
return 0;
}
运行:
$ ./main
a=8.799999, b=8, f=2.000000, x=3.600000
#include <stdio.h>
int main() {
int sum = 17, count = 5;
double mean;
mean = (double)sum / count;
// mean = (double)(sum / count); 此时返回 3.000000
printf("Value of mean: %f", mean);
return 0;
}
需要注意的是,强制类型转换运算符的优先级大于除法,因此 sum 的值首先被转换为 double 型,然后除以 count,得到一个类型为 double 的值。注意,如果是 (double)(sum / count)
的话,则会先进行整数运算得到 3 再类型转换为双精度浮点数 3.000000。
运行:
$ ./main
Value of mean: 3.400000