Java中native方法read()可以人为的去输入-1让文件读取的时候还没到末尾提前结束读取吗?

简介: Java中native方法read()可以人为的去输入-1让文件读取的时候还没到末尾提前结束读取吗?

InputStream就是Java标准库提供的最基本的输入流。它位于java.io这个包里。java.io包提供了所有同步IO的功能。

要特别注意的一点是,InputStream并不是一个接口,而是一个抽象类,它是所有输入流的超类。这个抽象类定义的一个最重要的方法就是int read(),起方法在源码中定义如下:

在这里插入图片描述
我们如下以FileInputStream类为例,来结束read()方法,在FileInputStream类中,read()方法调用了read0()方法,而read0()方法才是我们标题中提到的native方法,包括其他的实现类,也基本上都是这样去实现的,这里只以FileInputStream为例,其他的类都类似。
如下为FileInputStream类中read()和read0()方法:
在这里插入图片描述

这个方法会读取输入流的下一个字节,并返回字节表示的int值(0~255)。如果已读到末尾,返回-1表示不能继续读取了。

进入正题,那么我们可以人为的从去输入-1让文件读取的时候还没到末尾提前结束读取吗?答案是不能的,
虽然写入的时候是以byte形式写的,但是读出的时候是以int形式读的
比如:写的时候(byte)0b11111111,byte类型应该为-1,但是读的时候却是以int类型去读,会在前面自动补0,
也就是说读的时候,读取到的是(int)ob00000000_00000000_00000000_11111111;
所以说我们人为基本上是不能能输入为-1的情况,也就是文件读取结束的情况

具体看如下代码:

public class ReadDemo {
    
    public void readFile() throws IOException {
    

        FileOutputStream fileOutputStream = new FileOutputStream("src/com/ysw/demo02IO/readtest.txt");
        /**
         * byte共有8个比特位,
         * 其中最高位是符号位,
         * 给它赋值0b1111_1111时,
         * 最高位的1系统无法判断是实际数值还是符号位数值。
         * 添加强制类型转换(byte),则系统可以知道1是符号位,
         * 此时可以被赋值;如果没有加强制类型转换,则系统认为0b1001_0101是一个int类型数据。
         * int类型值无法赋值给byte变量,所以会报错。
         * */
        byte[] a = {
    0x30,0x31,0x32,(byte)0b11111111,0x30,0x31,0x32};
        fileOutputStream.write(a);

        // 创建一个FileInputStream对象:
        InputStream input = new FileInputStream("src/com/ysw/demo02IO/readtest.txt");
        for (;;) {
    
            /**
             * 虽然写是以byte形式写的,但是读的时候是以int形式读的
             * 比如:写的时候(byte)0b11111111,byte类型应该为-1,但是读的时候却是以int类型去读,会在前面自动补0,
             *      也就是说读的时候,读取到的是(int)ob00000000_00000000_00000000_11111111;
             * 所以说我们人为基本上是不能能输入为-1的情况,也就是文件读取结束的情况
             * */
            int n = input.read(); // 反复调用read()方法,直到返回-1
            if (n == -1) {
    
                break;
            }
            System.out.println(n); // 打印byte的值
        }
        input.close(); // 关闭流
        fileOutputStream.close();
    }

    public static void main(String[] args) throws IOException {
    
        new ReadDemo().readFile();
    }
}

                
AI 代码解读
目录
打赏
0
0
0
0
5
分享
相关文章
Java快速入门之数组、方法
### Java快速入门之数组与方法简介 #### 一、数组 数组是一种容器,用于存储同种数据类型的多个值。定义数组时需指定数据类型,如`int[]`只能存储整数。数组的初始化分为静态和动态两种: - **静态初始化**:直接指定元素,系统自动计算长度,如`int[] arr = {1, 2, 3};` - **动态初始化**:手动指定长度,系统给定默认值,如`int[] arr = new int[3];` 数组访问通过索引完成,索引从0开始,最大索引为`数组.length - 1`。遍历数组常用`for`循环。常见操作包括求和、找最值、统计特定条件元素等。
Java容器及其常用方法汇总
Java Collections框架提供了丰富的接口和实现类,用于管理和操作集合数据。
Java容器及其常用方法汇总
|
8天前
|
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
33 3
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
|
6天前
|
java.time常用方法汇总
`java.time` API 是从 Java 8 开始引入的时间日期处理库,旨在替代老旧的 `java.util.Date` 和 `Calendar`。它提供了更简洁、强大和灵活的方式处理日期、时间、时区及时间间隔,支持全球化和时间计算需求。API 包含获取当前时间、创建指定时间、解析和格式化字符串、进行加减运算、比较时间、获取年月日时分秒、计算时间间隔、时区转换以及判断闰年等功能。示例代码展示了如何使用这些功能,极大简化了开发中的时间处理任务。
Java快速入门之类、对象、方法
本文简要介绍了Java快速入门中的类、对象和方法。首先,解释了类和对象的概念,类是对象的抽象,对象是类的具体实例。接着,阐述了类的定义和组成,包括属性和行为,并展示了如何创建和使用对象。然后,讨论了成员变量与局部变量的区别,强调了封装的重要性,通过`private`关键字隐藏数据并提供`get/set`方法访问。最后,介绍了构造方法的定义和重载,以及标准类的制作规范,帮助初学者理解如何构建完整的Java类。
Java 高级面试技巧:yield() 与 sleep() 方法的使用场景和区别
本文详细解析了 Java 中 `Thread` 类的 `yield()` 和 `sleep()` 方法,解释了它们的作用、区别及为什么是静态方法。`yield()` 让当前线程释放 CPU 时间片,给其他同等优先级线程运行机会,但不保证暂停;`sleep()` 则让线程进入休眠状态,指定时间后继续执行。两者都是静态方法,因为它们影响线程调度机制而非单一线程行为。这些知识点在面试中常被提及,掌握它们有助于更好地应对多线程编程问题。
58 9
Java面试必问!run() 和 start() 方法到底有啥区别?
在多线程编程中,run和 start方法常常让开发者感到困惑。为什么调用 start 才能启动线程,而直接调用 run只是普通方法调用?这篇文章将通过一个简单的例子,详细解析这两者的区别,帮助你在面试中脱颖而出,理解多线程背后的机制和原理。
62 12
Java 方法注释:规范、实用和高质量的写法
本文深入探讨了如何编写高质量的 Java 方法注释
56 11

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等