推荐学习资料
- 脑图
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
-
@param clazz 请求结果要解析成的java bean
-
@param url
-
@param map 请求体参数
-
@param listener
-
@param errorListener
*/
public QJRequest(Class clazz, String url, Map<String, String> map, Response.Listener listener, Response.ErrorListener errorListener) {
super(Method.POST, url, errorListener);
mClass = clazz;
mListener = listener;//模仿StringRequest的做法
requestBodyMap = map;
}
/**
-
GET 请求
-
@param url 请求的url
-
@param listener 成功的监听
-
@param errorListener 失败的监听
*/
public QJRequest(Class clazz, String url, Response.Listener listener, Response.ErrorListener errorListener) {
super(Method.GET, url, errorListener);
mClass = clazz;
mListener = listener;//模仿StringRequest的做法
}
@Override
protected Response parseNetworkResponse(NetworkResponse networkResponse) {
byte[] data = networkResponse.data;//请求成功后得到的byte数组
// 使用 Gson解析
try {
String result = new String(data, “utf-8”);//使用utf-8防止乱码问题
T bean = getGson().fromJson(result, mClass);
//返回解析后的结果
//第一个参数是解析后的结果(java bean)
//第二个参数是缓存的条目信息
return Response.success(bean, HttpHeaderParser.parseCacheHeaders(networkResponse));
} catch (IOException e) {
e.printStackTrace();
return Response.error(new ParseError(networkResponse));//返回解析错误
}
}
@Override
protected void deliverResponse(T t) {
this.mListener.onResponse(t);
}
/**
-
@return post 请求的请求体参数
-
@throws AuthFailureError
*/
@Override
protected Map<String, String> getParams() throws AuthFailureError {
return requestBodyMap;
}
/**
- @return 一个简单的单例 Gson对象
*/
private Gson getGson() {
if (mGson == null) {
mGson = new Gson();
}
return mGson;
}
/**
-
将请求加入到请求队列中
-
创建请求对象之后可以直接调用此方法,链式调用方便代码书写
*/
public void execute() {
NetworkManager.addRequest(this);
}
}
请求对象我们有了,还需要一个请求队列,我们把这个请求队列封装在网络管理类中
public class NetworkManager {
//整个app只保留和维护一个Volley请求队列
private static RequestQueue mRequestQueue;
//缓存大小是我们运行内存大小的1/4
private static final int CACHE_SIZE = (int) (Runtime.getRuntime().freeMemory() / 4);
//维护一个全局的ImageLoader
private static ImageLoader mImageLoader;//Helper that handles loading and caching images from remote URLs.
/**
-
在application 的onCreate方法中调用此方法
-
@param context getApplicationContext
*/
public static void init(Context context) {
mRequestQueue = Volley.newRequestQueue(context);
mImageLoader = new ImageLoader(mRequestQueue, new MyImageCache(CACHE_SIZE));
}
/**
- 添加请求到请求队列
*/
public static void addRequest(Request request) {
mRequestQueue.add(request);
}
/**
-
LruCache (Least Recent Use Cache)
-
当缓存空间已经满了,就会把最近最少使用的数据清除掉
-
K 存储数据的键值
-
V 存储的数据
*/
public static class MyImageCache extends LruCache<String, Bitmap> implements ImageLoader.ImageCache {
/**
- @param maxSize 缓存的大小
*/
public MyImageCache(int maxSize) {
super(maxSize);
}
/**
- @return 返回对应数据缓存的大小, 即图片的大小
*/
@Override
protected int sizeOf(String key, Bitmap value) {
//return value.getByteCount(); api 要求比较高 , 故用下面的 , 实质相同
return value.getRowBytes() * value.getHeight();
}
/**
-
从缓存里面获取对应url的图片
-
@param url 缓存的key
*/
@Override
public Bitmap getBitmap(String url) {
return get(url);//从lru cache里面获取图片
}
/**
- 把对应url的图片存进缓存
*/
@Override
public void putBitmap(String url, Bitmap bitmap) {
put(url, bitmap);
}
}
/**
- @return 全局唯一的ImageLoader
*/
public static ImageLoader getImageLoader() {
return mImageLoader;
}
}
在应用的Application中还需要初始化我们的NetWorkManager:
public class QJApplication extends Application {
@Override
public void onCreate() {
super.onCreate();
NetworkManager.init(getApplicationContext());
}
}
如此简单封装之后我们的请求就可以这么写了:
private void performGetRequest() {
String url = “http://192.168.1.9:8080/version.json”;//自己测试的url
Response.Listener listener = new Response.Listener() {
@Override
public void onResponse(VersionBean o) {
Log.d(TAG, "onResponse: " + o);
}
};
Response.ErrorListener errorListener = new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError volleyError) {
Log.d(TAG, "onErrorResponse: " + volleyError.getMessage());
}
};
new QJRequest(VersionBean.class, url, listener, errorListener).execute();//get请求封装后写法示例
}
写在最后
今天关于面试的分享就到这里,还是那句话,有些东西你不仅要懂,而且要能够很好地表达出来,能够让面试官认可你的理解,例如Handler机制,这个是面试必问之题。有些晦涩的点,或许它只活在面试当中,实际工作当中你压根不会用到它,但是你要知道它是什么东西。
最后在这里小编分享一份自己收录整理上述技术体系图相关的几十套腾讯、头条、阿里、美团等公司的面试题,把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,这里以图片的形式给大家展示一部分。
还有 高级架构技术进阶脑图、Android开发面试专题资料,高级进阶架构资料 帮助大家学习提升进阶,也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习。
【Android核心高级技术PDF文档,BAT大厂面试真题解析】
【算法合集】
【延伸Android必备知识点】
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
高级技术PDF文档,BAT大厂面试真题解析】**
[外链图片转存中…(img-ZmV4bqSj-1714974746366)]
【算法合集】
[外链图片转存中…(img-paSuymjg-1714974746367)]
【延伸Android必备知识点】
[外链图片转存中…(img-93zqbCfC-1714974746367)]
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!