file.delete() 无法删除文件的问题

xiaoxiao2021-02-28  42

这几天遇到一个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在编译器中是不报错的。

转载请注明原文地址: https://www.6miu.com/read-2630828.html

最新回复(0)