1. 取小数的整数部分
可以通过两种方式来获取小数的整数部分:
方案1:赋值运算符的原则
通过将一个浮点数赋值给一个整数变量,C语言会自动去除小数部分,只保留整数部分。
示例:
#include <stdio.h>
int main() {
float num = 5.67;
int intPart = num; // 通过赋值运算符将小数赋给整数变量
printf("整数部分: %d\n", intPart); // 输出:整数部分: 5
return 0;
}
解释:
num
是一个浮点数。- 将
num
赋值给整数变量intPart
时,C语言会自动去除小数部分,保留整数部分5
。
方案2:强制类型转换原则
通过强制类型转换,将浮点数转换为整数,C语言会截断小数部分,只保留整数部分。
示例:
#include <stdio.h>
int main() {
float num = 5.67;
int intPart = (int)num; // 强制类型转换
printf("整数部分: %d\n", intPart); // 输出:整数部分: 5
return 0;
}
解释:
(int)num
是将num
强制转换为整数类型。- 这种转换会直接截断小数部分,只保留整数部分
5
。
2. 取多字节的低字节部分
在实际编程中,我们有时需要从一个多字节的数据中提取出低字节(即最低的 8 位)。同样可以通过赋值运算符和强制类型转换来实现。
方案1:赋值运算符的原则
通过将多字节数据(如 short
或 int
)赋值给一个字节变量,可以提取出低字节部分。
示例:
#include <stdio.h>
int main() {
int num = 0x1234; // 十六进制值 0x1234
unsigned char lowByte = num; // 赋值运算符,只取低字节部分
printf("低字节部分: 0x%02X\n", lowByte); // 输出:低字节部分: 0x34
return 0;
}
解释:
num
是一个 4 字节整数,值为0x1234
。- 将
num
赋值给lowByte
(1 字节的unsigned char
类型)时,只会保留num
的低字节部分0x34
(即 16 进制表示的 34)。
方案2:强制类型转换原则
通过强制类型转换,将多字节数据转换为 1 字节类型,这样可以获取低字节部分。
示例:
#include <stdio.h>
int main() {
int num = 0x1234; // 十六进制值 0x1234
unsigned char lowByte = (unsigned char)num; // 强制类型转换
printf("低字节部分: 0x%02X\n", lowByte); // 输出:低字节部分: 0x34
return 0;
}
解释:
(unsigned char)num
是将num
强制转换为unsigned char
类型,丢弃了高字节,只保留低字节部分。- 结果是
0x34
,即num
的低字节。
总结
-
取小数的整数部分:
- 方案1(赋值运算符):直接将浮点数赋值给整数,自动去除小数部分。
- 方案2(强制转换):通过强制类型转换,将浮点数转为整数,截断小数部分。
-
取多字节的低字节部分:
- 方案1(赋值运算符):将多字节类型赋值给 1 字节类型变量,自动提取低字节部分。
- 方案2(强制转换):通过强制类型转换,只保留多字节数据的低字节部分。
(完)