IO流(四) 标准输出流 PrintStream

一.PrintStream的基本使用 setOut()方法

package com.io;

import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.PrintStream;

/*
java.io.PrintStream :标准的字节输出流。默认输出到控制台
 */
public class PrintStreamTest {
    public static void main(String[] args)  {
        //联合起来写
        System.out.println("hello world!");

        //分开写
        PrintStream ps = System.out;
        ps.println("hello world!");

        //标准输出流不需要手动close关闭
        //可以改变标准输出流的输出方向
        //标准输出流不再指向控制台,指向“log”文件
        try {
            System.setOut(new PrintStream(new FileOutputStream("log")));
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        }
        System.out.println("hello world !");
        System.out.println("hello Kitty !");
    }
}

二.记录日志的实现

1.Logger类

package com.io;

import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.PrintStream;
import java.text.SimpleDateFormat;
import java.util.Date;

public class Logger {
    /*
    记录日志的方法
     */
    public static void log(String msg)  {
        try {
            //指向一个日志文件
            PrintStream out = new PrintStream(new FileOutputStream("log.txt",true));
            //改变输出方向
            System.setOut(out);
            //日期当前时间
            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();
        }

    }

}

2.测试

package com.io;

public class LogTest {
    public static void main(String[] args) {
        Logger.log("调用System类的gc()方法,建议启动垃圾回收");
        Logger.log("用户尝试登陆,验证失败");

    }
}

3.结果

2021-01-07 11:20:58 565: 调用System类的gc()方法,建议启动垃圾回收
2021-01-07 11:20:58 640: 用户尝试登陆,验证失败

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值