目录存在吗:false
目录存在吗:true
从Log可以看出,在调用了getExternalFilesDir(Environment.DIRECTORY_DOCUMENTS)方法之后,系统就会自动创建出对应的目录,系统创建出应用目录之后,我们就可以在里面自由的创建目录和文件了,示例如下:
val documentDir = getExternalFilesDir(Environment.DIRECTORY_DOCUMENTS)
val logDir = File(documentDir, "/logs")
if (!logDir.exists()) logDir.mkdirs() // 如果log目录不存在,必须先创建
val logFile = File(logDir, "log.txt")
BufferedWriter(OutputStreamWriter(FileOutputStream(logFile))).use {
it.write("Hello World!")
}
Log.i("ABCD","logFile是否存在:${logFile.exists()}")
需要注意的是,我们需要用新的目录时,需要先调用mkdirs创建出来之后才能往里面写文件,而写文件时,不需要调用file.createNewFile()来创建文件,直接使用输出流写东西就会自动创建出文件了。
OK,到这里,我们就可以知道了logback是直接使用目录路径然后调用mkdirs来创建应用目录的,所以才会创建失败,解决方案也很简单,我们没法修改logback框架,但是我们可以在使用logback前先调用getExternalFilesDir(Environment.DIRECTORY_DOCUMENTS)让系统创建出应用的目录,这样logback再创建目录时就不会失败了,示例如下:
context.getExternalFilesDir(Environment.DIRECTORY_DOCUMENTS)
val logger = LoggerFactory.getLogger(Timber::class.java)
logger.info("Hello World!")
这里需要注意的是Environment.DIRECTORY_DOCUMENTS是API 19(Android4.4)才出来的,想兼容到更低版本,这让我不得不去了解一下getExternalFilesDir()函数的声明,通过官方声明了解到,如果参数传null,则返回应用的文件的根目录,如果传了具体的值,则返回具体值的子目录,示例如下:
getExternalFilesDir(null)
getExternalFilesDir("mydir")
返回的目录为:
/sdcard/Android/data/应用包名/files
/sdcard/Android/data/应用包名/files/mydir
最后
其实Android开发的知识点就那么多,面试问来问去还是那么点东西。所以面试没有其他的诀窍,只看你对这些知识点准备的充分程度。so,出去面试时先看看自己复习到了哪个阶段就好。
虽然 Android 没有前几年火热了,已经过去了会四大组件就能找到高薪职位的时代了。这只能说明 Android 中级以下的岗位饱和了,现在高级工程师还是比较缺少的,很多高级职位给的薪资真的特别高(钱多也不一定能找到合适的),所以努力让自己成为高级工程师才是最重要的。
这里附上上述的面试题相关的几十套字节跳动,京东,小米,腾讯、头条、阿里、美团等公司21年的面试题。把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。
由于篇幅有限,这里以图片的形式给大家展示一小部分。
网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
618156601)**
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!