【小白 新手向】 图片三级缓存的快乐你真的GET到了吗?看完必入门的文章。(转载)

本文主要是介绍【小白 新手向】 图片三级缓存的快乐你真的GET到了吗?看完必入门的文章。(转载),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

图片三级缓存
(零)图片三级缓存的具体实现步骤
(一)网络缓存
NetCacheUtils网络缓存工具类
(二)本地缓存
工具类 MD5Encoder 加密
LocalCacheUtels 本地缓存工具类
(三)内存缓存
MemoryCacheUtils 内存缓存工具类
(四)图片三级缓存工具类整合
(零)图片三级缓存的具体实现步骤

  • 三级缓存设计步骤:
  • 从内存中取图片
  • 从本地文件中取图片
  • 向内存中保持一份
  • 请求网络图片,获取图片,显示到控件上(Hanlder,postion):
  • 向内存 存一份
  • 向本地文件中存一份
    1
    2
    3
    4
    5
    6
    7
    8
    9
    因此我们的储存的逻辑是从网络请求开始写的,第二步实现本地缓存,第三步最后实现内存缓存。

其中从内存缓存中获取最快,本地缓存次之,网络请求垫底。

(一)网络缓存
因为网络缓存中需要,向内存 存一份,向本地文件中存一份,因此需要把内存和本地缓存的工具类实例传进来。

