一、xUtils简介

  xUtils 最初源于Afinal框架,进行了大量重构,使得xUtils支持大文件上传,更全面的http请求协议支持(10种谓词),拥有更加灵活的ORM,更多的事件注解支持且不受混淆影响...

  xUtils最低兼容android 2.2 (api level 8)。当前xUtils主要有四大模块:

  DbUtils模块

android中的orm框架,一行代码就可以进行增删改查;

支持事务,默认关闭;

可通过注解自定义表名,列名,外键,唯一性约束,NOT NULL约束,CHECK约束等(需要混淆的时候请注解表名和列名);

支持绑定外键,保存实体时外键关联实体自动保存或更新;

  ViewUtils模块

android中的ioc框架,完全注解方式就可以进行UI,资源和事件绑定;

新的事件绑定方式,使用混淆工具混淆后仍可正常工作;

  HttpUtils模块

支持同步,异步方式的请求;

支持大文件上传,上传大文件不会oom;

支持GET,POST,PUT,MOVE,COPY,DELETE,HEAD,OPTIONS,TRACE,CONNECT请求;

  BitmapUtils模块

加载bitmap的时候无需考虑bitmap加载过程中出现的oom和android容器快速滑动时候出现的图片错位等现象;

支持加载网络图片和本地图片;

内存管理使用lru算法,更好的管理bitmap内存;

二、DbUtils使用方法
DbUtils db = DbUtils.create(this);User user = new User(); //这里需要注意的是User对象必须有id属性,或者有通过@ID注解的属性user.setEmail("jerehedu@qq.com");user.setName("jerehedu");db.save(user); // 使用saveBindingId保存实体时会为实体的id赋值...// 查找Parent entity = db.findById(Parent.class, parent.getId());List<Parent> list = db.findAll(Parent.class);//通过类型查找Parent Parent = db.findFirst(Selector.from(Parent.class).where("name","=","test"));// IS NULLParent Parent = db.findFirst(Selector.from(Parent.class).where("name","=", null));// IS NOT NULLParent Parent = db.findFirst(Selector.from(Parent.class).where("name","!=", null));// WHERE id<54 AND (age>20 OR age<30) ORDER BY id LIMIT pageSize OFFSET pageOffsetList<Parent> list = db.findAll(Selector.from(Parent.class)                                   .where("id" ,"<", 54)                                   .and(WhereBuilder.b("age", ">", 20).or("age", " < ", 30))                                   .orderBy("id")                                   .limit(pageSize)                                   .offset(pageSize * pageIndex));// op为"in"时,最后一个参数必须是数组或Iterable的实现类(例如List等)Parent test = db.findFirst(Selector.from(Parent.class).where("id", "in", new int[]{1, 2, 3}));// op为"between"时,最后一个参数必须是数组或Iterable的实现类(例如List等)Parent test = db.findFirst(Selector.from(Parent.class).where("id", "between", new String[]{"1", "5"}));DbModel dbModel = db.findDbModelAll(Selector.from(Parent.class).select("name"));//select("name")只取出name列List<DbModel> dbModels = db.findDbModelAll(Selector.from(Parent.class).groupBy("name").select("name", "count(name)"));...List<DbModel> dbModels = db.findDbModelAll(sql); // 自定义sql查询db.execNonQuery(sql) // 执行自定义sql
三、HttpUtils使用方法
HttpUtils http = new HttpUtils();http.send(HttpRequest.HttpMethod.GET,    "http://www.jerehedu.com",    new RequestCallBack<String>(){        @Override        public void onLoading(long total, long current, boolean isUploading) {            testTextView.setText(current + "/" + total);        }        @Override        public void onSuccess(ResponseInfo<String> responseInfo) {            textView.setText(responseInfo.result);        }        @Override        public void onStart() {        }        @Override        public void onFailure(HttpException error, String msg) {        }});

这次就先介绍这两个utils的用法,其他方法详见https://github.com/wyouflf/xUtils ,
下次博客我也会进行介绍。

作者: 杰瑞教育
出处: http://www.cnblogs.com/jerehedu/
本文版权归烟台杰瑞教育科技有限公司和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

更多相关文章

  1. Android(安卓)SDK 3.0正式放出 —— 我的使用感受(2/23更新)
  2. Appium移动自动化框架初探
  3. android sqlite支持的数据类型
  4. Android热更新实现方式
  5. SpringSource通过Spring for Android(安卓)1.0将Spring Framewor
  6. Error:Execution failed for task ':demo:packageRelease'. > Un
  7. 几个比较混淆概念,android中的Info类以及PackageManager和Activit
  8. Android(安卓)编译时注解 —— 语法详解
  9. appium新手入门(1)—— appium介绍

随机推荐

  1. Android获取屏幕宽度的4种方法
  2. Android UI属性大解
  3. 国内目前最全面的介绍——Android中的Bro
  4. Hook android系统调用研究(一)
  5. android 建数据库 SQLite 存储sd 卡或者
  6. Android应用程序进程启动过程的源代码分
  7. Android网络连接判断与处理
  8. 安卓布局之线性布局(Linearlayout)
  9. Android EditText取消自动焦点获取
  10. 【Android】Android Layout Binder——根