weakReference一般用來防止內(nèi)存泄漏,要保證內(nèi)存被VM回收
softReference的話,好像多用作來實現(xiàn)cache機制.
WeakReference:
弱引用對象,它們并不禁止其指示對象變得可終結(jié),并被終結(jié),然后被回收。弱引用最常用于實現(xiàn)規(guī)范化的映射。
假定垃圾回收器確定在某一時間點上某個對象是弱可到達對象。這時,它將自動清除針對此對象的所有弱引用,以及通過強引用鏈和軟引用,可以從其到達該對象的針對任何其他弱可到達對象的所有弱引用。同時它將聲明所有以前的弱可到達對象為可終結(jié)的。在同一時間或晚些時候,它將那些已經(jīng)向引用隊列注冊的新清除的弱引用加入隊列。
///////////////////
SoftReference:
軟引用對象,在響應(yīng)內(nèi)存需要時,由垃圾回收器決定是否清除此對象。軟引用對象最常用于實現(xiàn)內(nèi)存敏感的緩存。
假定垃圾回收器確定在某一時間點某個對象是軟可到達對象。這時,它可以選擇自動清除針對該對象的所有軟引用,以及通過強引用鏈,從其可以到達該對象的針對任何其他軟可到達對象的所有軟引用。在同一時間或晚些時候,它會將那些已經(jīng)向引用隊列注冊的新清除的軟引用加入隊列。
軟可到達對象的所有軟引用都要保證在虛擬機拋出 OutOfMemoryError 之前已經(jīng)被清除。否則,清除軟引用的時間或者清除不同對象的一組此類引用的順序?qū)⒉皇苋魏渭s束。然而,虛擬機實現(xiàn)不鼓勵清除最近訪問或使用過的軟引用。
此類的直接實例可用于實現(xiàn)簡單緩存;該類或其派生的子類還可用于更大型的數(shù)據(jù)結(jié)構(gòu),以實現(xiàn)更復(fù)雜的緩存。只要軟引用的指示對象是強可到達對象,即正在實際使用的對象,就不會清除軟引用。例如,通過保持最近使用的項的強指示對象,并由垃圾回收器決定是否放棄剩余的項,復(fù)雜的緩存可以防止放棄最近使用的項
軟引用 (Soft Reference)的主要特點是具有較強的引用功能。只有當(dāng)內(nèi)存不夠的時候才回收這類內(nèi)存,因此在內(nèi)存足夠的時候,他們通常不被回收。另外,這些引用對象還能保證在Java 拋出OutOfMemory異常之前,被設(shè)置為null。他可以用于實現(xiàn)一些常用資源的緩存,實現(xiàn)Cache的功能,保證最大限度的使用內(nèi)存而不引起 OutOfMemory異常。
下面是軟引用的實現(xiàn)代碼:
- import java.lang.ref.SoftReference;
- public class softReference {
- public static void main(String[] args) {
- A a = new A();
- // 使用a
- a.test();
- // 使用完了a,將它設(shè)置為soft引用類型,并且釋放強引用
- SoftReference sr = new SoftReference(a);
- a = null;
- // 下次使用
- if (sr != null) {
- a = (A) sr.get();
- a.test();
- } else {
- // GC由于低內(nèi)存,已釋放a,因此需要重新裝載
- a = new A();
- a.test();
- a = null;
- sr = new SoftReference(a);
- }
- }
- }
- class A {
- public void test() {
- System.out.println("Soft Reference test");
- }
- }
軟引用技術(shù)的引進使Java應(yīng)用可以更好的管理內(nèi)存,穩(wěn)定系統(tǒng),防止系統(tǒng)內(nèi)存溢出,避免系統(tǒng)崩潰。因此在處理一些占用內(nèi)存大而且聲明周期較長,但使用并不頻繁的對象時應(yīng)盡量應(yīng)用該技術(shù)。但事物總帶有兩面性的,有利也有弊,在某些時候?qū)浺玫氖褂脮档蛻?yīng)用的運行效率與性能,例如:應(yīng)用軟引用的對象的初始化過程較為耗時,或者對象的狀態(tài)在程序的運行過程中發(fā)生了變化,都會給重新創(chuàng)建對象與初始化對象帶來不同程度的麻煩,有些時候我們要權(quán)衡利弊擇時應(yīng)用。
在android中可以巧妙的運用軟引用(SoftRefrence)(來源段落:http://winuxxan.blog.51cto.com/2779763/512180)
有些時候,我們使用Bitmap后沒有保留對它的引用,因此就無法調(diào)用Recycle函數(shù)。這時候巧妙的運用軟引用,可以使Bitmap在內(nèi)存快不足時得到有效的釋放。如下例:
- private class MyAdapter extends BaseAdapter {
-
- private ArrayList<SoftReference<Bitmap>> mBitmapRefs = new ArrayList<SoftReference<Bitmap>>();
- private ArrayList<Value> mValues;
- private Context mContext;
- private LayoutInflater mInflater;
-
- MyAdapter(Context context, ArrayList<Value> values) {
- mContext = context;
- mValues = values;
- mInflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
- }
- public int getCount() {
- return mValues.size();
- }
-
- public Object getItem(int i) {
- return mValues.get(i);
- }
-
- public long getItemId(int i) {
- return i;
- }
-
- public View getView(int i, View view, ViewGroup viewGroup) {
- View newView = null;
- if(view != null) {
- newView = view;
- } else {
- newView =(View)mInflater.inflate(R.layout.image_view, false);
- }
-
- Bitmap bitmap = BitmapFactory.decodeFile(mValues.get(i).fileName);
- mBitmapRefs.add(new SoftReference<Bitmap>(bitmap)); //此處加入ArrayList
- ((ImageView)newView).setImageBitmap(bitmap);
-
- return newView;
- }
- }