国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

如何編寫高效android代碼

移動開發 Android
基于Android相關設備作為嵌入式設備范疇,在書寫App應用的時候要格外關注效率,并且受電池電量的限制。這就導致嵌入式設備有諸多考慮、有限處理能力,因此就要求我們盡量去寫高效的代碼。本文討論了很多能讓開發者使他們的程序運行更有效的方法,遵照這些方法,你可以使你的程序發揮最大的效力。

基于Android相關設備作為嵌入式設備范疇,在書寫App應用的時候要格外關注效率,并且受電池電量的限制。這就導致嵌入式設備有諸多考慮、有限處理能力,因此就要求我們盡量去寫高效的代碼。本文討論了很多能讓開發者使他們的程序運行更有效的方法,遵照這些方法,你可以使你的程序發揮***的效力。

引言

對于占用資源的系統,有兩條基本原則:

不要做不必要的事

不要分配不必要的內存

所有下面的內容都遵照這兩個原則。

1、避免建立對象

世界上沒有免費的對象。雖然GC為每個線程都建立了臨時對象池,可以使創建對象的代價變得小一些,但是分配內存永遠都比不分配內存的代價大。

如果你在用戶界面循環中分配對象內存,就會引發周期性的垃圾回收,用戶就會覺得界面像打嗝一樣一頓一頓的。

所以,除非必要,應盡量避免盡力對象的實例。下面的例子將幫助你理解這條原則:

當你從用戶輸入的數據中截取一段字符串時,盡量使用substring函數取得原始數據的一個子串,而不是為子串另外建立一份拷貝。這樣你就有一個新的String對象,它與原始數據共享一個char數組。

如果你有一個函數返回一個String對象,而你確切的知道這個字符串會被附加到一個StringBuffer,那么,請改變這個函數的參數和實現方式,直接把結果附加到StringBuffer中,而不要再建立一個短命的臨時對象。

一個更極端的例子是,把多維數組分成多個一維數組:

int數組比Integer數組好,這也概括了一個基本事實,兩個平行的int數組比(int,int)對象數組性能要好很多。同理,這試用于所有基本類型的組合。

如果你想用一種容器存儲(Foo,Bar)元組,嘗試使用兩個單獨的Foo[]數組和Bar[]數組,一定比(Foo,Bar)數組效率更高。(也有例外的情況,就是當你建立一個API,讓別人調用它的時候。這時候你要注重對API借口的設計而犧牲一點兒速度。當然在API的內部,你仍要盡可能的提高代碼的效率)

總體來說,就是避免創建短命的臨時對象。減少對象的創建就能減少垃圾收集,進而減少對用戶體驗的影響。

2、使用本地方法

當你在處理字串的時候,不要吝惜使用String.indexOf(), String.lastIndexOf()等特殊實現的方法。這些方法都是使用C/C++實現的,比起Java循環快10到100倍。

但也并非要完全使用本地方法,調用本地方法的代價要高于調用解釋方法。所以如果可以避免,就不應使用本地方法去做一些并不復雜的運算。

3、選擇虛類而不是接口

假設你有一個HashMap對象,你可以將它聲明為HashMap或者Map:

Map myMap1 = new HashMap();

HashMap myMap2 = new HashMap();哪個更好呢?

按照傳統的觀點Map會更好些,因為這樣你可以改變他的具體實現類,只要這個類繼承自Map接口。傳統的觀點對于傳統的程序是正確的,但是它并不適合嵌入式系統。調用一個接口的引用會比調用實體類的引用多花費一倍的時間。如果HashMap完全適合你的程序,那么使用Map就沒有什么價值。如果有些地方你不能確定,先避免使用Map,剩下的交給IDE提供的重構功能好了。(當然公共API是一個例外:一個好的API常常會犧牲一些性能)

4、用靜態方法比虛方法好

