android File多次写入文字,保存日志

本文介绍了一个用于记录应用程序日志的日志管理系统的设计与实现。该系统能够将包含用户名、日志内容及时间戳的信息写入指定路径下的文本文件,并通过单例模式确保全局只有一个实例进行操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

package com.cuateng.office2.controller;

import com.cuateng.office2.App;
import com.cuateng.office2.constants.Constant;
import com.umeng.socialize.utils.Log;

import java.io.File;
import java.io.RandomAccessFile;
import java.text.SimpleDateFormat;
import java.util.Date;

/**
 * author li Xiao hui on 2017/1/3  14:13
 */

public class MessageLogManager {

    private String filePath = Constant.APP_FILEPATH;
    private String fileName = "log.txt";
    private static MessageLogManager manager;

    private MessageLogManager() {
    }

    public static MessageLogManager getInstance() {
        if (manager == null) {
            manager = new MessageLogManager();
        }
        return manager;
    }

    /**
     * @param content 将字符串写入到文本文件中
     */
    synchronized public void writeTxtToFile(String content) {
        //生成文件夹之后,再生成文件,不然会出错
        makeFilePath(filePath, fileName);

        String strFilePath = filePath + fileName;
        // 每次写入时,都换行写
        String strContent = App.currentUser.username + "------" + content +"---"+getTime()+ "\r\n";
        try {
            File file = new File(strFilePath);
            if (!file.exists()) {
                Log.d("TestFile", "Create the file:" + strFilePath);
                file.getParentFile().mkdirs();
                file.createNewFile();
            }
            RandomAccessFile raf = new RandomAccessFile(file, "rwd");
            raf.seek(file.length());
            raf.write(strContent.getBytes());
            raf.close();
        } catch (Exception e) {
            Log.e("TestFile", "Error on write File:" + e.getMessage());
        }
    }

    // 生成文件
    private File makeFilePath(String filePath, String fileName) {
        File file = null;
        makeRootDirectory(filePath);
        try {
            file = new File(filePath + fileName);
            if (!file.exists()) {
                file.createNewFile();
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
        return file;
    }

    // 生成文件夹
    private void makeRootDirectory(String filePath) {
        File file;
        try {
            file = new File(filePath);
            if (!file.exists()) {
                file.mkdir();
            }
        } catch (Exception e) {
            Log.i("TestFile:", e.getMessage() + "");
        }
    }

    private String getTime() {
        SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
        Date curDate = new Date(System.currentTimeMillis());
        String str = formatter.format(curDate);
        return str;
    }

    public boolean isUpdate() {

        return true;
    }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值