如何在Android studio 中使用單例模式
本篇簡單介紹如何在Android studio中 使用單例模式和使用注意事項(xiàng)。
單例模式為什么要使用單例模式?
有一些對象我們只需要一個(gè),只需要一個(gè)線程池 、緩存或是只有一臺(tái)打印機(jī)、機(jī)器人 、機(jī)器人上面只有一個(gè)尋磁傳感器。我們可以通過全局的靜態(tài)變量來實(shí)現(xiàn),但是全局變量在程序一開始就創(chuàng)建 可能比較耗費(fèi)資源、可能一直沒用到。單例模式和全局變量一樣方便又沒有它的缺點(diǎn)。
單利模式使用public class Sensor { // 使用靜態(tài)變量記錄唯一的實(shí)例 private static Sensor sensorInstance; /** * 私有的構(gòu)造方法 */ private Sensor(){} /** * 實(shí)例化方法 * @return Sersor * synchronized包住不會(huì)有兩個(gè)線程同時(shí)進(jìn)入 */ public static synchronized Sensor getSersorInstance(){ if(sensorInstance == null) { sensorInstance = new Sensor(); } // 返回Sensor唯一實(shí)例 return sensorInstance; }}
但是如果想要很急切的創(chuàng)建示例,而且在示例創(chuàng)建方面的負(fù)擔(dān)不繁重。
public class Sensor { private static Sensor sensorInstance = new Sensor(); private Sensor(){} public static Sensor getSersorInstance(){ return sensorInstance; }}
如果有很多線程頻繁的使用getSersorInstance可能就影響性能,可以使用雙重檢查加鎖
public class Sensor { // volatile 保證 sensorInstance 被初始化 多個(gè)線程正確的處理 private volatile static Sensor sensorInstance; private Sensor(){} public static Sensor getSersorInstance(){ // 檢查 sensorInstance是否存在 如果不存在就進(jìn)入同步區(qū)塊if(sensorInstance == null) { // 同步區(qū)塊里面的代碼只有在第一次才會(huì)執(zhí)行 synchronized(Sensor.class) {if(sensorInstance == null) { sensorInstance = new Sensor();} } } return sensorInstance; }}Android 中使用內(nèi)存泄漏問題
1.在實(shí)例化的時(shí)候我們經(jīng)常需要傳入一些參數(shù) 比如說 Context
然后順利成章的
Sensor sensor = Sensor.getSersorInstance(MainActivity.this);
然后出現(xiàn)了一個(gè)很嚴(yán)重的問題Sensor單例持有了MainActivity 的this對象,所以當(dāng)我們轉(zhuǎn)跳其他Activity頁面的時(shí)候MainActivity 的對象仍然得不到釋放不能被回收。
所以我們應(yīng)該使用Application中的 context
2.同樣在急切的方法中
public class Sensor { public static final Sensor SENSOR_INSTANCE = new Sensor(); private List<MyListener> mListenerList; private Sensor() { mListenerList = new ArrayList<MyListener>(); } public static Sensor getInstance() { return SENSOR_INSTANCE; } public void registerListener(MyListener listener) { if (!mListenerList.contains(listener)) {mListenerList.add(listener); } } public void unregisterListener(MyListener listener) { mListenerList.remove(listener); } } interface MyListener { public void onSomeThingHappen(); }
MainActivity:
public class MainActivity extends Activity { private MyListener mMyListener=new MyListener() { @Override public void onSomeThingHappen() { } }; private Sensor sensor = Sensor.getInstance(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); sensor.registerListener(mMyListener); }}
非靜態(tài)的內(nèi)部類(Sensor)的對象(mListenerList)都是會(huì)持有指向外部類對象(mMyListener)的引用。因此外部類對象(mMyListener)被持有了 同樣的不會(huì)被回收,內(nèi)存泄漏,所以需要
@Override protected void onDestroy() { Sensor.unregisterListener(mMyListener); super.onDestroy(); }
以上就是如何在Android studio 中使用單例模式的詳細(xì)內(nèi)容,更多關(guān)于在Android studio 中使用單例模式的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. 淺談XML Schema中的elementFormDefault屬性2. 利用XMLSerializer將對象串行化到XML3. 父div高度不能自適應(yīng)子div高度的解決方案4. 三個(gè)不常見的 HTML5 實(shí)用新特性簡介5. XML中顯示HTML的小技巧6. 阿里前端開發(fā)中的規(guī)范要求7. 選擇模式 - XSL教程 - 28. CSS3實(shí)例分享之多重背景的實(shí)現(xiàn)(Multiple backgrounds)9. 前端從瀏覽器的渲染到性能優(yōu)化10. 淺談?dòng)蓀osition屬性引申的css進(jìn)階討論
