시작하기 전에 xerces.jar 및 xalan.jar 파일을 java.class.path 디렉터리에 넣어야 합니다. 이 두 파일은 Xalan-Java 1.2에 포함되어 있으며 xml.apache.org에서 다운로드할 수 있습니다. ) .
1.글라이드 캐시 소개
EngineKey
rewrites = () 및 hashCode() 메소드는 EngineKey에 전달된 모든 매개변수가 동일한 경우 동일한 EngineKey 객체만 고려되도록 합니다
Glide.with(this) .load(url) .skipMemoryCache(true) .into(imageView);
Android는 대용량 이미지와 다중 이미지 솔루션을 효율적으로 로드하여 OOM 프로그램을 효과적으로 피합니다
LruCache 알고리즘을 생각하면 매우 쉽습니다( 최소 최근 사용됨), 가장 최근에 사용되지 않은 알고리즘이라고도 합니다. 주요 알고리즘 원리는 가장 최근에 사용된 개체를 강력한 참조와 함께 LinkedHashMap에 저장하고, 캐시 값이 미리 설정된 값에 도달하기 전에 가장 최근에 사용된 개체를 메모리에서 제거하는 것입니다. LruCache의 사용법도 비교적 간단합니다loadFromCache() 및 loadFromActiveResources(). 이 두 가지 방법 중 하나는 LruCache 알고리즘을 사용하고 다른 하나는 약한 참조를 사용합니다. 하드 디스크 캐시loadFromCache() 메서드는 캐시된 이미지를 얻는 데 사용됩니다. 얻은 경우 콜백을 위해 cb.onResourceReady() 메서드가 직접 호출됩니다. 획득하지 못한 경우 26행에서 loadFromActiveResources() 메서드를 호출하여 캐시된 이미지를 획득한 경우 콜백이 직접 수행됩니다. 두 메서드 모두 캐시를 얻지 못한 경우에만 실행이 계속되고 이미지를 로드하기 위해 스레드가 열립니다.
Glide.with(this) .load(url) .diskCacheStrategy(DiskCacheStrategy.NONE) .into(imageView);
DiskCacheStrategy.NONE: 콘텐츠를 캐시하지 않음을 나타냅니다.DiskLruCacheDiskCacheStrategy.SOURCE: 원본 이미지만 캐시됨을 나타냅니다.
DiskCacheStrategy.RESULT: 변환된 이미지만 캐시됨을 나타냅니다(기본 옵션).
DiskCacheStrategy.ALL: 원본 이미지와 변환된 이미지가 모두 캐시됨을 나타냅니다.
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; } }로그인 후 복사Related 권장 사항 :Glide.with(this) .load(new MyGlideUrl(url)) .into(imageView);로그인 후 복사Java에서 mysql_MySQL에 연결하는 방법#🎜에서 DatainputStream 클래스를 구현합니다. 🎜#
위 내용은 Glide의 캐싱 메커니즘에 대한 심층 탐구의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!