android开发:使用RandomAccessFile来输出日志

RandomAccessFile是用来访问那些保存数据记录的文件的,你就可以用seek( )方法来访问记录,并进行读写了。这些记录的大小不必相同;但是其大小和位置必须是可知的。但是该类仅限于操作文件。

RandomAccessFile不属于InputStream和OutputStream类系的。实际上,除了实现DataInput和DataOutput接口之外(DataInputStream和DataOutputStream也实现了这两个接口),它和这两个类系毫不相干,甚至不使用InputStream和OutputStream类中已经存在的任何功能;它是一个完全独立的类,所有方法(绝大多数都只属于它自己)都是从零开始写的。这可能是因为RandomAccessFile能在文件里面前后移动,所以它的行为与其它的I/O类有些根本性的不同。总而言之,它是一个直接继承Object的,独立的类。

基本上,RandomAccessFile的工作方式是,把DataInputStream和DataOutputStream结合起来,再加上它自己的一些方法,比如定位用的getFilePointer( ),在文件里移动用的seek( ),以及判断文件大小的length( )、skipBytes()跳过多少字节数。此外,它的构造函数还要一个表示以只读方式(“r”),还是以读写方式(“rw”)打开文件的参数 (和C的fopen( )一模一样)。它不支持只写文件。

只有RandomAccessFile才有seek搜寻方法,而这个方法也只适用于文件。BufferedInputStream有一个mark( )方法,你可以用它来设定标记(把结果保存在一个内部变量里),然后再调用reset( )返回这个位置,但是它的功能太弱了,而且也不怎么实用。

/**
* 写出日志
*
* @param str
* @return
*/
public static boolean putTextLog(String str) {
String filepath = Environment.getExternalStorageDirectory() + “/lanxin”;

File file = new File(filepath);
if (!file.exists())
file.mkdirs();

SimpleDateFormat sdf = new SimpleDateFormat(“yyyyMMdd”);
String tmp = sdf.format(new Date());
String filename = “/” + tmp + “.log”;

sdf = new SimpleDateFormat(“yyyy-MM-dd HH:mm:ss”);
str = “[” + sdf.format(new Date()) + “]” + str + “\n”;

Log.i(“putTextLog”,str);

file = new File(filepath + filename);

try {
if (!file.exists()) {
file.createNewFile();
}
RandomAccessFile raf = new RandomAccessFile(file, “rw”);
raf.seek(file.length());
raf.write(str.getBytes());
raf.close();

} catch (IOException e) {
e.printStackTrace();
return false;
}

return true;
}

 

Leave a Comment

 
Copyright © 2008-2021 lanxinbase.com Rights Reserved. | 粤ICP备14086738号-3 |