小萌新的C语言——数据类型转换

目录

一、自动类型转换(隐式转换)

二、强制类型转换


一、自动类型转换(隐式转换)

计算机自动进行的数据类型之间的转换,一般往字节占比最大的数据类型去转;

例子:

#include <stdio.h>

int main(int argc, char *argv[])

    char a = 'a';
    int b = 12;
    float c = 12.3;
    double d = 123.123;

    printf("自动类型的转换的大小:%ld\n",sizeof(a+b-c*d));

    return 0;

最终结果大小为计算机中数据类型最大字节的double的大小

二、强制类型转换

使用者根据自己需求进行转换的数据类型;

一般形式:
(使用者需要的数据类型)需要转换的对象;

例子:

#include <stdio.h>

int main(int argc, char *argv[])

    char a = 'a';
    int b = 12;
    float c = 12.3;
    double d = 123.123;
    int f;
    f = (int)a+b-c*d;//强制类型转换
    printf("强制类型的转换的大小:%ld\n",sizeof(f));
    
    return 0;

最终结果大小为使用者自己需要的int类型的大小

### Java 中 `double` 和 `float` 类型的数值范围 #### 浮点数类型概述 Java 提供两种基本浮点数据类型:`float` 和 `double`。每种类型都有不同的存储大小和精度特性。 #### `float` 类型 `float` 使用 32 位表示,属于单精度浮点数。这种类型的数值能够提供大约 6 到 7 位的有效数字[^4]。对于大多数应用而言,在不需要极高精度的情况下可以选择使用 `float` 来节省内存空间并提高运算效率。然而需要注意的是,当处理特别大或特别小的数值时,`float` 可能会出现精度损失的情况[^1]。 ```java // 示例展示 float 的近似值显示 public class FloatExample { public static void main(String[] args) { float f = 9876.123456789f; System.out.println(f); } } ``` #### `double` 类型 相比之下,`double` 是一种双精度浮点数,占用 64 位来存储数据。这使得它具有更高的精度——通常可以保证至少 15 位有效数字,并且适用于需要更高准确性计算的应用场景。默认情况下,未指定后缀的小数会被视为 `double` 类型。 ```java // 示例说明 double 默认分配以及其高精度特点 public class DoubleExample { public static void main(String[] args) { double d = 9876.123456789123456789; // 隐式声明为 double System.out.println(d); double df = (float) Math.pow(10, 6.92); // 显示转换成 float 后再赋给 double System.out.println(df); } } ``` #### 特殊情况下的精度问题 有时即使指定了合适的浮点数类型,仍然可能遇到意外的结果。例如下面这段代码展示了如何因为内部二进制表达方式而导致看似相同的两个值实际上并不相等: ```java public class PrecisionLossDemo { public static void main(String[] args) { float f = 20014999; double d = f; double d2 = 20014999; System.out.printf("f=%.1e%n", f); System.out.printf("d=%.1e%n", d); System.out.printf("d2=%.1e%n", d2); } } ``` 上述程序输出表明虽然三个变量看起来应该相同但实际上存在细微差异,这是因为从 `float` 转换到 `double` 过程中发生了舍入误差[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值