存储容量检测 注意构建StatFs对象的参数合法性

Android 2.3.3
Eclipse Version: 3.7.0
LogCat

LogCat 报错信息:

02-14 10:24:27.134: ERROR/(4355): statfs nokia failed, errno: 2
02-14 10:24:27.144: WARN/System.err(4355): java.lang.IllegalArgumentException
02-14 10:24:27.153: WARN/System.err(4355): at android.os.StatFs.native_setup(Native Method)
02-14 10:24:27.173: WARN/System.err(4355): at android.os.StatFs.(StatFs.java:32)
02-14 10:24:27.173: WARN/System.err(4355): at com.tmall.util.Devices.getBlock(Devices.java:161)
02-14 10:24:27.184: WARN/System.err(4355): at com.tmall.util.Devices.getUsedRatio(Devices.java:199)
02-14 10:24:27.184: WARN/System.err(4355): at com.tmall.nokia.Check.checkSDBlock(Check.java:271)
02-14 10:24:27.184: WARN/System.err(4355): at com.tmall.nokia.Check.run(Check.java:332)
02-14 10:24:27.195: WARN/System.err(4355): at java.lang.Thread.run(Thread.java:1019)

发生错误原因分析:
分析发生错误部分代码,发现在构建StatFs对象时出错

 

	nokiaPath = "nokia"
	StatFs sf = new StatFs(nokiaPath);

 StatFs用于对系统的存储容量进行检测。报错是因为构建StatFs对象时使用了非法参数。"nokia"不是一个合法有效的参数,合法参数应该形如"sdcard"。

 

解决办法:

使用默认的路径及名称是最好的方法

	nokiaPath = Environment.getExternalStorageDirectory().getPath();// nokiaPath ="/mnt/sdcard"
	//nokiaPath = Environment.getExternalStorageDirectory().getName();// nokiaPath ="sdcard"
	StatFs sf = new StatFs(nokiaPath);

  
如果一定需要自定义路径作为参数,也应使用类似下列格式的有效自定义路径

	nokiaPath = "/mnt/sdcard/nokia/";
	nokiaPath = "/sdcard/nokia/";
	nokiaPath = "sdcard/nokia/";

  

以合法的路径及名称作为参数,一般类似以"/mnt/sdcard" 或"sdcard/"开头的路径都是正确的。针对不同硬件,可能需要在编程中通过测试,使用有效格式。

 

你可能感兴趣的:(eclipse,android,statfs,DebugLog)