Picasso图片框架加载图片 使用及缓存问题

简介: Picasso图片框架加载图片 使用及缓存问题

项目中用的Picasso 框架 ,加载图片。使用很方便 而且缓存机制非常强大。

正常使用我们可以这样直接调用,我把方法写到一个util里面了。

调用代码如下:

PicassoUtil.displayImage(context, Constants.U_IMG_URL, R.drawable.default, iv_icon);

Util工具类

import java.io.File;
import android.content.Context;
import android.text.TextUtils;
import android.widget.ImageView;
import com.squareup.picasso.Picasso;
import com.squareup.picasso.RequestCreator;
public class PicassoUtil {
  public static void displayImage(Context context, String url,
      int defaultDrawableId, ImageView userPhoto) {
    if (TextUtils.isEmpty(url)) {
      userPhoto.setImageResource(defaultDrawableId);
    } else if (url.startsWith("http")) {
      getPicasso(context, url, defaultDrawableId).into(userPhoto);
    } else if (url.startsWith("/")) {
      File file = new File(url);
      showUserPhoto(context, file, defaultDrawableId, userPhoto);
    }
  }
  public static RequestCreator getPicasso(Context context, String url,
      int loadingResId) {
    RequestCreator requestCreator = Picasso.with(context).load(url);
    if (loadingResId > 0) {
      return requestCreator.error(loadingResId).placeholder(loadingResId);
    } else {
      return requestCreator;
    }
  }
  private static void showUserPhoto(Context context, File file,
      int defaultDrawableId, ImageView imageView) {
    if (file == null || !file.exists()) {
      imageView.setImageResource(defaultDrawableId);
      return;
    }
    Picasso.with(context).load(file).error(defaultDrawableId)
        .placeholder(defaultDrawableId)
        .into(imageView);
  }
}

上面的是正常加载图片的过程 ,都没有问题。 但是一些特殊情况 ,就不能用上述调用加载图片的方法了。因为会出问题,原因就是缓存机制。


当我们做修改头像功能时候  就会发现这个问题,当我们头像上传成功,服务器返回给我们修改成功的imgUrl时,我们拿着这个新的url去加载图片时候,发现用picasso上面的加载方法,图片并没有变化。


这是因为picasso有双缓存机制,就是 内存缓存 和 网络缓存 ,导致就算你给他传新的url,它也不会去重新访问新的地址上的图片。


怎么解决 让它不加载缓存中的图片呢?


在之前的版本中 用的是

Picasso.with(context).load(url)
                      .skipMemoryCache()                       
                      .into(imageView);

若不起作用可改为:

  Picasso.with(context).load(url)
                       .memoryPolicy(MemoryPolicy.NO_CACHE)
                       .networkPolicy(NetworkPolicy.NO_CACHE)
                       .error(R.drawable.default_icon)
                       .into(imageView);


相关文章
|
缓存 Java Spring
Spring框架(四) 三级缓存与循环依赖
首先我们需要明白什么是循环依赖 , 打个比方 , 就是说A对象在创建的过程中 , 需要依赖注入B对象 , 但是B对象没有 , 就需要去创建 , 而在创建B对象的过程中又需要注入A对象 , A对象此时还在创建中,所以就构成了一个死循环 , A,B相互依赖 这样的关系被成为循环依赖(当然 , 可能还会有其他的情况),下面我们就来看看Spring是如何让解决循环依赖的
158 0
|
6月前
|
缓存 NoSQL Java
微服务框架(十二)Spring Boot Redis 缓存
  此系列文章将会描述Java框架Spring Boot、服务治理框架Dubbo、应用容器引擎Docker,及使用Spring Boot集成Dubbo、Mybatis等开源框架,其中穿插着Spring Boot中日志切面等技术的实现。 本文为Spring Boot集成Redis。 在这篇文章中,我们将配置一个Spring Boot应用程序示例,并将其与Redis Cache 集成。虽然Redis是一个开源是一个开源内存数据结构存储,用作数据库,缓存和消息代理,但本文仅演示缓存集成。
|
18天前
|
存储 缓存 监控
网站的图片资源是否需要设置缓存?
【10月更文挑战第18天】网站的图片资源一般是需要设置缓存的,但要根据图片的具体特点和网站的需求,合理设置缓存时间和缓存策略,在提高网站性能和用户体验的同时,确保用户能够获取到准确、及时的图片信息。
|
2月前
|
缓存 Java 开发工具
Spring是如何解决循环依赖的?从底层源码入手,详细解读Spring框架的三级缓存
三级缓存是Spring框架里,一个经典的技术点,它很好地解决了循环依赖的问题,也是很多面试中会被问到的问题,本文从源码入手,详细剖析Spring三级缓存的来龙去脉。
191 24
Spring是如何解决循环依赖的?从底层源码入手,详细解读Spring框架的三级缓存
|
3月前
|
缓存 NoSQL Java
SpringBoot的三种缓存技术(Spring Cache、Layering Cache 框架、Alibaba JetCache 框架)
Spring Cache 是 Spring 提供的简易缓存方案,支持本地与 Redis 缓存。通过添加 `spring-boot-starter-data-redis` 和 `spring-boot-starter-cache` 依赖,并使用 `@EnableCaching` 开启缓存功能。JetCache 由阿里开源,功能更丰富,支持多级缓存和异步 API,通过引入 `jetcache-starter-redis` 依赖并配置 YAML 文件启用。Layering Cache 则提供分层缓存机制,需引入 `layering-cache-starter` 依赖并使用特定注解实现缓存逻辑。
986 1
SpringBoot的三种缓存技术(Spring Cache、Layering Cache 框架、Alibaba JetCache 框架)
|
3月前
|
缓存 分布式计算 Java
详细解读MapReduce框架中的分布式缓存
【8月更文挑战第31天】
39 0
|
3月前
|
开发框架 缓存 NoSQL
基于SqlSugar的开发框架循序渐进介绍(17)-- 基于CSRedis实现缓存的处理
基于SqlSugar的开发框架循序渐进介绍(17)-- 基于CSRedis实现缓存的处理
|
4月前
|
存储 缓存 开发框架
Winform框架中窗体基类的用户身份信息的缓存和提取
Winform框架中窗体基类的用户身份信息的缓存和提取
|
4月前
|
存储 缓存 NoSQL
GuavaCache、EVCache、Tair、Aerospike 缓存框架比较
**摘要:** Guava Cache、EVCache、Tair 和 Aerospike 是不同的缓存解决方案。Guava Cache 是轻量级的本地缓存,适用于Java应用,提供丰富的配置选项和自动加载功能。EVCache 基于 Memcached,适合分布式场景,高并发访问。Tair,阿里巴巴的分布式缓存,支持多种数据结构,适用于大规模系统。Aerospike 是高性能NoSQL数据库,结合缓存和持久化,适用于低延迟和大数据量的场景。选择时要考虑应用场景、性能需求和数据规模。
GuavaCache、EVCache、Tair、Aerospike 缓存框架比较
|
5月前
|
存储 缓存 NoSQL
SpringBoot配置第三方专业缓存框架j2cache
SpringBoot配置第三方专业缓存框架j2cache
196 5