如何生成日志文件

 

try {

        //保存原输出流

        PrintStream out = System.out;

        //创建文件输出流

        PrintStream ps = new PrintStream("./log.txt");

        //设置使用新的输出流

        System.setOut(ps);

        //得到要写入的数据这里用自己定义的代替

        int age = 18;

        System.out.println("age variable defind success ,init value is 18 !");

        //拼接要写入日志的内容

        String info = "this people is about "+age+" year !";

        System.out.println("the result is :"+info);

        //恢复原有输出流

        System.setOut(out);

      } catch (FileNotFoundException e) {

        // TODO Auto-generated catch block

        e.printStackTrace();

      }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您可以使用log4j或者logback框架来实现按日期生成日志文件的功能。下面是使用logback框架的示例代码: 1. 首先,在pom.xml中添加logback依赖: ```xml <dependencies> <dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback-classic</artifactId> <version>1.2.3</version> </dependency> </dependencies> ``` 2. 在logback.xml中配置按日期生成日志文件: ```xml <?xml version="1.0" encoding="UTF-8"?> <configuration> <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"> <file>/path/to/logs/mylog.log</file> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <!-- daily rollover --> <fileNamePattern>/path/to/logs/mylog-%d{yyyy-MM-dd}.log</fileNamePattern> <!-- keep 30 days' worth of history --> <maxHistory>30</maxHistory> </rollingPolicy> <encoder> <pattern>%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{35} - %msg%n</pattern> </encoder> </appender> <root level="info"> <appender-ref ref="FILE" /> </root> </configuration> ``` 这里的`fileNamePattern`指定了生成日志文件名格式为`mylog-yyyy-MM-dd.log`,并且保留最近30天的日志文件。`encoder`中的`pattern`指定了日志输出的格式。 3. 使用Logger输出日志: ```java import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class MyClass { private static final Logger logger = LoggerFactory.getLogger(MyClass.class); public void myMethod() { logger.info("This is a log message"); } } ``` 这样就可以在`/path/to/logs`目录下按日期生成日志文件了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值