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日志并进行多维度分析。
相关文章
|
3月前
|
Java
java 中 IO 流
Java中的IO流是用于处理输入输出操作的机制,主要包括字节流和字符流两大类。字节流以8位字节为单位处理数据,如FileInputStream和FileOutputStream;字符流以16位Unicode字符为单位,如FileReader和FileWriter。这些流提供了读写文件、网络传输等基本功能。
70 10
|
4月前
|
存储 缓存 Java
java基础:IO流 理论与代码示例(详解、idea设置统一utf-8编码问题)
这篇文章详细介绍了Java中的IO流,包括字符与字节的概念、编码格式、File类的使用、IO流的分类和原理,以及通过代码示例展示了各种流的应用,如节点流、处理流、缓存流、转换流、对象流和随机访问文件流。同时,还探讨了IDEA中设置项目编码格式的方法,以及如何处理序列化和反序列化问题。
133 1
java基础:IO流 理论与代码示例(详解、idea设置统一utf-8编码问题)
|
5月前
|
安全 Java API
【Java面试题汇总】Java基础篇——String+集合+泛型+IO+异常+反射(2023版)
String常量池、String、StringBuffer、Stringbuilder有什么区别、List与Set的区别、ArrayList和LinkedList的区别、HashMap底层原理、ConcurrentHashMap、HashMap和Hashtable的区别、泛型擦除、ABA问题、IO多路复用、BIO、NIO、O、异常处理机制、反射
|
4月前
|
Java 数据处理 开发者
揭秘Java IO流:字节流与字符流的神秘面纱!
揭秘Java IO流:字节流与字符流的神秘面纱!
62 1
|
4月前
|
自然语言处理 Java 数据处理
Java IO流全解析:字节流和字符流的区别与联系!
Java IO流全解析:字节流和字符流的区别与联系!
140 1
|
5月前
|
Java 大数据 API
Java 流(Stream)、文件(File)和IO的区别
Java中的流(Stream)、文件(File)和输入/输出(I/O)是处理数据的关键概念。`File`类用于基本文件操作,如创建、删除和检查文件;流则提供了数据读写的抽象机制,适用于文件、内存和网络等多种数据源;I/O涵盖更广泛的输入输出操作,包括文件I/O、网络通信等,并支持异常处理和缓冲等功能。实际开发中,这三者常结合使用,以实现高效的数据处理。例如,`File`用于管理文件路径,`Stream`用于读写数据,I/O则处理复杂的输入输出需求。
315 12
|
4月前
|
Java
Java 中 IO 流的分类详解
【10月更文挑战第10天】不同类型的 IO 流具有不同的特点和适用场景,我们可以根据具体的需求选择合适的流来进行数据的输入和输出操作。在实际应用中,还可以通过组合使用多种流来实现更复杂的功能。
88 0
|
4月前
|
存储 Java 程序员
【Java】文件IO
【Java】文件IO
52 0
|
网络协议 Java API
Java新人必学课程,Java进阶学习全路线(内涵Java超级干货推送及专家社群福利)
自从拉了java社群之后,发现经常有一些新手java开发在吐槽,吐槽java不知道从何学起,感觉路很迷惘。其实小编想说,沉下心,你会发现要走的路并不是很难。为了帮助新人更好的成长,小编特意邀请了最课程的陆敏技老师来给大家进行java基础课程直播分享。
19131 0
|
2天前
|
安全 Java 程序员
Java 面试必问!线程构造方法和静态块的执行线程到底是谁?
大家好,我是小米。今天聊聊Java多线程面试题:线程类的构造方法和静态块是由哪个线程调用的?构造方法由创建线程实例的主线程调用,静态块在类加载时由主线程调用。理解这些细节有助于掌握Java多线程机制。下期再见! 简介: 本文通过一个常见的Java多线程面试题,详细讲解了线程类的构造方法和静态块是由哪个线程调用的。构造方法由创建线程实例的主线程调用,静态块在类加载时由主线程调用。理解这些细节对掌握Java多线程编程至关重要。
29 13

热门文章

最新文章