转载请标明出处:

http://www.cnblogs.com/why168888/p/6681232.html

本文出自:【Edwin博客园】

Volley

介绍

  • Android系统中主要提供了两种方式来进行HTTP通信,HttpURLConnection和HttpClient

  • Android 4.4以上使用HttpURLConnection底层使用OkHttp实现

  • Volley自带Request

    • StringRequest
    • ImageRequest
    • JsonObjectRequest
    • ClearCacheRequest
  • 对Volley扩展的Request

    • XMLRequest
    • JsonArrayRequest
    • MultipartRequest
    • GsonRequest
  • HttpStack

    • HurlStack
    • HttpClientStack
    • OkApacheClientStack
    • OkHttpURLConnectionStack
  • 实现底层HttpURLConnection替换成OkHttp

  • TrafficStats——流量统计类的范例,获取实时网速

    • static long getMobileRxBytes() //获取通过Mobile连接收到的字节总数,不包含WiFi
    • static long getMobileRxPackets() //获取Mobile连接收到的数据包总数
    • static long getMobileTxPackets() //Mobile发送的总数据包数
    • static long getTotalRxBytes() //获取总的接受字节数,包含Mobile和WiFi等
    • static long getTotalRxPackets() //总的接受数据包数,包含Mobile和WiFi等
    • static long getTotalTxBytes() //总的发送字节数,包含Mobile和WiFi等
    • static long getTotalTxPackets() //发送的总数据包数,包含Mobile和WiFi等
    • static long getUidRxBytes(int uid) //获取某个网络UID的接受字节数,某一个进程的总接收量
    • static long getUidTxBytes(int uid) //获取某个网络UID的发送字节数,某一个进程的总发送量
  • Process.setThreadPriority(Process.THREAD_PRIORITY_BACKGROUND);//设置线程优先级为后台,这样当多个线程并发后很多无关紧要的线程分配的CPU时间将会减少,有利于主线程的处理,有以下几种:

    • int THREAD_PRIORITY_AUDIO //标准音乐播放使用的线程优先级
    • int THREAD_PRIORITY_BACKGROUND //标准后台程序
    • int THREAD_PRIORITY_DEFAULT // 默认应用的优先级
    • int THREAD_PRIORITY_DISPLAY //标准显示系统优先级,主要是改善UI的刷新
    • int THREAD_PRIORITY_FOREGROUND //标准前台线程优先级
    • int THREAD_PRIORITY_LESS_FAVORABLE //低于favorable
    • int THREAD_PRIORITY_LOWEST //有效的线程最低的优先级
    • int THREAD_PRIORITY_MORE_FAVORABLE //高于favorable
    • int THREAD_PRIORITY_URGENT_AUDIO //标准较重要音频播放优先级
    • int THREAD_PRIORITY_URGENT_DISPLAY //标准较重要显示优先级,对于输入事件同样适用。

参考资料

示例代码

compile 'com.squareup.okhttp3:okhttp-urlconnection:3.6.0'
compile 'com.squareup.okhttp3:okhttp-apache:3.6.0'
compile 'com.squareup.okhttp3:okhttp:3.6.0'
compile 'com.squareup.okhttp3:logging-interceptor:3.6.0'
compile 'com.google.code.gson:gson:2.8.0'
/**
* 请求方式一:
* <p>
* volley默认的请求方式
* 2.3以后底层用的是HttpURLConnection
*/
void HttpRequest$1() {
RequestQueue queue = Volley.newRequestQueue(this);
queue.add(initializedRequest());
} /**
* 请求方式二:
* 底层使用okHttp-apache
*/
void HttpRequest$2() {
OkApacheClient okApacheClient = new OkApacheClient();
OkApacheClientStack clientStack = new OkApacheClientStack(okApacheClient); RequestQueue queue = Volley.newRequestQueue(this, clientStack);
queue.add(initializedRequest());
} /**
* 请求方式三:
* 底层使用okHttp-urlConnection
*/
void HttpRequest$3() {
OkHttpURLConnectionStack clientStack = new OkHttpURLConnectionStack(); RequestQueue queue = Volley.newRequestQueue(this, clientStack);
queue.add(initializedRequest());
} Request initializedRequest() {
return new StringRequest(Request.Method.GET,
"http://www.aybrowser.com/sdk/partners/",
new Response.Listener<String>() {
@Override
public void onResponse(String response) {
Log.e("Edwin", "response = " + response);
}
},
new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
Log.e("Edwin", "VolleyError = " + error);
}
});
} /**
* post请求
* 多类型上传
* 文件+字符
*/
void MultipartRequest$4() {
try {
//构造参数列表
List<Part> partList = new ArrayList<Part>();
partList.add(new StringPart("username", "edwin"));
partList.add(new StringPart("email", "edwin.wu@gmail.com")); String path = Environment.getExternalStorageDirectory().getAbsolutePath() + "/ic_launcher.png";
partList.add(new FilePart("ic_launcher", new File(path))); //获取队列
RequestQueue requestQueue = Volley.newRequestQueue(this);
String url = "http://www.cnblogs.com/";
//生成请求
MultipartRequest profileUpdateRequest = new MultipartRequest(url,
partList.toArray(new Part[partList.size()]),
new Response.Listener<String>() {
@Override
public void onResponse(String response) {
Log.e("Edwin", "onResponse : " + response);
}
},
new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
Log.e("Edwin", "MultipartRequest : " + error.getMessage(), error);
}
}) {
@Override
public String getBodyContentType() {
return super.getBodyContentType();
} };
requestQueue.add(profileUpdateRequest);
} catch (Exception e) {
e.printStackTrace();
}
}

