Android 2.3.3
Eclipse Version: 3.7.0
LogCat
LogCat 报错信息:
02-14 11:54:12.834: ERROR/(2525): statfs htc failed, errno: 2
02-14 11:54:12.844: WARN/System.err(2525): java.lang.IllegalArgumentException
02-14 11:54:12.853: WARN/System.err(2525): at android.os.StatFs.native_setup(Native Method)
02-14 11:54:12.873: WARN/System.err(2525): at android.os.StatFs.(StatFs.java:32)
02-14 11:54:12.873: WARN/System.err(2525): at com.taobao.util.Devices.getBlock(Devices.java:161)
02-14 11:54:12.884: WARN/System.err(2525): at com.taobao.util.Devices.getUsedRatio(Devices.java:199)
02-14 11:54:12.884: WARN/System.err(2525): at com.taobao.htc.Check.checkSDBlock(Check.java:271)
02-14 11:54:12.884: WARN/System.err(2525): at com.taobao.htc.Check.run(Check.java:332)
02-14 11:54:12.895: WARN/System.err(2525): at java.lang.Thread.run(Thread.java:1019)
发生错误原因分析:
分析发生错误部分代码,发现在构建StatFs对象时出错
sdpath = "htc/";
StatFs sf = new StatFs(sdpath);
StatFs用于对系统的存储容量进行检测。报错是因为构建StatFs对象时使用了非法参数。"htc/"不是一个合法有效的参数,合法参数应该形如“"/mnt/sdcard”。
解决办法:
使用默认的路径及名称是最好的方法
sdpath = Environment.getExternalStorageDirectory().getPath();// sdpath ="/mnt/sdcard"
//sdpath = Environment.getExternalStorageDirectory().getName();// sdpath ="sdcard"
StatFs sf = new StatFs(sdpath);
如果一定需要自定义路径作为参数,也应使用类似下列格式的有效自定义路径
sdpath = "/mnt/sdcard/htc/";
sdpath = "/sdcard/htc/";
sdpath = "sdcard/htc/";
以合法的路径及名称作为参数,一般类似以"/mnt/sdcard" 或"sdcard/"开头的路径都是正确的。具体情况需要在编程中测试一下。