Android中使用正确参数构建StatFs对象

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/"开头的路径都是正确的。具体情况需要在编程中测试一下。

你可能感兴趣的:(eclipse,编程,android,测试,存储,HTC)