如果你不需要訪問一個對象的成員變量,那么請把方法聲明成static。虛方法執行的更快,因為它可以被直接調用而不需要一個虛函數表。另外你也可以通過聲明體現出這個函數的調用不會改變對象的狀態。

5、不用getter和setter

在很多本地語言如C++中,都會使用getter(比如:i = getCount())來避免直接訪問成員變量(i = mCount)。在C++中這是一個非常好的習慣,因為編譯器能夠內聯訪問,如果你需要約束或調試變量,你可以在任何時候添加代碼。在Android上,這就不是個好主意了。虛方法的開銷比直接訪問成員變量大得多。在通用的接口定義中,可以依照OO的方式定義getters和setters,但是在一般的類中,你應該直接訪問變量。

6、將成員變量緩存到本地

訪問成員變量比訪問本地變量慢得多,下面一段代碼:

 

  1. for (int i = 0; i < this.mCount; i++) 
  2.  
  3.  
  4.    dumpItem(this.mItems[i]);你應該寫成: 
  5.  
  6.  int count = this.mCount; 
  7.  
  8.  
  9.  Item[] items = this.mItems; 
  10.  
  11.  
  12.  for (int i = 0; i < count; i++) 
  13.  
  14.  
  15.    dumpItems(items[i]);(顯示的使用”this”是為了表明這些是成員變量) 

