【Android】私有目录获取方法

cache缓存目录

上下文提供的 getCacheDir()

返回值 方法 获取路径
File getCacheDir() 获取/data/user/packagename/cache目录,应用程序的缓存目录,该目录内的文件在设备内存不足时会优先被删除掉,所以存放在这里的文件是没有任何保障的

 files目录

上下文提供了两个方法,用于操作私有目录文件的输入和输出

返回值 方法 获取路径
File getFilesDir() 获取/data/user/packagename/files目录
FileOutputStream openFileOutput(String fileName, int mode)

直接指定到/data/user/packagename/files/fileName目录下的文件.

四种模式Mode值:

  • MODE_PRIVATE
  • MODE_APPEND
  • MODE_WORLD_READABLE
  • MODE_WORLD_WRITEABLE

操作模式可以叠加,如:

openFileOutput("file.txt", MODE_PRIVATE + MODE_APPEND);

FileInputStream openFileInput(String fileName) 直接指定到/data/user/packagename/files/fileName目录下的文件

四种模式,意义分别为(模式为Context中的字段值):

  • MODE_PRIVATE:为默认操作模式,代表该文件是私有数据,只能被应用本身访问,在该模式下,写入的内容会覆盖原文件的内容,如果想把新写入的内容追加到原文件中,可以使用MODE_APPEND。
  • MODE_APPEND:模式会检查文件是否存在,存在就往文件追加内容,否则就创建新文件。
  • MODE_WORLD_READABLE:表示该文件可以被其他应用读取。
  • MODE_WORLD_WRITEABLE:表示该文件可以被其他应用写入。

不传递参数MODE_WORLD_READABLEMODE_WORLD_WRITEABLE 模式则默认其它程序不可操作此程序在files目录下更改的new 新文件

shared_prefs键值对文件目录

SharedPreferences sp = Context.getSharedPreferences(String fileName, int mode);

 如果指定的文件为null,则会自动创建。

databases数据库目录

 查找指定名字的数据库文件,如果没有的话,会创建一个新的。创建数据库的时候,也需要指定模式:

SQLiteDatabase db = Context.openOrCreateDatabase(String dbName, int mode, CursorFactory factory);

 该方法将返回一个指向指定数据库文件的File对象: 

File dbFile = Context.getDatabasePath(String name);

databases/目录下全部数据库文件:

String[] dbsName = Context.databaseList();

如果指定名字的数据库文件被删除成功将返回true,反之返回false:

boolean Context.deleteDatabase(String dbName);

lib目录 

  • 这个子目录存放着的是应用程序需要使用的Native原生程序,即JNI调用需要加载的.so文件。
  • 这些文件一般是位于apk安装包里的lib目录下。在程序安装的时候,系统会将所有apk文件中lib目录下的所有原生程序拷贝到这个子目录下。
  • 该目录是程序不能操作的,不能在程序运行时,向该目录拷贝.so文件,然后再通过调用System.loadLibrary函数将其加载进来。

自定义目录

File Context.getDir(String name, int mode);

 该方法返回指向/data/data//下指定名称的文件夹的一个File对象。如果该文件夹不存在则用指定名称创建一个新的文件夹。

你可能感兴趣的:(Android,随笔,Android,Android私有目录获取)