安卓应用程序的自定义日志记录
我想为Android应用程序创建自定义记录器。日志记录应在单独的线程中完成,因为应用程序会生成大量信息。我不想使用Android日志,因为我需要以特定格式编写日志。多个线程将同时写入日志文件,因此我使用了队列来保留日志消息
这是我有的代码
Queue<LogEntry> logQueue = new LinkedBlockingQueue<LogEntry>();
LogWritterThread logWritterThread = new LogWritterThread();
// to queue the log messages
public void QueueLogEntry(String message)
{
LogEntry le = new LogEntry(message);
{
logQueue.add(le);
logQueue.notifyAll();
}
logWritterThread.start();
}
class LogWritterThread extends Thread
{
public void run()
{
try
{
while(true)
{
//thread waits until there are any logs to write in the queue
if(logQueue.peek() == null)
synchronized(logQueue){
logQueue.wait();
}
if(logQueue.peek() != null)
{
LogEntry logEntry;
synchronized(logQueue){
logEntry = logQueue.poll();
}
// write the message to file
}
if(Thread.interrupted())
break;
}
}
catch (InterruptedException e)
{
}
}
}
这段代码有什么问题吗?或创建日志记录队列的更好方法
谢谢,阿努杰