另一個相似的原則是:永遠不要在for的第二個條件中調用任何方法。如下面方法所示,在每次循環的時候都會調用getCount()方法,這樣做比你在一個int先把結果保存起來開銷大很多。

  for (int i = 0; i < this.getCount();i++)

    dumpItems(this.getItem(i));同樣如果你要多次訪問一個變量,也***先為它建立一個本地變量,例如:

  1. protected void drawHorizontalScrollBar(Canvas canvas, int width, int height) { 
  2.  
  3. if (isHorizontalScrollBarEnabled()) { 
  4.  
  5. int size = mScrollBar.getSize(false); 
  6.  
  7. if (size <= 0) { 
  8.  
  9. size = mScrollBarSize; 
  10.  
  11.  
  12. mScrollBar.setBounds(0, height – size, width, height); 
  13.  
  14.  
  15. mScrollBar.setParams( 
  16.  
  17. computeHorizontalScrollRange(), 
  18.  
  19. computeHorizontalScrollOffset(), 
  20.  
  21. computeHorizontalScrollExtent(), false); 
  22.  
  23. mScrollBar.draw(canvas); 

這里有4次訪問成員變量mScrollBar,如果將它緩存到本地,4次成員變量訪問就會變成4次效率更高的棧變量訪問。

順便說明一下,就是方法的參數與本地變量的性能是相同的。

7、使用常量

讓我們來看看這兩段在類前面的聲明:

static int intVal = 42;

static String strVal = “Hello, world!”;

編譯器會生成一個叫做<clinit>的初始化類的方法,當類***次被使用的時候這個方法會被執行。方法會將42賦給intVal,然后把一個指向類中常量表的引用賦給strVal。當以后要用到這些值的時候,會在成員變量表中查找到他們。

我們可以做一些改進,使用“final”關鍵字:

static final int intVal = 42;

static final String strVal = “Hello, world!”;

現在,類不再需要<clinit>方法,因為在成員變量初始化的時候,會將常量直接保存到類文件中。用到intVal的代碼被直接替換成42,而使用strVal的會指向一個字符串常量,而不是使用成員變量。

將一個方法或類聲明為”final”不會帶來性能的提升,但是會幫助編譯器優化代碼。舉例說,如果編譯器知道一個”getter”方法不會被重載,那么編譯器會對其采用內聯調用。

你也可以將本地變量聲明為”final”,同樣,這也不會帶來性能的提升。使用”final”只能使本地變量看起來更清晰些(但是也有些時候這是必須的,比如在使用匿名內部類的時候)。

8、謹慎使用foreach

9、避免使用枚舉

結束語:

為嵌入式系統編寫正確高效的代碼的***的方法就是去理解你的代碼究竟要做什么。如果你的確想要分配一個迭代器或者無論如何都要在Lists上面使用增強循環語法,那么一定是深思熟慮后的選擇,而不是一個不小心心的副作用。凡事預則立,不預則廢。一定要知道你在做什么。按照你自己的風格去編寫代碼,但一定要仔細考慮代碼所作的事,并找到提升速度的方法

責任編輯:chenqingxiang 來源: chenxiaoliba的博客
相關推薦

2011-03-24 13:09:11

數據庫代碼

2014-07-18 14:03:06

Android高效編寫代碼

2010-08-31 13:32:12

CSS

2010-02-05 16:49:05

編寫Android 代

2011-11-25 10:35:20

Java

2014-11-10 09:59:08

jQuery

2023-07-06 14:37:05

2010-09-09 13:59:55

CSS

2021-02-23 10:48:30

Python代碼開發

2024-01-30 08:54:05

JavaScript技巧代碼

2020-09-21 06:58:56

TS 代碼建議

2021-06-08 09:35:11

Cleaner ReaReact開發React代碼

2022-12-15 10:52:26

代碼開發

2022-06-27 06:23:23

代碼編程

2012-07-11 10:51:37

編程

2012-03-15 13:36:51

云計算JavaSpring框架

2010-09-14 13:49:38

CSS代碼

2023-02-26 23:23:36

CSS開發Web

2010-02-03 13:55:51

Python 代碼

2016-02-24 16:03:34

代碼質量編寫函數
點贊
收藏

51CTO技術棧公眾號

黄在线免费看| 欧美videos粗暴| 国产精品日韩精品在线播放| 久久精品女人天堂| 国产麻豆视频一区| 久久综合电影一区| 日韩视频在线观看国产| av中文字幕在线| 国产98色在线|日韩| 色伦专区97中文字幕| 成人免费视频77777| 婷婷视频在线| 国产精品88888| 国产亚洲欧美一区| 国产日产欧美一区二区| a毛片在线观看| 国产精品久久久久久久久晋中 | 天天综合天天综合色| 91亚洲精品久久久| 羞羞网站在线免费观看| 国产乱人伦偷精品视频不卡| 欧美色爱综合网| 国产女主播一区二区三区| 超碰资源在线| 婷婷另类小说| 欧美一级电影在线| 最近在线中文字幕| 蜜臀av性久久久久av蜜臀妖精| 制服丝袜国产精品| 大j8黑人w巨大888a片| 日韩激情毛片| 亚洲第一区在线观看| 9久久婷婷国产综合精品性色| 综合色中文字幕| 日本精品久久久久久久久久| 老牛精品亚洲成av人片| 老牛影视免费一区二区| 黄色精品视频| 69堂成人精品视频免费| 免费网站在线观看人| 9久re热视频在线精品| 久久精品99久久久香蕉| 国产精品视频在线看| 日韩精品欧美国产精品忘忧草| 久久999免费视频| 伊人精品综合| 欧美丰满少妇xxxx| 国产精品1区2区3区| 欧美激情免费观看| 狠狠做六月爱婷婷综合aⅴ| 亚洲aaaaaa| 天堂久久久久va久久久久| 欧美日韩国产综合在线| 成人深夜福利app| 黄色片av在线| 精品国产伦一区二区三区观看方式 | 三区四区在线视频| 日韩高清欧美高清| 色综合久久中文| 国产自产精品| 26uuu精品一区二区三区四区在线| sm一区二区三区| 日韩午夜av一区| 欧美a一欧美| 日本一区精品| 亚洲精品乱码久久久久久| 午夜影院免费在线| 日韩av免费在线看| 国产一区二区91| 日韩福利一区二区| 久久好看免费视频| 亚洲一区激情| 久草福利资源站| 亚洲成av人影院在线观看| 亚洲人成精品久久久 | 精品国产成人系列| 精品人人人人| 一区二区三区四区| 一区二区在线免费| 欧美片第1页| 国产一区二区不卡视频在线观看| 99久久综合狠狠综合久久| 神马久久高清| 欧美精品日韩三级| 久久精品国产在热久久| 男女激情视频网站| 色婷婷av一区二区三区在线观看| 欧美私人啪啪vps| 男人的天堂狠狠干| 欧美性感一区二区三区| 欧美激情久久久久久久久久久| 国产视频在线一区二区| 精品久久久久久久久久久下田| 在线国产99| 欧美揉bbbbb揉bbbbb| 超碰成人在线免费| 成人在线免费观看视频网站| 欧美日韩一区精品| 欧洲杯什么时候开赛| 免费无码av片在线观看| 亚洲高清一二三区| 夜夜爽av福利精品导航| 色视频www在线播放| 色综合男人天堂| 本田岬高潮一区二区三区| 国产后进白嫩翘臀在线观看视频| 91精品啪在线观看麻豆免费| 国产精品污污网站在线观看| 国外成人福利视频| 三年中文高清在线观看第6集| 欧美日韩午夜影院| 欧美午夜不卡| 三级黄视频在线观看| 国产成人激情小视频| 国产精品丝袜黑色高跟| 国产精品国产三级在线观看| 一级特黄妇女高潮| 亚洲精品aⅴ中文字幕乱码 | 色呦呦在线播放| 国产一区二区在线观看免费播放| 一区二区三区资源| 久久婷婷国产| 手机在线成人免费视频| 久久人人爽人人爽爽久久| 久久国产乱子精品免费女| 久久日韩视频| 久久99精品久久久久久久久久| 在线视频一区二区免费| 日韩电影二区| 制服黑丝国产在线| 日韩暖暖在线视频| 一区二区三区精品在线观看| 日韩美女精品| 黄色污网站在线免费观看| 国产精品激情av电影在线观看 | 337p粉嫩大胆噜噜噜鲁| 在线观看久久久久久| 国产盗摄精品一区二区三区在线| 黑人玩欧美人三根一起进| 亚洲视频sss| 亚洲欧美三级在线| 成人av在线影院| 综合激情网...| 369你懂的电影天堂| 国产精品一二区| 欧美色图一区二区三区| 国产精品毛片| 国产在线拍揄自揄拍视频| 免费成人进口网站| 久久综合久久八八| 亚洲免费在线视频一区 二区| 日韩精品一区二区三区免费观影| 日韩美女一级视频| 色播五月综合| 在线日韩日本国产亚洲| 欧美精彩视频一区二区三区| 真实原创一区二区影院| 国产高清视频免费最新在线| 久久涩涩网站| 夜夜嗨av一区二区三区四区| 久久伊99综合婷婷久久伊| 日韩手机在线| 在线天堂视频| 日韩高清三级| 九色成人免费视频| 欧美色视频日本版| 美女网站在线免费欧美精品| 蜜桃视频成人m3u8| 成人在线看片网站| 免费不卡亚洲欧美| 精品久久久av| 在线观看亚洲成人| 成人妖精视频yjsp地址| 亚洲综合色婷婷在线观看| 色播色播色播色播色播在线| 一区二区在线观看网站| 1769国内精品视频在线播放| 欧美在线视频不卡| 97精品久久久午夜一区二区三区| 九九热线有精品视频99| 日本无删减在线| 杨幂毛片午夜性生毛片| 精品一区二区三区免费毛片| 亚洲视频视频在线| 亚洲福利视频一区| 精品一区二区三区久久| 亚欧日韩另类中文欧美| 福利在线观看| 青青青青草视频| 亚洲一区二区三区视频| 亚洲乱码国产乱码精品精| 亚洲天堂中文字幕| 日韩av一区二区在线影视| 北条麻妃在线一区二区免费播放 | av在线播放国产| 欧美国产日韩在线播放| 国产精品久久久久久久久久久久午夜片 | 欧美精品不卡| 亚洲男男av| gogo在线观看|