file.delete() 无法删除文件的问题
这几天遇到一个bug,使用file.delete()方法无法删除文件,在网上找了些资料基本上都是说的写文件时候没有正常关闭导致的,而且在 logcat 中也报了相关的错误,但是查代码时候怎么也里不出来哪里错了。最终在同事的帮助下查处了bug所在,具体原理还没有深究,这周末就搞一搞这方面的东西。
以下是原来的代码:
Log.d(TAG, "onClick: " + uri.toString());File file = new File(uri.toString());System.gc();boolean success = file.delete();if ( success ){Log.d(TAG, "onClick: 成功删除文件");} else {Log.d(TAG, "onClick: 删除功能待添加");
以下是修正后的代码:
Log.d(TAG, "onClick: " + path);File file = new File(path);System.gc();boolean success = file.delete();/*boolean result = false;int tryCount = 0;while(!result && tryCount++ <10){System.gc();result = file.delete();}*/if ( success ){Log.d(TAG, "onClick: 成功删除文件");} else {Log.d(TAG, "onClick: 删除功能待添加");
}
打印出来的log:
原代码
file:///sdcard/MyVoiceForder/Record/db21c25b-97ec-4663-b0e5-1dcd4142dade.wav
修改后代的代码
/sdcard/MyVoiceForder/Record/db21c25b-97ec-4663-b0e5-1dcd4142dade.wav
以上对比就很明显了,是delete()的传入参数有误,导致文件无法删除,而且这样的bug在编译器中是不报错的。
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
