Java基础进阶IO流-标准输出流

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: Java基础进阶IO流-标准输出流

java.io.PrintStream:标准的字节输出流。默认输出到控制台。


示例代码:


public class PrintStreamTest {
    public static void main(String[] args) {
        // 联合起来写
        System.out.println("HelloWorld!");
        // 分开写
        PrintStream ps = System.out;
        ps.println("hello zahgnsan!");
        ps.println("hello lisi!");
        ps.println("hello wangwu!");
        // 标准输出流不需要手动close()关闭。
        // 可以改变标准输出流的输出方向吗? 可以
        /*
        // 这些是之前System类使用过的方法和属性。
        System.gc();
        System.currentTimeMillis();
        PrintStream ps2 = System.out;
        System.exit(0);
        System.arraycopy(....);
         */
        PrintStream p = null;
        try {
            // 标准输出流不再指向控制台,指向“log”文件。
            p = new PrintStream(new FileOutputStream("log"));
            //改变流的输出方向// 修改输出方向,将输出方向修改到"log"文件。
            System.setOut(p);
            //再输出
            p.println("hello zhangsan");
            p.println("hello lisi");
            p.println("hello wangwu");
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        }
    }
}


运行结果:


0a2653c851af460fa595bd959398a8f1.png


使用标准输出流实现日志


①Logger.java


/*
* 日志工具
* */
public class Logger {
    /*
    * 记录日志的方法
    * */
    public static void Logger(String msg) {
    PrintStream ps = null;
    {
        try {
            // 指向一个日志文件
            ps = new PrintStream(new FileOutputStream("log.txt",true));
            //改变流输出方向
            System.setOut(ps);
            //写入指定格式数据,日期当前时间
            Date nowtime = new Date();
            SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH-mm-ss SSS");
            String strtime = sdf.format(nowtime);
            System.out.println(strtime + ": " + msg);
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        }
    }
}
}


②LogTest.java


public class LogTest {
    public static void main(String[] args) {
        Logger.Logger("调用了System类的gc方法,建议启动垃圾回收");
        Logger.Logger("调用了UserService的doSome方法");
        Logger.Logger("用户尝试登录,验证失败");
        Logger.Logger("调用了System类的gc方法,建议启动垃圾回收");
        Logger.Logger("调用了UseService的doSome方法");
        Logger.Logger("用户尝试进行登录,验证失败");
        Logger.Logger("我非常喜欢这个记录日志的工具哦!");
    }
}


运行结果:


2d65d23f6d4748949b924e4057485923.png

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
2月前
|
Java
java 中 IO 流
Java中的IO流是用于处理输入输出操作的机制,主要包括字节流和字符流两大类。字节流以8位字节为单位处理数据,如FileInputStream和FileOutputStream;字符流以16位Unicode字符为单位,如FileReader和FileWriter。这些流提供了读写文件、网络传输等基本功能。
64 9
|
3月前
|
存储 缓存 Java
java基础:IO流 理论与代码示例(详解、idea设置统一utf-8编码问题)
这篇文章详细介绍了Java中的IO流,包括字符与字节的概念、编码格式、File类的使用、IO流的分类和原理,以及通过代码示例展示了各种流的应用,如节点流、处理流、缓存流、转换流、对象流和随机访问文件流。同时,还探讨了IDEA中设置项目编码格式的方法,以及如何处理序列化和反序列化问题。
109 1
java基础:IO流 理论与代码示例(详解、idea设置统一utf-8编码问题)
|
4月前
|
安全 Java API
【Java面试题汇总】Java基础篇——String+集合+泛型+IO+异常+反射(2023版)
String常量池、String、StringBuffer、Stringbuilder有什么区别、List与Set的区别、ArrayList和LinkedList的区别、HashMap底层原理、ConcurrentHashMap、HashMap和Hashtable的区别、泛型擦除、ABA问题、IO多路复用、BIO、NIO、O、异常处理机制、反射
|
3月前
|
Java 数据处理 开发者
揭秘Java IO流:字节流与字符流的神秘面纱!
揭秘Java IO流:字节流与字符流的神秘面纱!
54 1
|
3月前
|
自然语言处理 Java 数据处理
Java IO流全解析:字节流和字符流的区别与联系!
Java IO流全解析:字节流和字符流的区别与联系!
131 1
|
4月前
|
Java 大数据 API
Java 流(Stream)、文件(File)和IO的区别
Java中的流(Stream)、文件(File)和输入/输出(I/O)是处理数据的关键概念。`File`类用于基本文件操作,如创建、删除和检查文件;流则提供了数据读写的抽象机制,适用于文件、内存和网络等多种数据源;I/O涵盖更广泛的输入输出操作,包括文件I/O、网络通信等,并支持异常处理和缓冲等功能。实际开发中,这三者常结合使用,以实现高效的数据处理。例如,`File`用于管理文件路径,`Stream`用于读写数据,I/O则处理复杂的输入输出需求。
281 12
|
3月前
|
Java
Java 中 IO 流的分类详解
【10月更文挑战第10天】不同类型的 IO 流具有不同的特点和适用场景,我们可以根据具体的需求选择合适的流来进行数据的输入和输出操作。在实际应用中,还可以通过组合使用多种流来实现更复杂的功能。
79 0
|
3月前
|
存储 Java 程序员
【Java】文件IO
【Java】文件IO
47 0
|
5月前
|
存储 Java
【IO面试题 四】、介绍一下Java的序列化与反序列化
Java的序列化与反序列化允许对象通过实现Serializable接口转换成字节序列并存储或传输,之后可以通过ObjectInputStream和ObjectOutputStream的方法将这些字节序列恢复成对象。
|
6月前
|
Java 大数据
解析Java中的NIO与传统IO的区别与应用
解析Java中的NIO与传统IO的区别与应用