Android Volley源码分析及扩展的更多相关文章

  1. Android base-adapter-helper 源码分析与扩展

    转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/44014941,本文出自:[张鸿洋的博客] 本篇博客是我加入Android 开源项 ...

  2. Android Volley源码分析

    今天来顺手分析一下谷歌的volley http通信框架.首先从github上 下载volley的源码, 然后新建你自己的工程以后 选择import module 然后选择volley. 最后还需要更改 ...

  3. [Android]Volley源码分析(五)

    前面几篇通过源码分析了Volley是怎样进行请求调度及请求是如何被实际执行的,这篇最后来看下请求结果是如何交付给请求者的(一般是Android的UI主线程). 类图:

  4. [Android]Volley源码分析(三)

    上篇看了关于Request的源码,这篇接着来看下RequestQueue的源码. RequestQueue类图:

  5. [Android]Volley源码分析(二)

    上一篇介绍了Volley的使用,主要接触了Request与RequestQueue这两个类,这篇就来了解一下这两个类的具体实现. Request类图:

  6. [Android]Volley源码分析(四)

    上篇中有提到NetworkDispatcher是通过mNetwork(Network类型)来进行网络访问的,现在来看一下关于Network是如何进行网络访问的. Network部分的类图:

  7. [Android]Volley源码分析(一)

    一. 如何使用Volley? 1. 首先定义一个RequestManager类,用来在Android程序启动时对Volley进行初始化.RequestManager为单例类,因为只有在程序启动时调用, ...

  8. Volley源码分析(2)----ImageLoader

    一:imageLoader 先来看看如何使用imageloader: public void showImg(View view){ ImageView imageView = (ImageView) ...

  9. Appium Android Bootstrap源码分析之启动运行

    通过前面的两篇文章<Appium Android Bootstrap源码分析之控件AndroidElement>和<Appium Android Bootstrap源码分析之命令解析 ...

随机推荐

  1. 带你走近WebSocket协议

    一.WebSocket协议是什么? WebSocket 是 HTML5 开始提供的一种在单个 TCP 连接上进行全双工通讯的协议. 二.那为什么我们要用WebSocket协议呢? 了解计算机网络协议的 ...

  2. IOS项目之弹出动画终结篇

    在之前写过IOS项目之弹出动画一.IOS项目之弹出动画二.IOS项目之弹出动画三,今天来一个终极封装已经上传到Github上弹出动画总结篇UIPopoverTableView. UIPopoverTa ...

  3. Modbus Com SerialPort

    项目中用到的工具,串口modbus协议读写数据. public class ModbusHelper { private readonly SerialPort _serialPort; privat ...

  4. nodejs记录2——一行代码实现文件下载

    主要使用fs模块的pipe方法,简单粗暴: import fs from "fs"; import path from 'path'; import request from 'r ...

  5. 最短路问题(dijkstral 算法)(优化待续)

    迪杰斯特拉算法是由荷兰计算机科学家狄克斯特拉于1959 年提出的,因此又叫狄克斯特拉算法.是从一个顶点到其余各顶点的最短路径算法,解决的是有向图中最短路径问题.迪杰斯特拉算法主要特点是以起始点为中心向 ...

  6. Struts2 (四) — 拦截器

    一.拦截器 1.概述 1.1什么是拦截器 ​ 在struts2中,拦截器(Interceptor)是用来动态拦截Action执行的对象. ​ 拦截器有点类似以前Servlet阶段的Filter(过滤器 ...

  7. Windows命令行方式执行OracleSQL脚本

    调用格式 sqlplus user/pwd@orcl @F:\DB_BAKFile\createpro.sql>>F:\DB_BAKFile\log\createpro.log SQL脚本 ...

  8. web杂记-禁止输入框自动填充文字

    1:背景 公司基于业务需求开发了一套纯JS的时间控件,本来用得好好得.后来发现在部分浏览器下使用该时间控件会出现输入框自动填充的部分与控件的展示产生了冲突: 如图: 2:问题分析 因为部分浏览太人性化 ...

  9. 事件处理程序DOM0,DOM2,IE的区别总结

    一.事件流   顺序 备注 事件冒泡 目标对象~document对象   事件捕获 document对象~目标对象 老版本浏览器不支持 DOM事件流 document对象~目标对象~document对 ...

  10. js 对象数组去重

    var arr = [{ "name": "ZYTX", "age": "Y13xG_4wQnOWK1QwJLgg11d0pS4h ...