如何在Android studio 中使用單例模式
本篇簡(jiǎn)單介紹如何在Android studio中 使用單例模式和使用注意事項(xiàng)。
單例模式為什么要使用單例模式?
有一些對(duì)象我們只需要一個(gè),只需要一個(gè)線程池 、緩存或是只有一臺(tái)打印機(jī)、機(jī)器人 、機(jī)器人上面只有一個(gè)尋磁傳感器。我們可以通過(guò)全局的靜態(tài)變量來(lái)實(shí)現(xiàn),但是全局變量在程序一開(kāi)始就創(chuàng)建 可能比較耗費(fèi)資源、可能一直沒(méi)用到。單例模式和全局變量一樣方便又沒(mé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)存泄漏問(wèn)題
1.在實(shí)例化的時(shí)候我們經(jīng)常需要傳入一些參數(shù) 比如說(shuō) Context
然后順利成章的
Sensor sensor = Sensor.getSersorInstance(MainActivity.this);
然后出現(xiàn)了一個(gè)很嚴(yán)重的問(wèn)題Sensor單例持有了MainActivity 的this對(duì)象,所以當(dāng)我們轉(zhuǎn)跳其他Activity頁(yè)面的時(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. moment轉(zhuǎn)化時(shí)間戳出現(xiàn)Invalid Date的問(wèn)題及解決2. python爬蟲(chóng)實(shí)戰(zhàn)之制作屬于自己的一個(gè)IP代理模塊3. Ajax返回值類型與用法實(shí)例分析4. 如何在jsp界面中插入圖片5. .NET6打包部署到Windows Service的全過(guò)程6. UDDI FAQs7. 解決ajax請(qǐng)求后臺(tái),有時(shí)收不到返回值的問(wèn)題8. 開(kāi)發(fā)效率翻倍的Web API使用技巧9. asp批量添加修改刪除操作示例代碼10. HTML 絕對(duì)路徑與相對(duì)路徑概念詳細(xì)
