ToB企服应用市场:ToB评测及商务社交产业平台

标题: C 语言:类型转换与常量的细致理解 [打印本页]

作者: 王柳    时间: 2024-2-24 14:45
标题: C 语言:类型转换与常量的细致理解
C 语言中的类型转换

有时,您必须将一种数据类型的值转换为另一种类型。这称为类型转换
隐式转换

当您将一种类型的值分配给另一种类型的变量时,编译器会自动进行隐式转换。
例如,如果您将一个 int 值分配给一个 float 类型:
  1. // 自动转换:int to float
  2. float myFloat = 9;
  3. printf("%f", myFloat); // 输出 9.000000
复制代码
如您所见,编译器会自动将 int 值 9 转换为 float 值 9.000000。
这可能是危险的,因为您可能会在某些情况下失去对特定值的控制。
尤其是如果相反的情况 - 以下示例会自动将 float 值 9.99 转换为 int 值 9:
  1. // 自动转换:float to int
  2. int myInt = 9.99;
  3. printf("%d", myInt); // 输出 9
复制代码
0.99 发生了什么?我们可能想要在我们的程序中使用这个数据!所以要小心。您必须了解编译器在这些情况下的工作方式,以避免意外结果。
另一个例子,如果您将两个整数 5 除以 2,您知道结果是 2.5。正如您在此页面的开头所知,如果您将 sum 存储为整数,结果将只显示数字 2。因此,将 sum 存储为 float 或 double 会更好,对吗?
  1. float sum = 5 / 2;
  2. printf("%f", sum); // 输出 2.000000
复制代码
为什么结果是 2.00000 而不是 2.5?好吧,因为 5 和 2 在除法中仍然是整数。在这种情况下,您需要将整数值手动转换为浮点值(参见下文)。
显式转换

显式转换是通过在值之前放置类型括号 () 来手动完成的。
考虑到我们上面示例中的问题,我们现在可以得到正确的结果:
  1. // 手动转换: int to float
  2. float sum = (float) 5 / 2;
  3. printf("%f", sum); // 输出 2.500000
复制代码
您也可以将类型放在变量前面:
  1. int num1 = 5;
  2. int num2 = 2;
  3. float sum = (float) num1 / num2;
  4. printf("%f", sum); // 输出 2.500000
复制代码
由于您在上一章中学习了“小数精度”,您可以通过删除多余的零(如果您愿意)使输出更清晰:
  1. int num1 = 5;
  2. int num2 = 2;
  3. float sum = (float) num1 / num2;
  4. printf("%.1f", sum); // 输出 2.5
复制代码
C 语言中的常量

如果您不想让其他人(或自己)更改现有变量的值,可以使用 const 关键字。
这将声明变量为“常量”,这意味着它不可更改,只读:
  1. const int myNum = 15; // myNum 始终为 15
  2. myNum = 10; // 错误:对只读变量 'myNum' 进行赋值
复制代码
当您拥有不太可能改变的值时,应始终将变量声明为常量:
  1. const int minutesPerHour = 60;
  2. const float PI = 3.14;
复制代码
关于常量的注意事项

当您声明一个常量变量时,必须为其分配一个值:
  1. // 就像这样:
  2. const int minutesPerHour = 60;
  3. // 然而,这不起作用:
  4. const int minutesPerHour;
  5. minutesPerHour = 60; // 错误
复制代码
常量在程序中可以提高代码的可读性,并防止在程序中无意中更改重要的值。
最后

为了方便其他设备和平台的小伙伴观看往期文章:
微信公众号搜索:Let us Coding,关注后即可获取最新文章推送
看完如果觉得有帮助,欢迎 点赞、收藏、关注

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4