java byte[] 与int float long 等的互相转换

本文详细介绍了Java中利用字节流进行整型、字符、短整型、浮点型、长整型和双精度浮点型的打包与拆包操作的方法,包括使用big-endian字节顺序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >



package java.io;

/**
 * Utility methods for packing/unpacking primitive values in/out of byte arrays
 * using big-endian byte ordering.
 */
class Bits {

    /*
     * Methods for unpacking primitive values from byte arrays starting at
     * given offsets.
     */

    static boolean getBoolean(byte[] b, int off) {
        return b[off] != 0;
    }

    static char getChar(byte[] b, int off) {
        return (char) ((b[off + 1] & 0xFF) +
                       (b[off] << 8));
    }

    static short getShort(byte[] b, int off) {
        return (short) ((b[off + 1] & 0xFF) +
                        (b[off] << 8));
    }

    static int getInt(byte[] b, int off) {
        return ((b[off + 3] & 0xFF)      ) +
               ((b[off + 2] & 0xFF) <<  8) +
               ((b[off + 1] & 0xFF) << 16) +
               ((b[off    ]       ) << 24);
    }

    static float getFloat(byte[] b, int off) {
        return Float.intBitsToFloat(getInt(b, off));
    }

    static long getLong(byte[] b, int off) {
        return ((b[off + 7] & 0xFFL)      ) +
               ((b[off + 6] & 0xFFL) <<  8) +
               ((b[off + 5] & 0xFFL) << 16) +
               ((b[off + 4] & 0xFFL) << 24) +
               ((b[off + 3] & 0xFFL) << 32) +
               ((b[off + 2] & 0xFFL) << 40) +
               ((b[off + 1] & 0xFFL) << 48) +
               (((long) b[off])      << 56);
    }

    static double getDouble(byte[] b, int off) {
        return Double.longBitsToDouble(getLong(b, off));
    }

    /*
     * Methods for packing primitive values into byte arrays starting at given
     * offsets.
     */

    static void putBoolean(byte[] b, int off, boolean val) {
        b[off] = (byte) (val ? 1 : 0);
    }

    static void putChar(byte[] b, int off, char val) {
        b[off + 1] = (byte) (val      );
        b[off    ] = (byte) (val >>> 8);
    }

    static void putShort(byte[] b, int off, short val) {
        b[off + 1] = (byte) (val      );
        b[off    ] = (byte) (val >>> 8);
    }

    static void putInt(byte[] b, int off, int val) {
        b[off + 3] = (byte) (val       );
        b[off + 2] = (byte) (val >>>  8);
        b[off + 1] = (byte) (val >>> 16);
        b[off    ] = (byte) (val >>> 24);
    }

    static void putFloat(byte[] b, int off, float val) {
        putInt(b, off,  Float.floatToIntBits(val));
    }

    static void putLong(byte[] b, int off, long val) {
        b[off + 7] = (byte) (val       );
        b[off + 6] = (byte) (val >>>  8);
        b[off + 5] = (byte) (val >>> 16);
        b[off + 4] = (byte) (val >>> 24);
        b[off + 3] = (byte) (val >>> 32);
        b[off + 2] = (byte) (val >>> 40);
        b[off + 1] = (byte) (val >>> 48);
        b[off    ] = (byte) (val >>> 56);
    }

    static void putDouble(byte[] b, int off, double val) {
        putLong(b, off, Double.doubleToLongBits(val));
    }
}




