容易遗忘的东西(持续添加中)

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的使用注意事项

  1. 、有时候因为一些需要,我们需要在适配器中进行判断,因为listview复用的原因,所以一定要注意在有if的地方一定要加上else。不然会导致错乱
  2. 图片错乱的处理,尽量加载小图片,上传服务器时先压缩
  3. 加载图片前使用默认图,加载完成后再设置上去,
  4. 给图片设置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更多一些,所以可以进入到不同的页面。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值