>类库下载 >java类库 >Glide의 캐싱 메커니즘에 대한 심층 탐구

Glide의 캐싱 메커니즘에 대한 심층 탐구

坏嘻嘻
坏嘻嘻원래의
2018-09-14 10:29:413137검색

시작하기 전에 xerces.jar 및 xalan.jar 파일을 java.class.path 디렉터리에 넣어야 합니다. 이 두 파일은 Xalan-Java 1.2에 포함되어 있으며 xml.apache.org에서 다운로드할 수 있습니다. ) .

1.글라이드 캐시 소개

2.캐시 키

EngineKey

rewrites = () 및 hashCode() 메소드는 EngineKey에 전달된 모든 매개변수가 동일한 경우 동일한 EngineKey 객체만 고려되도록 합니다

3 메모리 캐시

Glide.with(this)
     .load(url)
     .skipMemoryCache(true)
     .into(imageView);
# 🎜🎜# LruCache 알고리즘(Least Recent Used)

Android는 대용량 이미지와 다중 이미지 솔루션을 효율적으로 로드하여 OOM 프로그램을 효과적으로 피합니다

LruCache 알고리즘을 생각하면 매우 쉽습니다( 최소 최근 사용됨), 가장 최근에 사용되지 않은 알고리즘이라고도 합니다. 주요 알고리즘 원리는 가장 최근에 사용된 개체를 강력한 참조와 함께 LinkedHashMap에 저장하고, 캐시 값이 미리 설정된 값에 도달하기 전에 가장 최근에 사용된 개체를 메모리에서 제거하는 것입니다. LruCache의 사용법도 비교적 간단합니다

loadFromCache() 메서드는 캐시된 이미지를 얻는 데 사용됩니다. 얻은 경우 콜백을 위해 cb.onResourceReady() 메서드가 직접 호출됩니다. 획득하지 못한 경우 26행에서 loadFromActiveResources() 메서드를 호출하여 캐시된 이미지를 획득한 경우 콜백이 직접 수행됩니다. 두 메서드 모두 캐시를 얻지 못한 경우에만 실행이 계속되고 이미지를 로드하기 위해 스레드가 열립니다.

loadFromCache() 및 loadFromActiveResources(). 이 두 가지 방법 중 하나는 LruCache 알고리즘을 사용하고 다른 하나는 약한 참조를 사용합니다.

하드 디스크 캐시

Glide.with(this)
     .load(url)
     .diskCacheStrategy(DiskCacheStrategy.NONE)
     .into(imageView);

DiskCacheStrategy.NONE: 콘텐츠를 캐시하지 않음을 나타냅니다.

DiskCacheStrategy.SOURCE: 원본 이미지만 캐시됨을 나타냅니다.
DiskCacheStrategy.RESULT: 변환된 이미지만 캐시됨을 나타냅니다(기본 옵션).
DiskCacheStrategy.ALL: 원본 이미지와 변환된 이미지가 모두 캐시됨을 나타냅니다.

DiskLruCache

Android DiskLruCache는 완전히 구문 분석되었으며 하드 디스크 캐싱을 위한 최고의 솔루션입니다.

private Resource<?> decode() throws Exception {    if (isDecodingFromCache()) {        return decodeFromCache();
    } else {        return decodeFromSource();
    }
}

여기서 먼저 DecodeJob의 decodeResultFromCache( ) 캐시를 얻을 수 없는 경우 캐시를 얻기 위해 decodeSourceFromCache() 메서드가 다시 호출됩니다. 이 두 메서드의 차이점은 실제로 DiskCacheStrategy.RESULT와 DiskCacheStrategy.SOURCE의 두 매개 변수 간의 차이입니다. 나는 다른 일을 할 필요가 없다고 믿습니다.

고급기술

예를 들어 예전에 그룹에 있던 친구가 자기 프로젝트의 이미지 리소스가 모두 세븐온에 저장되어 있다고 하더군요. Niuyun, Qiniuyun은 이미지 리소스를 보호하기 위해 이미지 URL 주소에 토큰 매개변수를 추가합니다. 즉, 이미지의 URL 주소는 다음과 같은 형식일 수 있습니다:

http://url.com/image.jpg?token=d9caa6e02c990b0a

public class MyGlideUrl extends GlideUrl {

    private String mUrl;    public MyGlideUrl(String url) {        super(url);
        mUrl = url;
    }    @Override
    public String getCacheKey() {        return mUrl.replace(findTokenParam(), "");
    }    private String findTokenParam() {
        String tokenParam = "";        int tokenKeyIndex = mUrl.indexOf("?token=") >= 0 ? mUrl.indexOf("?token=") : mUrl.indexOf("&token=");        if (tokenKeyIndex != -1) {            int nextAndIndex = mUrl.indexOf("&", tokenKeyIndex + 1);            if (nextAndIndex != -1) {
                tokenParam = mUrl.substring(tokenKeyIndex + 1, nextAndIndex + 1);
            } else {
                tokenParam = mUrl.substring(tokenKeyIndex);
            }
        }        return tokenParam;
    }

}
Glide.with(this)
     .load(new MyGlideUrl(url))
     .into(imageView);
Related 권장 사항 :

PHP는 java.

Java에서 mysql_MySQL에 연결하는 방법#🎜에서 DatainputStream 클래스를 구현합니다. 🎜#

위 내용은 Glide의 캐싱 메커니즘에 대한 심층 탐구의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
이전 기사:JAVA IO 및 NIO 이해다음 기사:JAVA IO 및 NIO 이해