Android开发:日志功能备忘

临时记一下吧,以后就直接复制粘贴这里面的好了。

实现一个日志记录程序的运行状态,并且带上时间信息,可以写一个类灵活调用。

MyLog.java

package com.example.networkaccessrestrictions;

import static android.content.ContentValues.TAG;

import android.content.Context;
import android.util.Log;

import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.io.PrintWriter;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;

public class MyLog {
    private static final String LOG_FILE_NAME = "service_log.txt";//写入日志的文件名

    private Context context;

    // 构造函数,接收 Context
    public MyLog(Context context) {
        this.context = context;
    }

    public void writeLog(String message) {
        File logFile = new File(context.getFilesDir(), LOG_FILE_NAME); // 使用内部存储
        // 获取当前日期
        LocalDateTime currentDateTime = LocalDateTime.now();//注意这里用到的是currentDateTime,不是currentDate也不是currentDateTime

        // 定义日期格式
        DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");

        // 格式化当前日期
        String formattedDateTime = currentDateTime.format(formatter);

        // 输出格式化后的日期
        //System.out.println("当前日期: " + formattedDateTime);

        try (FileWriter fileWriter = new FileWriter(logFile, true); // 以追加模式打开文件
             PrintWriter printWriter = new PrintWriter(fileWriter)) {

            printWriter.println(formattedDateTime + ":" + message); // 写入时间戳和消息
        } catch (IOException e) {
            Log.e(TAG, "Error writing to log file", e);
        }
    }
    
}

在其他代码里把活动写入日志时只需要

MyLog mylog=new MyLog(this);
mylog.writeLog("阿巴阿巴阿巴阿巴阿巴");

即可。

那么要上哪找这个日志文件呢?

直接去/data/data/your.package.name/files/ 目录下找日志就完事了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值