NetCacheUtils网络缓存工具类
public class NetCacheUtils {

//请求图片成功
public static final int SUCESS = 1;
public static final int FAIL = 2;//本地缓存工具类
private final LocalCacheUtels localCacheUtils;//内存缓存工具类
private final MemoryCacheUtils memoryCacheUtils;//线程池服务类
private ExecutorService service;public NetCacheUtils( LocalCacheUtels localCacheUtels, MemoryCacheUtils memoryCacheUtils) {this.localCacheUtils = localCacheUtels;this.memoryCacheUtils = memoryCacheUtils;
}//联网请求得到图片
public void getBitmapFromNet(String imageUrl, int position) {service= Executors.newFixedThreadPool(10);service.execute(new MyRunnable(imageUrl,position));
}class MyRunnable implements Runnable{private final int position;private String imageUrl;public MyRunnable(String imageUrl, int position) {this.imageUrl = imageUrl;this.position = position;}@Overridepublic void run() {//子线程//请求网络图片try {HttpURLConnection connection = (HttpURLConnection) new URL(imageUrl).openConnection();connection.setRequestMethod("GET");connection.setConnectTimeout(4000);connection.setReadTimeout(4000);connection.connect();//可写 可不写int code = connection.getResponseCode();if (code == 200){InputStream is = connection.getInputStream();Bitmap bitmap = BitmapFactory.decodeStream(is);//在内存中缓存一份memoryCacheUtils.putBitmap(imageUrl,bitmap);//在本地中缓存一份localCacheUtils.putBitmap(imageUrl,bitmap);}} catch (IOException e) {e.printStackTrace();}}
}

}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
(二)本地缓存
工具类 MD5Encoder 加密
//该工具类直接复制粘贴 即可使用
public class MD5Encoder {
public static String encode(String string) throws Exception {
byte[] hash = MessageDigest.getInstance(“MD5”).digest(string.getBytes(“UTF-8”));
StringBuilder hex = new StringBuilder(hash.length * 2);
for (byte b : hash) {
if ((b & 0xFF) < 0x10) {
hex.append(“0”);
}
hex.append(Integer.toHexString(b & 0xFF));
}
return hex.toString();
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
LocalCacheUtels 本地缓存工具类
class LocalCacheUtels {

private final MemoryCacheUtils memoryCacheUtils;//传入内存缓存工具类实例
public LocalCacheUtels(MemoryCacheUtils memoryCacheUtils) {this.memoryCacheUtils = memoryCacheUtils;
}/*** 获取储存图片* @param imageUrl* @return*/
public Bitmap getBitmapFromUrl(String imageUrl) {//判断sd卡是否可用if (Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)){try {String fileName = MD5Encoder.encode(imageUrl);File file = new File("/data/data/com.coderpig.beijingnews/beijingnews/",fileName);if (file.exists()){FileInputStream is = new FileInputStream(file);Bitmap bitmap = BitmapFactory.decodeStream(is);if (bitmap!=null){memoryCacheUtils.putBitmap(imageUrl,bitmap);LogUtil.e("从本地保存到内存中");}return bitmap;}} catch (Exception e) {e.printStackTrace();LogUtil.e("图片本地获取失败");}}return null;
}/*** 根据Url 保存图片* @param imageUrl:url* @param bitmap:图片*/
public void putBitmap(String imageUrl, Bitmap bitmap) {//保存图片在 /mnt/sdcard/beijingnews/http://。。。。。///data/data/com.coderpig.beijingnews/beijingnews//判断sd卡是否可用if (Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)){try {String fileName = MD5Encoder.encode(imageUrl);//LogUtil.e("图片保存地址是:" + Environment.getExternalStorageDirectory().toString());File file = new File("/data/data/com.coderpig.beijingnews/beijingnews/",fileName);if (!file.exists()){file.createNewFile();}//保存图片bitmap.compress(Bitmap.CompressFormat.PNG,100,new FileOutputStream(file));LogUtil.e("图片本地缓存--成功");} catch (Exception e) {e.printStackTrace();LogUtil.e("图片本地缓存--失败");}}}

}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
(三)内存缓存
MemoryCacheUtils 内存缓存工具类
不得不提一下LruCache是面试常客,知道怎么用,却不知道它是怎么干的,这就出大问题,知其然得知其所以然,下面这篇链接的文章 可以带你进行一次源码层的遨游。
LruCache实现原理分析 作者:胖子爱你520

class MemoryCacheUtils {

private LruCache<String, Bitmap> lruCache;public MemoryCacheUtils() {//使用系统分配给应用的内存的八分之一int maxSize = (int) (Runtime.getRuntime().maxMemory()/8);lruCache = new LruCache<String, Bitmap>(maxSize){@Overrideprotected int sizeOf(String key, Bitmap value) {return value.getRowBytes() * value.getHeight();}};}/*** 根据url去取* @param imageUrl* @return*/
public Bitmap getBitmapFromUrl(String imageUrl) {return lruCache.get(imageUrl);
}/*** 根据ur保存图片到lrucache集合中* @param imageUrl* @param bitmap*/
public void putBitmap(String imageUrl, Bitmap bitmap) {lruCache.put(imageUrl,bitmap);
}

}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
(四)图片三级缓存工具类整合
private MemoryCacheUtils memoryCacheUtils;

public BitmapCacheUtils(){memoryCacheUtils = new MemoryCacheUtils();localCacheUtels = new LocalCacheUtels(memoryCacheUtils);netCacheUtils = new NetCacheUtils(localCacheUtels,memoryCacheUtils);
}/*** 三级缓存设计步骤:* 从内存中取图片** 从本地文件中取图片* 向内存中保持一份** 请求网络图片,获取图片,显示到控件上(Hanlder,postion):* 向内存 存一份* 向本地文件中存一份* @param imageUrl* @param position* @return*/
public Bitmap getBitmap(String imageUrl, int position) {//1.从内存中取图片if (memoryCacheUtils!=null){Bitmap bitmap = memoryCacheUtils.getBitmapFromUrl(imageUrl);if (bitmap != null){LogUtil.e("内存加载图片==成功"+position);return bitmap;}}//2.从本地文件中取图片if (localCacheUtels != null){Bitmap bitmap = localCacheUtels.getBitmapFromUrl(imageUrl);if (bitmap != null){LogUtil.e("本地加载图片==成功"+position);return bitmap;}}//3.请求网络图片,获取图片netCacheUtils.getBitmapFromNet(imageUrl,position);return null;
}

}

原文链接:https://blog.csdn.net/weixin_42765222/article/details/107595950?utm_medium=distribute.pc_feed.none-task-blog-alirecmd-4.nonecase&depth_1-utm_source=distribute.pc_feed.none-task-blog-alirecmd-4.nonecase&request_id=

这篇关于【小白 新手向】 图片三级缓存的快乐你真的GET到了吗?看完必入门的文章。(转载)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/480924

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

缓存雪崩问题

缓存雪崩是缓存中大量key失效后当高并发到来时导致大量请求到数据库,瞬间耗尽数据库资源,导致数据库无法使用。 解决方案: 1、使用锁进行控制 2、对同一类型信息的key设置不同的过期时间 3、缓存预热 1. 什么是缓存雪崩 缓存雪崩是指在短时间内,大量缓存数据同时失效,导致所有请求直接涌向数据库,瞬间增加数据库的负载压力,可能导致数据库性能下降甚至崩溃。这种情况往往发生在缓存中大量 k

数论入门整理(updating)

一、gcd lcm 基础中的基础,一般用来处理计算第一步什么的,分数化简之类。 LL gcd(LL a, LL b) { return b ? gcd(b, a % b) : a; } <pre name="code" class="cpp">LL lcm(LL a, LL b){LL c = gcd(a, b);return a / c * b;} 例题:

Java 创建图形用户界面(GUI)入门指南(Swing库 JFrame 类)概述

概述 基本概念 Java Swing 的架构 Java Swing 是一个为 Java 设计的 GUI 工具包,是 JAVA 基础类的一部分,基于 Java AWT 构建,提供了一系列轻量级、可定制的图形用户界面(GUI)组件。 与 AWT 相比,Swing 提供了许多比 AWT 更好的屏幕显示元素,更加灵活和可定制,具有更好的跨平台性能。 组件和容器 Java Swing 提供了许多

【IPV6从入门到起飞】5-1 IPV6+Home Assistant(搭建基本环境)

【IPV6从入门到起飞】5-1 IPV6+Home Assistant #搭建基本环境 1 背景2 docker下载 hass3 创建容器4 浏览器访问 hass5 手机APP远程访问hass6 更多玩法 1 背景 既然电脑可以IPV6入站,手机流量可以访问IPV6网络的服务,为什么不在电脑搭建Home Assistant(hass),来控制你的设备呢?@智能家居 @万物互联

poj 2104 and hdu 2665 划分树模板入门题

题意: 给一个数组n(1e5)个数,给一个范围(fr, to, k),求这个范围中第k大的数。 解析: 划分树入门。 bing神的模板。 坑爹的地方是把-l 看成了-1........ 一直re。 代码: poj 2104: #include <iostream>#include <cstdio>#include <cstdlib>#include <al

MySQL-CRUD入门1

文章目录 认识配置文件client节点mysql节点mysqld节点 数据的添加(Create)添加一行数据添加多行数据两种添加数据的效率对比 数据的查询(Retrieve)全列查询指定列查询查询中带有表达式关于字面量关于as重命名 临时表引入distinct去重order by 排序关于NULL 认识配置文件 在我们的MySQL服务安装好了之后, 会有一个配置文件, 也就

Android 10.0 mtk平板camera2横屏预览旋转90度横屏拍照图片旋转90度功能实现

1.前言 在10.0的系统rom定制化开发中,在进行一些平板等默认横屏的设备开发的过程中,需要在进入camera2的 时候,默认预览图像也是需要横屏显示的,在上一篇已经实现了横屏预览功能,然后发现横屏预览后,拍照保存的图片 依然是竖屏的,所以说同样需要将图片也保存为横屏图标了,所以就需要看下mtk的camera2的相关横屏保存图片功能, 如何实现实现横屏保存图片功能 如图所示: 2.mtk

Spring MVC 图片上传

引入需要的包 <dependency><groupId>commons-logging</groupId><artifactId>commons-logging</artifactId><version>1.1</version></dependency><dependency><groupId>commons-io</groupId><artifactId>commons-