Android基础:外部存储写入日志教程

需积分: 1 0 下载量 81 浏览量 更新于2024-09-15 收藏 2KB TXT 举报
"本文档主要介绍了Android基础中的日志写入外部存储卡的操作方法。" 在Android开发中,日志系统是调试和分析应用行为的重要工具。Android提供了多种级别的日志输出,如`Log.d()`、`Log.i()`、`Log.w()`、`Log.e()`等,用于记录不同级别的信息。在给定的代码片段中,我们看到的是如何将自定义的日志信息写入到设备的外部存储卡上,以便于后期分析或导出。 首先,代码检查是否能够写入外部存储卡,这是通过调用`Environment.getExternalStorageDirectory().canWrite()`实现的。如果返回`true`,说明应用有权限向外部存储卡写入数据。 然后,定义了一个路径变量`logpath`,它是外部存储卡的根目录加上一个名为"logMessages"的子目录。`File.separator`是根据平台(这里是Android)自动选择正确的路径分隔符。 接着,有两种不同的方式来写入日志文件: 1. 使用`FileOutputStream`: 这部分被注释掉了,但我们可以看到它首先尝试创建一个新的`FileOutputStream`实例,指向`logpath`。然后,将消息转换为字节数组,并写入到输出流中,最后关闭流。这段代码没有处理异常,这在实际开发中应避免,因为文件操作可能抛出异常。 2. 使用`BufferedWriter`: 这是实际执行的部分,它创建了一个`BufferedWriter`,通过`OutputStreamWriter`和`FileOutputStream`连接到`logpath`,并设置为追加模式,这样新的日志条目会被添加到现有文件的末尾。接着,使用`write()`方法写入消息,加上换行符`\r\n`,并在完成后关闭`BufferedWriter`。这里对异常进行了适当的处理,确保即使在发生错误时也能关闭流。 另外,还有一段被注释掉的代码尝试使用`context.openFileOutput()`,这是一个用于打开内部存储的函数,与外部存储的写入方式不同。内部存储通常用于保存应用私有的数据,而外部存储则允许用户访问和管理文件。 在实际开发中,写入外部存储的代码需要考虑权限问题。从Android 6.0(API级别23)开始,应用需要在运行时请求`WRITE_EXTERNAL_STORAGE`权限,即使在清单文件中声明了该权限。同时,为了兼容性,应该使用`Environment.getExternalStorageDirectory()`的替代方法,如`getExternalFilesDir()`或`getExternalCacheDir()`,这些方法会返回应用特定的外部存储目录,不需要额外的权限请求。