<think>好的,我现在需要帮用户解答关于Java基本数据类型的问题,用户希望了解byte、short、intfloatlong、double和char的定义区别。根据用户提供的引用内容,我需要整合这些信息,确保回答准确且符合格式要求。首先,用户提到的引用[1]、[2]、[3]中,详细说明了各个数据类型的范围、转换规则以及注意事项。比如引用[1]提到byte和short赋值给char会报错,因为char的范围是正数,而short可能包含负数,这点需要重点解释。引用[2]给出了各个整数类型的取值范围,比如byte是-2^7到2^7-1,int是4字节等。引用[3]讨论了类型转换,特别是自动类型转换的条件,即小容量到大容量。接下来,我需要将这些信息结构化,按照数据类型逐个说明定义、内存大小、范围、默认值和转换规则。同时,要注意数学表达式的格式,比如使用$符号包裹数值范围,确保LaTeX正确。例如,byte的范围是$-2^7$到$2^7-1$,int是$-2^{31}$到$2^{31}-1$等。然后,要处理用户提到的类型转换问题,特别是byte和short不能直接赋值给char的原因。这里需要引用[1]中的内容,强调char的无符号特性导致范围不兼容,因此需要显式转换。另外,自动类型转换的条件,如小容量到大容量可以自动转换,反之需要强制转换,这部分引用[3]的例子来说明。还需要注意各个数据类型的默认值,比如整数类型默认0,浮点数默认0.0,char默认\u0000,boolean默认false。这些信息在引用[2]和[3]中都有涉及,需要整合到回答中。 关于区别部分,需要分整数型、浮点型、字符型和布尔型,对比它们的存储大小、用途和转换规则。例如,整数型包括byte、short、intlong,分别对应不同范围的整数;浮点型有float和double,精度不同;char用于Unicode字符,而boolean只有两个值。在回答过程中,要确保每个部分的引用标记正确,比如在解释char的范围时引用[1],在讨论类型转换时引用[3]。同时,生成的相关问题需要基于用户之前的问题和当前内容,例如类型转换报错的原因、处理中文字符的方法等。 最后,检查数学表达式是否正确使用$符号,独立公式是否用$$格式,代码块是否用正确语法高亮。确保回答结构清晰,分点明确,用户能够逐步理解各个数据类型的定义和区别。</think>### Java 基本数据类型的定义区别 #### 一、整数类型(整型) 1. **byte** - **定义**:8 位有符号整数,用于节省内存的小范围整数存储[^2] - **范围**:$-2^7$ 至 $2^7 - 1$($-128$ 到 $127$) - **默认值**:$0$ - **示例**:`byte b = 100;` 2. **short** - **定义**:16 位有符号整数,适用于中等范围整数[^2] - **范围**:$-2^{15}$ 至 $2^{15} - 1$($-32768$ 到 $32767$) - **默认值**:$0$ - **示例**:`short s = 20000;` 3. **int** - **定义**:32 位有符号整数,最常用的整数类型[^2] - **范围**:$-2^{31}$ 至 $2^{31} - 1$(约 $-2.1 \times 10^9$ 到 $2.1 \times 10^9$) - **默认值**:$0$ - **示例**:`int i = 1000000;` 4. **long** - **定义**:64 位有符号整数,用于极大整数[^2] - **范围**:$-2^{63}$ 至 $2^{63} - 1$(约 $-9.2 \times 10^{18}$ 到 $9.2 \times 10^{18}$) - **默认值**:$0$ - **示例**:`long l = 10000000000L;`(需加 `L` 后缀) --- #### 二、浮点类型 5. **float** - **定义**:32 位单精度浮点数,适合节省内存的浮点运算[^2] - **范围**:约 $\pm 3.4 \times 10^{38}$,精度为 6-7 位小数 - **默认值**:$0.0$ - **示例**:`float f = 3.14f;`(需加 `f` 后缀) 6. **double** - **定义**:64 位双精度浮点数,默认浮点类型[^2] - **范围**:约 $\pm 1.7 \times 10^{308}$,精度为 15 位小数 - **默认值**:$0.0$ - **示例**:`double d = 3.141592653589793;` --- #### 三、字符类型 7. **char** - **定义**:16 位无符号 Unicode 字符,用于表示单个字符[^1] - **范围**:$0$ 至 $2^{16} - 1$($0$ 到 $65535$) - **默认值**:`\u0000`(空字符) - **示例**:`char c = 'A';` 或 `char ch = '\u0041';`(Unicode 编码) --- #### 四、布尔类型 8. **boolean** - **定义**:表示逻辑值,仅有两个取值:`true` 或 `false`[^3] - **默认值**:`false` - **示例**:`boolean flag = true;` --- ### 关键区别注意事项 | 特性 | 整数类型(byte/short/int/long) | 浮点类型(float/double) | char | boolean | |------------|--------------------------------|--------------------------|-----------|---------| | **符号** | 有符号(除 char) | 有符号 | 无符号 | - | | **内存** | 1-8 字节 | 4-8 字节 | 2 字节 | 1 位 | | **用途** | 精确整数计算 | 近似小数计算 | 字符存储 | 逻辑判断 | | **转换规则** | 小容量可自动转大容量(如 `byteint`)[^3] | 需强制转换大转小(如 `double → float`) | 整型需显式转换[^1] | 不参数值运算 | #### 类型转换示例 ```java // 自动转换(小→大) byte b = 10; int i = b; // 合法 // 强制转换(大→小) double d = 3.14; float f = (float)d; // 需显式转换 // char 整型的转换问题 short s = 65; char c = (char)s; // 必须显式转换[^1] ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值