如何在Android studio 中使用單例模式
本篇簡(jiǎn)單介紹如何在Android studio中 使用單例模式和使用注意事項(xiàng)。
單例模式為什么要使用單例模式?
有一些對(duì)象我們只需要一個(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對(duì)象,所以當(dāng)我們轉(zhuǎn)跳其他Activity頁面的時(shí)候MainActivity 的對(duì)象仍然得不到釋放不能被回收。
所以我們應(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)的對(duì)象(mListenerList)都是會(huì)持有指向外部類對(duì)象(mMyListener)的引用。因此外部類對(duì)象(mMyListener)被持有了 同樣的不會(huì)被回收,內(nèi)存泄漏,所以需要
@Override protected void onDestroy() { Sensor.unregisterListener(mMyListener); super.onDestroy(); }
以上就是如何在Android studio 中使用單例模式的詳細(xì)內(nèi)容,更多關(guān)于在Android studio 中使用單例模式的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. JS實(shí)現(xiàn)前端動(dòng)態(tài)分頁碼代碼實(shí)例2. 用Spring JMS使異步消息變得簡(jiǎn)單3. 關(guān)于IDEA 2020.3 多窗口視圖丟失的問題4. PHP驗(yàn)證碼工具-Securimage5. js實(shí)現(xiàn)碰撞檢測(cè)6. 一文帶你徹底理解Java序列化和反序列化7. ASP基礎(chǔ)知識(shí)VBScript基本元素講解8. Python 利用Entrez庫篩選下載PubMed文獻(xiàn)摘要的示例9. 通過實(shí)例解析Python文件操作實(shí)現(xiàn)步驟10. ASP.NET MVC使用jQuery ui的progressbar實(shí)現(xiàn)進(jìn)度條

網(wǎng)公網(wǎng)安備