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在编译器中是不报错的。



本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部