1、获取文件大小(清理缓存)
获取文件的大小(单位B)
public static long getFileSize(File file) throws Exception {
long size = 0;
if (file.exists()) {
FileInputStream fis = null;
fis = new FileInputStream(file);
size = fis.available();
} else {
file.createNewFile();
Log.e("获取文件大小", "文件不存在!");
}
return size;
}
转换单位
public static String FormetFileSize(long fileS) {
DecimalFormat df = new DecimalFormat("#.00");
String fileSizeString = "";
String wrongSize = "0B";
if (fileS == 0) {
return wrongSize;
}
if (fileS < 1024) {
fileSizeString = df.format((double) fileS) + "B";
} else if (fileS < 1048576) {
fileSizeString = df.format((double) fileS / 1024) + "KB";
} else if (fileS < 1073741824) {
fileSizeString = df.format((double) fileS / 1048576) + "MB";
} else {
fileSizeString = df.format((double) fileS / 1073741824) + "GB";
}
return fileSizeString;
}
删除文件
public static boolean deleteFile(String path){
File file = new File(path);
if (file.isFile() && file.exists()) {
return file.delete();
}
return false;
}
2、SQLite语法记录
真的好久没用过SQLite了,最近项目中用到了,然后发现自己把增删改查语法忘完了,在此整理下。
具体用法就是我们要继承SQLiteOpenHelper并实现其onCreate和onUpgrade方法。
在onCreate中创建表:
db.execSQL("create table if not exists location_info(id integer primary key autoincrement,name varchar,lan varchar,lon varchar DEFAULT 'xx')");
//可以设置默认值,在插入数据的时候如果没有设置该值就使用默认值
我项目中只需要保存数据就可以了,所以用不到onUpgrade方法。
执行数据库操作有2种方法,一种是执行sql语句,一种是执行android的api。
**
插入数据:
**
sql语句:
db.execSQL("INSERT INTO location_info VALUES(XX,XX,XX)");
也可以根据列名插入:
INSERT INTO location_info (Name,lat,lon) VALUES('xx','xx','xx');
可以只插入几个列的数据
INSERT INTO location_info (Name,lat) VALUES('xx','xx');
android API:
ContentValues values = new ContentValues();
values.put("name", name);
values.put("lan",lan);
values.put("lon",lon);
db.insert("location_info","id",values);
**
删除数据
**
SQL语句:
//按条件删除行
DELETE FROM Teachers WHERE Age>30;
DELETE FROM Teachers WHERE Age>30 and name='john';
//删除表中所有数据
DELETE FROM Teachers;
Android API:
//根据列名删除数据,好像只能根据单一条件删除
db.delete(表名,列名,列的值(string数组));
//删除表中所有数据
db.delete(表名,null,null);
**
更新数据
**
SQL语句:
//更新数据也是根据条件某个条件去更新的
UPDATE Teachers SET Country='America' WHERE Id=3;
UPDATE Teachers SET Country='India' WHERE Age<30;
Android API:
//先通过contentvalues设置好需要更新的数据,然后根据列名对应的值去更新这个数据
db.update(表名,contentValues,列名,new String[]{});
**
查询数据
**
SQL语句:
//根据条件去查询条件
//查询所有
SELECT * FROM 表名;
//限制返回数量
SELECT * FROM Cars LIMIT 4;
//还可以设置返回的起始位置,从索引为2的位置开始返回4个数据
SELECT * FROM Cars LIMIT 4 OFFSET 2;
//条件查询
//LIKE 用通配符匹配字符串
//下划线 _ 匹配一个字符串
//百分号 % 匹配多个字符串
//LIKE 匹配字符串时不区分大小写
SELECT * FROM Cars WHERE Name Like '____';
SELECT * FROM Cars WHERE Name Like '%en';
//between
SELECT * FROM Cars WHERE Cost BETWEEN 20000 AND 55000;
//对应列的名称必须在集合中
SELECT * FROM Cars WHERE Name IN ('Audi','Hummer');
//排序
SELECT Name, Cost FROM Cars ORDER BY Cost DESC;
Android API:
db.query(...)
db.rawQuery(...)
3、listview的使用注意事项
- 、有时候因为一些需要,我们需要在适配器中进行判断,因为listview复用的原因,所以一定要注意在有if的地方一定要加上else。不然会导致错乱
- 图片错乱的处理,尽量加载小图片,上传服务器时先压缩
- 加载图片前使用默认图,加载完成后再设置上去,
- 给图片设置tag,可以是图片的url。设置tag一定要放在获取convertview之后
4、double类型数据运算
比如double类型的数据相加,直接相加会存在精度丢失的情况。
涉及到精度的计算,可以使用Math包下的BigDecimal函数
先转为string,然后进行运算
double v=Double.parseDouble(endParkBean.getTotalAmount());
double v1 = Double.parseDouble(coupon);
BigDecimal b1 = new BigDecimal(Double.toString(v));
BigDecimal b2 = new BigDecimal(Double.toString(v1));
return b1.add(b2);
5、点击应用图标可以进入应用,第三方应用程序也可以跳转过去,2者的区别?
点击桌面上的图标进入应用:是因为启动程序(主界面也是一个应用,launcher)发现这个应用程序中存在一个设置为
<category android:name="android.intent.category.LAUNCHER" />
的activity,所以这个launcher会把这个activity的icon提取出来放在桌面。当用户点击这个icon时,会发出一个intent:
Intent intent=
mActivity.getPackageManager().getLaunchIntentForPackage(packageName);
mActivity.startActivity(intent);
然后打开应用。
第三方应用程序打开该应用的道理是一样的,也是通过intent跳转activity的方式。系统会根据第三方程序向系统注册的功能,为你的Intent选择可以打开的程序或者页面。
区别就是:从首页点击icon进入应用程序的action是相对单一的,但是第三方页面进入的话action更多一些,所以可以进入到不同的页面。