就一個類而言,應該僅有一個引發它變化的緣由。簡單來講,一個類中應該是一組相關性很高的函數、數據的封裝。
軟件中的對象(類、模塊、函數等),應該對於擴展是開放的,而對於修改是封閉的。
全部引用基類的地方必須能透明的使用其子類。通俗的說,就是隻要父類能出現的地方子類就能夠出現,並且替換爲子類之後不會出現任何錯誤或異常。反過來就不行了,子類出現的地方父類不必定能適應。
依賴倒置原則在Java中的表現就是:模塊間的依賴經過抽象發生,實現類之間不發生直接的依賴關係,其依賴關係是經過接口或抽象類產生的。
類間的依賴關係應該創建在最小的接口上。
<!--將圖片寫入SD卡-->
public void put(String url, Bitmap bitmap) {
FileOutputStream fileOutputStream = null;
try {
fileOutputStream = new FileOutputStream(SDPath+url);
bitmap.compress(Bitmap.CompressFormat.PNG, 100, fileOutputStream);
}catch (FileNotFoundException e) {
e.printStackTrace();
}finally {
CloseUtils.closeQuietly(fileOutputStream);
}
}
<!--關閉工具類-->
public final class CloseUtils {
private CloseUtils() { }
/**
* 關閉Closeable對象
* @param closeable
*/
public static void closeQuietly(Closeable closeable) {
if (null != closeable) {
try {
closeable.close();
}catch (IOException e) {
e.printStackTrace();
}
}
}
}
複製代碼
一個對象應該對其餘的對象有最少的瞭解
public class ImageLoader {
// 圖片緩存,依賴接口,而不是具體實現
// 若是改成MemoryCache mImageCache = new MemoryCache();就不能定製圖片緩存的實現,擴展性大大下降,耦合度也會大大提升
ImageCache mImageCache = new MemoryCache();
// 線程池,線程數量爲CPU的數量
ExecutorService mExecutorService = Executors.newFixedThreadPool(Runtime.getRuntime().availableProcessors());
// 注入緩存,對擴展開放,對修改關閉
public void setImageCache(ImageCache cache) {
mImageCache = cache;
}
/**
* 顯示圖片
* @param imageUrl
* @param imageView
*/
public void displayImage(String imageUrl, ImageView imageView) {
Bitmap bitmap = mImageCache.get(imageUrl);
if (bitmap != null) {
imageView.setImageBitmap(bitmap);
return;
}
// 圖片沒有緩存,提交到線程池下載
submitLoadRequest(imageUrl, imageView);
}
/**
* 下載圖片
* @param imageUrl
* @param imageView
*/
private void submitLoadRequest(final String imageUrl, final ImageView imageView) {
imageView.setTag(imageUrl);
mExecutorService.submit(new Runnable() {
@Override
public void run() {
Bitmap bitmap = downloadImage(imageUrl);
if (bitmap == null) {
return;
}
if (imageUrl.equals(imageView.getTag())) {
imageView.setImageBitmap(bitmap);
}
mImageCache.put(imageUrl, bitmap);
}
});
}
/**
* 下載圖片
* @param imageUrl
* @return
*/
private Bitmap downloadImage(String imageUrl) {
Bitmap bitmap = null;
try {
URL url = new URL(imageUrl);
HttpURLConnection connection = (HttpURLConnection) url.openConnection();
bitmap = BitmapFactory.decodeStream(connection.getInputStream());
connection.disconnect();
}catch (Exception e) {
e.printStackTrace();
}
return bitmap;
}
複製代碼
<!--圖片緩存接口-->
public interface ImageCache {
public Bitmap get(String url);
public void put(String url, Bitmap bitmap);
}
<!--內存緩存的實現-->
public class MemoryCache implements ImageCache{
private LruCache<String, Bitmap> mMemoryCache;
public MemoryCache() {
//初始化LRU緩存
initImageCache();
}
private void initImageCache() {
// 計算可以使用的最大內存
final int maxMemory = (int) (Runtime.getRuntime().maxMemory()/1024);
// 取四分之一的可用內存做爲緩存
final int cacheSize = maxMemory / 4;
mMemoryCache = new LruCache<String, Bitmap>(cacheSize) {
@Override
protected int sizeOf(String key, Bitmap bitmap) {
return bitmap.getRowBytes() * bitmap.getHeight() / 1024;
}
};
}
@Override
public Bitmap get(String url) {
return mMemoryCache.get(url);
}
@Override
public void put(String url, Bitmap bitmap) {
mMemoryCache.put(url, bitmap);
}
}
複製代碼
歡迎掃碼關注公衆號,我們一塊兒學習成長吧 設計模式