真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網站制作重慶分公司

java中怎么調整代碼 java調整代碼格式

如何優(yōu)化JAVA代碼及提高執(zhí)行效率

可供程序利用的資源(內存、CPU時間、網絡帶寬等)是有限的,優(yōu)化的目的就是讓程序用盡可能少的資源完成預定的任務。優(yōu)化通常包含兩方面的內容:減小代碼的體積,提高代碼的運行效率。本文討論的主要是如何提高代碼的效率。

方山ssl適用于網站、小程序/APP、API接口等需要進行數據傳輸應用場景,ssl證書未來市場廣闊!成為成都創(chuàng)新互聯(lián)公司的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:028-86922220(備注:SSL證書合作)期待與您的合作!

在Java程序中,性能問題的大部分原因并不在于Java語言,而是在于程序本身。養(yǎng)成好的代碼編寫習慣非常重要,比如正確地、巧妙地運用java.lang.String類和java.util.Vector類,它能夠顯著地提高程序的性能。下面我們就來具體地分析一下這方面的問題。

1、 盡量指定類的final修飾符帶有final修飾符的類是不可派生的。在Java核心API中,有許多應用final的例子,例如java.lang.String。為String類指定final防止了人們覆蓋length()方法。另外,如果指定一個類為final,則該類所有的方法都是final。Java編譯器會尋找機會內聯(lián)(inline)所有的final方法(這和具體的編譯器實現有關)。此舉能夠使性能平均提高50%

。

2、 盡量重用對象。特別是String 對象的使用中,出現字符串連接情況時應用StringBuffer 代替。由于系統(tǒng)不僅要花時間生成對象,以后可能還需花時間對這些對象進行垃圾回收和處理。因此,生成過多的對象將會給程序的性能帶來很大的影響。

3、 盡量使用局部變量,調用方法時傳遞的參數以及在調用中創(chuàng)建的臨時變量都保存在棧(Stack)中,速度較快。其他變量,如靜態(tài)變量、實例變量等,都在堆(Heap)中創(chuàng)建,速度較慢。另外,依賴于具體的編譯器/JVM,局部變量還可能得到進一步優(yōu)化。請參見《盡可能使用堆棧變量》。

4、 不要重復初始化變量 默認情況下,調用類的構造函數時,

Java會把變量初始化成確定的值:所有的對象被設置成null,整數變量(byte、short、int、long)設置成0,float和double變量設置成0.0,邏輯值設置成false。當一個類從另一個類派生時,這一點尤其應該注意,因為用new關鍵詞創(chuàng)建一個對象時,構造函數鏈中的所有構造函數都會被自動調用。

5、 在JAVA + ORACLE 的應用系統(tǒng)開發(fā)中,java中內嵌的SQL語句盡量使用大寫的形式,以減輕ORACLE解析器的解析負擔。

6、 Java 編程過程中,進行數據庫連接、I/O流操作時務必小心,在使用完畢后,即使關閉以釋放資源。因為對這些大對象的操作會造成系統(tǒng)大的開銷,稍有不慎,會導致嚴重的后果。

7、 由于JVM的有其自身的GC機制,不需要程序開發(fā)者的過多考慮,從一定程度上減輕了開發(fā)者負擔,但同時也遺漏了隱患,過分的創(chuàng)建對象會消耗系統(tǒng)的大量內存,嚴重時會導致內存泄露,因此,保證過期對象的及時回收具有重要意義。JVM回收垃圾的條件是:對象不在被引用;然而,JVM的GC并非十分的機智,即使對象滿足了垃圾回收的條件也不一定會被立即回收。所以,建議我們在對象使用完畢,應手動置成null。

8、 在使用同步機制時,應盡量使用方法同步代替代碼塊同步。

9、 盡量減少對變量的重復計算

例如:for(int i = 0;i list.size; i ++) {

}

應替換為:

for(int i = 0,int len = list.size();i len; i ++) {

}

10、盡量采用lazy loading 的策略,即在需要的時候才開始創(chuàng)建。

例如: String str = “aaa”;

if(i == 1) {

list.add(str);

}

應替換為:

if(i == 1) {

String str = “aaa”;

list.add(str);

}

11、慎用異常

異常對性能不利。拋出異常首先要創(chuàng)建一個新的對象。Throwable接口的構造函數調用名為fillInStackTrace()的本地(Native)方法,fillInStackTrace()方法檢查堆棧,收集調用跟蹤信息。只要有異常被拋出,VM就必須調整調用堆棧,因為在處理過程中創(chuàng)建了一個新的對象。異常只能用于錯誤處理,不應該用來控制程序流程。

12、不要在循環(huán)中使用:

Try {

} catch() {

}

應把其放置在最外層。

13、StringBuffer 的使用:

StringBuffer表示了可變的、可寫的字符串。

有三個構造方法 :

StringBuffer (); //默認分配16個字符的空間

StringBuffer (int size); //分配size個字符的空間

StringBuffer (String str); //分配16個字符+str.length()個字符空間

你可以通過StringBuffer的構造函數來設定它的初始化容量,這樣可以明顯地提升性能。這里提到的構造函數是StringBuffer(int

length),length參數表示當前的StringBuffer能保持的字符數量。你也可以使用ensureCapacity(int

minimumcapacity)方法在StringBuffer對象創(chuàng)建之后設置它的容量。首先我們看看StringBuffer的缺省行為,然后再找出一條更好的提升性能的途徑。

StringBuffer在內部維護一個字符數組,當你使用缺省的構造函數來創(chuàng)建StringBuffer對象的時候,因為沒有設置初始化字符長度,StringBuffer的容量被初始化為16個字符,也就是說缺省容量就是16個字符。當StringBuffer達到最大容量的時候,它會將自身容量增加到當前的2倍再加2,也就是(2*舊值+2)。如果你使用缺省值,初始化之后接著往里面追加字符,在你追加到第16個字符的時候它會將容量增加到34(2*16+2),當追加到34個字符的時候就會將容量增加到70(2*34+2)。無論何事只要StringBuffer到達它的最大容量它就不得不創(chuàng)建一個新的字符數組然后重新將舊字符和新字符都拷貝一遍――這也太昂貴了點。所以總是給StringBuffer設置一個合理的初始化容量值是錯不了的,這樣會帶來立竿見影的性能增益。

StringBuffer初始化過程的調整的作用由此可見一斑。所以,使用一個合適的容量值來初始化StringBuffer永遠都是一個最佳的建議。

14、合理的使用Java類 java.util.Vector。

簡單地說,一個Vector就是一個java.lang.Object實例的數組。Vector與數組相似,它的元素可以通過整數形式的索引訪問。但是,Vector類型的對象在創(chuàng)建之后,對象的大小能夠根據元素的增加或者刪除而擴展、縮小。請考慮下面這個向Vector加入元素的例子:

Object obj = new Object();

Vector v = new Vector(100000);

for(int I=0;

I100000; I++) { v.add(0,obj); }

除非有絕對充足的理由要求每次都把新元素插入到Vector的前面,否則上面的代碼對性能不利。在默認構造函數中,Vector的初始存儲能力是10個元素,如果新元素加入時存儲能力不足,則以后存儲能力每次加倍。Vector類就象StringBuffer類一樣,每次擴展存儲能力時,所有現有的元素都要復制到新的存儲空間之中。下面的代碼片段要比前面的例子快幾個數量級:

Object obj = new Object();

Vector v = new Vector(100000);

for(int I=0; I100000; I++) { v.add(obj); }

同樣的規(guī)則也適用于Vector類的remove()方法。由于Vector中各個元素之間不能含有“空隙”,刪除除最后一個元素之外的任意其他元素都導致被刪除元素之后的元素向前移動。也就是說,從Vector刪除最后一個元素要比刪除第一個元素“開銷”低好幾倍。

假設要從前面的Vector刪除所有元素,我們可以使用這種代碼:

for(int I=0; I100000; I++)

{

 v.remove(0);

}

但是,與下面的代碼相比,前面的代碼要慢幾個數量級:

for(int I=0; I100000; I++)

{

 v.remove(v.size()-1);

}

從Vector類型的對象v刪除所有元素的最好方法是:

v.removeAllElements();

假設Vector類型的對象v包含字符串“Hello”??紤]下面的代碼,它要從這個Vector中刪除“Hello”字符串:

String s = "Hello";

int i = v.indexOf(s);

if(I != -1) v.remove(s);

這些代碼看起來沒什么錯誤,但它同樣對性能不利。在這段代碼中,indexOf()方法對v進行順序搜索尋找字符串“Hello”,remove(s)方法也要進行同樣的順序搜索。改進之后的版本是:

String s = "Hello";

int i = v.indexOf(s);

if(I != -1) v.remove(i);

這個版本中我們直接在remove()方法中給出待刪除元素的精確索引位置,從而避免了第二次搜索。一個更好的版本是:

String s = "Hello"; v.remove(s);

最后,我們再來看一個有關Vector類的代碼片段:

for(int I=0; I++;I v.length)

如果v包含100,000個元素,這個代碼片段將調用v.size()方法100,000次。雖然size方法是一個簡單的方法,但它仍舊需要一次方法調用的開銷,至少JVM需要為它配置以及清除堆棧環(huán)境。在這里,for循環(huán)內部的代碼不會以任何方式修改Vector類型對象v的大小,因此上面的代碼最好改寫成下面這種形式:

int size = v.size(); for(int I=0; I++;Isize)

雖然這是一個簡單的改動,但它仍舊贏得了性能。畢竟,每一個CPU周期都是寶貴的。

15、當復制大量數據時,使用System.arraycopy()命令。

16、代碼重構:增強代碼的可讀性。

例如:

public class ShopCart {

private List carts ;

public void add (Object item) {

if(carts == null) {

carts = new ArrayList();

}

crts.add(item);

}

public void remove(Object item) {

if(carts. contains(item)) {

carts.remove(item);

}

}

public List getCarts() {

//返回只讀列表

return Collections.unmodifiableList(carts);

}

//不推薦這種方式

//this.getCarts().add(item);

}

17、不用new關鍵詞創(chuàng)建類的實例

用new關鍵詞創(chuàng)建類的實例時,構造函數鏈中的所有構造函數都會被自動調用。但如果一個對象實現了Cloneable接口,我們可以調用它的clone()方法。clone()方法不會調用任何類構造函數。

在使用設計模式(Design Pattern)的場合,如果用Factory模式創(chuàng)建對象,則改用clone()方法創(chuàng)建新的對象實例非常簡單。例如,下面是Factory模式的一個典型實現:

public static Credit getNewCredit() {

return new Credit();

}

改進后的代碼使用clone()方法,如下所示:

private static Credit BaseCredit = new Credit();

public static Credit getNewCredit() {

return (Credit) BaseCredit.clone();

}

上面的思路對于數組處理同樣很有用。

18、乘法和除法

考慮下面的代碼:

for (val = 0; val 100000; val +=5) {

alterX = val * 8; myResult = val * 2;

}

用移位操作替代乘法操作可以極大地提高性能。下面是修改后的代碼:

for (val = 0; val 100000; val += 5) {

alterX = val 3; myResult = val 1;

}

修改后的代碼不再做乘以8的操作,而是改用等價的左移3位操作,每左移1位相當于乘以2。相應地,右移1位操作相當于除以2。值得一提的是,雖然移位操作速度快,但可能使代碼比較難于理解,所以最好加上一些注釋。

19、在JSP頁面中關閉無用的會話。

一個常見的誤解是以為session在有客戶端訪問時就被創(chuàng)建,然而事實是直到某server端程序調用HttpServletRequest.getSession(true)這樣的語句時才被創(chuàng)建,注意如果JSP沒有顯示的使用 %@pagesession="false"% 關閉session,則JSP文件在編譯成Servlet時將會自動加上這樣一條語句HttpSession

session = HttpServletRequest.getSession(true);這也是JSP中隱含的session對象的來歷。由于session會消耗內存資源,因此,如果不打算使用session,應該在所有的JSP中關閉它。

對于那些無需跟蹤會話狀態(tài)的頁面,關閉自動創(chuàng)建的會話可以節(jié)省一些資源。使用如下page指令:%@ page session="false"%

20、JDBC與I/O

如果應用程序需要訪問一個規(guī)模很大的數據集,則應當考慮使用塊提取方式。默認情況下,JDBC每次提取32行數據。舉例來說,假設我們要遍歷一個5000行的記錄集,JDBC必須調用數據庫157次才能提取到全部數據。如果把塊大小改成512,則調用數據庫的次數將減少到10次。

[p][/p]21、Servlet與內存使用

許多開發(fā)者隨意地把大量信息保存到用戶會話之中。一些時候,保存在會話中的對象沒有及時地被垃圾回收機制回收。從性能上看,典型的癥狀是用戶感到系統(tǒng)周期性地變慢,卻又不能把原因歸于任何一個具體的組件。如果監(jiān)視JVM的堆空間,它的表現是內存占用不正常地大起大落。

解決這類內存問題主要有二種辦法。第一種辦法是,在所有作用范圍為會話的Bean中實現HttpSessionBindingListener接口。這樣,只要實現valueUnbound()方法,就可以顯式地釋放Bean使用的資源。另外一種辦法就是盡快地把會話作廢。大多數應用服務器都有設置會話作廢間隔時間的選項。另外,也可以用編程的方式調用會話的setMaxInactiveInterval()方法,該方法用來設定在作廢會話之前,Servlet容器允許的客戶請求的最大間隔時間,以秒計。

22、使用緩沖標記

一些應用服務器加入了面向JSP的緩沖標記功能。例如,BEA的WebLogic Server從6.0版本開始支持這個功能,Open

Symphony工程也同樣支持這個功能。JSP緩沖標記既能夠緩沖頁面片斷,也能夠緩沖整個頁面。當JSP頁面執(zhí)行時,如果目標片斷已經在緩沖之中,則生成該片斷的代碼就不用再執(zhí)行。頁面級緩沖捕獲對指定URL的請求,并緩沖整個結果頁面。對于購物籃、目錄以及門戶網站的主頁來說,這個功能極其有用。對于這類應用,頁面級緩沖能夠保存頁面執(zhí)行的結果,供后繼請求使用。

23、選擇合適的引用機制

在典型的JSP應用系統(tǒng)中,頁頭、頁腳部分往往被抽取出來,然后根據需要引入頁頭、頁腳。當前,在JSP頁面中引入外部資源的方法主要有兩種:include指令,以及include動作。

include指令:例如%@ include file="copyright.html"

%。該指令在編譯時引入指定的資源。在編譯之前,帶有include指令的頁面和指定的資源被合并成一個文件。被引用的外部資源在編譯時就確定,比運行時才確定資源更高效。

include動作:例如jsp:include page="copyright.jsp"

/。該動作引入指定頁面執(zhí)行后生成的結果。由于它在運行時完成,因此對輸出結果的控制更加靈活。但時,只有當被引用的內容頻繁地改變時,或者在對主頁面的請求沒有出現之前,被引用的頁面無法確定時,使用include動作才合算。

24、及時清除不再需要的會話

為了清除不再活動的會話,許多應用服務器都有默認的會話超時時間,一般為30分鐘。當應用服務器需要保存更多會話時,如果內存容量不足,操作系統(tǒng)會把部分內存數據轉移到磁盤,應用服務器也可能根據“最近最頻繁使用”(Most

Recently

Used)算法把部分不活躍的會話轉儲到磁盤,甚至可能拋出“內存不足”異常。在大規(guī)模系統(tǒng)中,串行化會話的代價是很昂貴的。當會話不再需要時,應當及時調用HttpSession.invalidate()方法清除會話。HttpSession.invalidate()方法通常可以在應用的退出頁面調用。

25、不要將數組聲明為:public static final 。

26、HashMap的遍歷效率討論

經常遇到對HashMap中的key和value值對的遍歷操作,有如下兩種方法:MapString, String[] paraMap = new HashMapString, String[]();

................//第一個循環(huán)

SetString appFieldDefIds = paraMap.keySet();

for (String appFieldDefId : appFieldDefIds) {

String[] values = paraMap.get(appFieldDefId);

......

}

//第二個循環(huán)

for(EntryString, String[] entry : paraMap.entrySet()){

String appFieldDefId = entry.getKey();

String[] values = entry.getValue();

.......

}

第一種實現明顯的效率不如第二種實現。

分析如下 SetString appFieldDefIds = paraMap.keySet(); 是先從HashMap中取得keySet

代碼如下:

public SetK keySet() {

SetK ks = keySet;

return (ks != null ? ks : (keySet = new KeySet()));

}

private class KeySet extends AbstractSetK {

public IteratorK iterator() {

return newKeyIterator();

}

public int size() {

return size;

}

public boolean contains(Object o) {

return containsKey(o);

}

public boolean remove(Object o) {

return HashMap.this.removeEntryForKey(o) != null;

}

public void clear() {

HashMap.this.clear();

}

}

其實就是返回一個私有類KeySet, 它是從AbstractSet繼承而來,實現了Set接口。

再來看看for/in循環(huán)的語法

for(declaration : expression_r)

statement

在執(zhí)行階段被翻譯成如下各式

for(IteratorE #i = (expression_r).iterator(); #i.hashNext();){

declaration = #i.next();

statement

}

因此在第一個for語句for (String appFieldDefId : appFieldDefIds) 中調用了HashMap.keySet().iterator() 而這個方法調用了newKeyIterator()

IteratorK newKeyIterator() {

return new KeyIterator();

}

private class KeyIterator extends HashIteratorK {

public K next() {

return nextEntry().getKey();

}

}

所以在for中還是調用了

在第二個循環(huán)for(EntryString, String[] entry : paraMap.entrySet())中使用的Iterator是如下的一個內部類

private class EntryIterator extends HashIteratorMap.EntryK,V {

public Map.EntryK,V next() {

return nextEntry();

}

}

此時第一個循環(huán)得到key,第二個循環(huán)得到HashMap的Entry

效率就是從循環(huán)里面體現出來的第二個循環(huán)此致可以直接取key和value值

而第一個循環(huán)還是得再利用HashMap的get(Object key)來取value值

現在看看HashMap的get(Object key)方法

public V get(Object key) {

Object k = maskNull(key);

int hash = hash(k);

int i = indexFor(hash, table.length); //Entry[] table

EntryK,V e = table;

while (true) {

if (e == null)

return null;

if (e.hash == hash eq(k, e.key))

return e.value;

e = e.next;

}

}

其實就是再次利用Hash值取出相應的Entry做比較得到結果,所以使用第一中循環(huán)相當于兩次進入HashMap的Entry中

而第二個循環(huán)取得Entry的值之后直接取key和value,效率比第一個循環(huán)高。其實按照Map的概念來看也應該是用第二個循環(huán)好一點,它本來就是key和value的值對,將key和value分開操作在這里不是個好選擇。

java中如何調整代碼位置快捷方式

Ctrl+1 快速修復(最經典的快捷鍵,就不用多說了)

Ctrl+D: 刪除當前行

Ctrl+Alt+↓ 復制當前行到下一行(復制增加)

Ctrl+Alt+↑ 復制當前行到上一行(復制增加)

Alt+↓ 當前行和下面一行交互位置(特別實用,可以省去先剪切,再粘貼了)

Alt+↑ 當前行和上面一行交互位置(同上)

Alt+← 前一個編輯的頁面

Alt+→ 下一個編輯的頁面(當然是針對上面那條來說了)

Alt+Enter 顯示當前選擇資源(工程,or 文件 or文件)的屬性

Shift+Enter 在當前行的下一行插入空行(這時鼠標可以在當前行的任一位置,不一定是最后)

Shift+Ctrl+Enter 在當前行插入空行(原理同上條)

Ctrl+Q 定位到最后編輯的地方

Ctrl+L 定位在某行 (對于程序超過100的人就有福音了)

Ctrl+M 最大化當前的Edit或View (再按則反之)

Ctrl+/ 注釋當前行,再按則取消注釋

Ctrl+O 快速顯示 OutLine

Ctrl+T 快速顯示當前類的繼承結構

Ctrl+W 關閉當前Editer

Ctrl+K 參照選中的Word快速定位到下一個

Ctrl+E 快速顯示當前Editer的下拉列表(如果當前頁面沒有顯示的用黑體表示)

Ctrl+/(小鍵盤) 折疊當前類中的所有代碼

Ctrl+×(小鍵盤) 展開當前類中的所有代碼

Ctrl+Space 代碼助手完成一些代碼的插入(但一般和輸入法有沖突,可以修改輸入法的熱鍵,也可以暫用Alt+/來代替)

Ctrl+Shift+E 顯示管理當前打開的所有的View的管理器(可以選擇關閉,激活等操作)

Ctrl+J 正向增量查找(按下Ctrl+J后,你所輸入的每個字母編輯器都提供快速匹配定位到某個單詞,如果沒有,則在stutes line中顯示沒有找到了,查一個單詞時,特別實用,這個功能Idea兩年前就有了)

Ctrl+Shift+J 反向增量查找(和上條相同,只不過是從后往前查)

Ctrl+Shift+F4 關閉所有打開的Editer

Ctrl+Shift+X 把當前選中的文本全部變味小寫

Ctrl+Shift+Y 把當前選中的文本全部變?yōu)樾?/p>

Ctrl+Shift+F 格式化當前代碼

Ctrl+Shift+P 定位到對于的匹配符(譬如{}) (從前面定位后面時,光標要在匹配符里面,后面到前面,則反之)

下面的快捷鍵是重構里面常用的,本人就自己喜歡且常用的整理一下(注:一般重構的快捷鍵都是Alt+Shift開頭的了)

Alt+Shift+R 重命名 (是我自己最愛用的一個了,尤其是變量和類的Rename,比手工方法能節(jié)省很多勞動力)

Alt+Shift+M 抽取方法 (這是重構里面最常用的方法之一了,尤其是對一大堆泥團代碼有用)

Alt+Shift+C 修改函數結構(比較實用,有N個函數調用了這個方法,修改一次搞定)

Alt+Shift+L 抽取本地變量( 可以直接把一些魔法數字和字符串抽取成一個變量,尤其是多處調用的時候)

Alt+Shift+F 把Class中的local變量變?yōu)閒ield變量 (比較實用的功能)

Alt+Shift+I 合并變量(可能這樣說有點不妥Inline)

Alt+Shift+V 移動函數和變量(不怎么常用)

Alt+Shift+Z 重構的后悔藥(Undo)

編輯

作用域 功能 快捷鍵

全局 查找并替換 Ctrl+F

文本編輯器 查找上一個 Ctrl+Shift+K

文本編輯器 查找下一個 Ctrl+K

全局 撤銷 Ctrl+Z

全局 復制 Ctrl+C

全局 恢復上一個選擇 Alt+Shift+↓

全局 剪切 Ctrl+X

全局 快速修正 Ctrl1+1

全局 內容輔助 Alt+/

全局 全部選中 Ctrl+A

全局 刪除 Delete

全局 上下文信息 Alt+?

Alt+Shift+?

Ctrl+Shift+Space

Java編輯器 顯示工具提示描述 F2

Java編輯器 選擇封裝元素 Alt+Shift+↑

Java編輯器 選擇上一個元素 Alt+Shift+←

Java編輯器 選擇下一個元素 Alt+Shift+→

文本編輯器 增量查找 Ctrl+J

文本編輯器 增量逆向查找 Ctrl+Shift+J

全局 粘貼 Ctrl+V

全局 重做 Ctrl+Y

查看

作用域 功能 快捷鍵

全局 放大 Ctrl+=

全局 縮小 Ctrl+-

窗口

作用域 功能 快捷鍵

全局 激活編輯器 F12

全局 切換編輯器 Ctrl+Shift+W

全局 上一個編輯器 Ctrl+Shift+F6

全局 上一個視圖 Ctrl+Shift+F7

全局 上一個透視圖 Ctrl+Shift+F8

全局 下一個編輯器 Ctrl+F6

全局 下一個視圖 Ctrl+F7

全局 下一個透視圖 Ctrl+F8

文本編輯器 顯示標尺上下文菜單 Ctrl+W

全局 顯示視圖菜單 Ctrl+F10

全局 顯示系統(tǒng)菜單 Alt+-

導航

作用域 功能 快捷鍵

Java編輯器 打開結構 Ctrl+F3

全局 打開類型 Ctrl+Shift+T

全局 打開類型層次結構 F4

全局 打開聲明 F3

全局 打開外部javadoc Shift+F2

全局 打開資源 Ctrl+Shift+R

全局 后退歷史記錄 Alt+←

全局 前進歷史記錄 Alt+→

全局 上一個 Ctrl+,

全局 下一個 Ctrl+.

Java編輯器 顯示大綱 Ctrl+O

全局 在層次結構中打開類型 Ctrl+Shift+H

全局 轉至匹配的括號 Ctrl+Shift+P

全局 轉至上一個編輯位置 Ctrl+Q

Java編輯器 轉至上一個成員 Ctrl+Shift+↑

Java編輯器 轉至下一個成員 Ctrl+Shift+↓

文本編輯器 轉至行 Ctrl+L

搜索

作用域 功能 快捷鍵

全局 出現在文件中 Ctrl+Shift+U

全局 打開搜索對話框 Ctrl+H

全局 工作區(qū)中的聲明 Ctrl+G

全局 工作區(qū)中的引用 Ctrl+Shift+G

文本編輯

作用域 功能 快捷鍵

文本編輯器 改寫切換 Insert

文本編輯器 上滾行 Ctrl+↑

文本編輯器 下滾行 Ctrl+↓

文件

作用域 功能 快捷鍵

全局 保存 Ctrl+X

Ctrl+S

全局 打印 Ctrl+P

全局 關閉 Ctrl+F4

全局 全部保存 Ctrl+Shift+S

全局 全部關閉 Ctrl+Shift+F4

全局 屬性 Alt+Enter

全局 新建 Ctrl+N

項目

作用域 功能 快捷鍵

全局 全部構建 Ctrl+B

源代碼

作用域 功能 快捷鍵

Java編輯器 格式化 Ctrl+Shift+F

Java編輯器 取消注釋 Ctrl+\

Java編輯器 注釋 Ctrl+/

Java編輯器 添加導入 Ctrl+Shift+M

Java編輯器 組織導入 Ctrl+Shift+O

Java編輯器 使用try/catch塊來包圍 未設置,太常用了,所以在這里列出,建議自己設置。

也可以使用Ctrl+1自動修正。

運行

作用域 功能 快捷鍵

全局 單步返回 F7

全局 單步跳過 F6

全局 單步跳入 F5

全局 單步跳入選擇 Ctrl+F5

全局 調試上次啟動 F11

全局 繼續(xù) F8

全局 使用過濾器單步執(zhí)行 Shift+F5

全局 添加/去除斷點 Ctrl+Shift+B

全局 顯示 Ctrl+D

全局 運行上次啟動 Ctrl+F11

全局 運行至行 Ctrl+R

全局 執(zhí)行 Ctrl+U

重構

作用域 功能 快捷鍵

全局 撤銷重構 Alt+Shift+Z

全局 抽取方法 Alt+Shift+M

全局 抽取局部變量 Alt+Shift+L

全局 內聯(lián) Alt+Shift+I

全局 移動 Alt+Shift+V

全局 重命名 Alt+Shift+R

全局 重做 Alt+Shift+Y

怎么調試jsp中的java代碼

調試jsp中的java代碼,可以通過 Syste.out.println(); 在控制臺打印輸出 。 感覺哪一行代碼有問題就在那個代碼后面寫上輸出語句。 代碼都是重上往下一行一行執(zhí)行的 。

Java代碼如何優(yōu)化

1. 盡量在合適的場合使用單例

使用單例可以減輕加載的負擔,縮短加載的時間,提高加載的效率,但并不是所有地方都適用于單例,簡單來說,單例主要適用于以下三個方面:

第一,控制資源的使用,通過線程同步來控制資源的并發(fā)訪問;

第二,控制實例的產生,以達到節(jié)約資源的目的;

第三,控制數據共享,在不建立直接關聯(lián)的條件下,讓多個不相關的進程或線程之間實現通信。

2. 盡量避免隨意使用靜態(tài)變量

要知道,當某個對象被定義為stataic變量所引用,那么gc通常是不會回收這個對象所占有的內存

3. 盡量避免過多過常的創(chuàng)建Java對象

盡量避免在經常調用的方法,循環(huán)中new對象,由于系統(tǒng)不僅要花費時間來創(chuàng)建對象,而且還要花時間對這些對象進行垃圾回收和處理,在我們可以控制的范圍內,最大限度的重用對象,最好能用基本的數據類型或數組來替代對象。

4. 盡量使用final修飾符

帶有final修飾符的類是不可派生的。在Java核心API中,有許多應用final的例子,例如java.lang.String.為String類指定final防止了使用者覆蓋length()方法。另外,如果一個類是final的,則該類所有方法都是final的。Java編譯器會尋找機會內聯(lián)(inline)所有的final方法(這和具體的編譯器實現有關)。此舉能夠使性能平均提高50%.

5. 盡量使用局部變量

調用方法時傳遞的參數以及在調用中創(chuàng)建的臨時變量都保存在棧(Stack)中,速度較快。其他變量,如靜態(tài)變量、實例變量等,都在堆(Heap)中創(chuàng)建,速度較慢。

6. 盡量處理好包裝類型和基本類型兩者的使用場所

雖然包裝類型和基本類型在使用過程中是可以相互轉換,但它們兩者所產生的內存區(qū)域是完全不同的,基本類型數據產生和處理都在棧中處理,包裝類型是對象,是在堆中產生實例。

在集合類對象,有對象方面需要的處理適用包裝類型,其他的處理提倡使用基本類型。

7. 慎用synchronized,盡量減小synchronize的方法

都知道,實現同步是要很大的系統(tǒng)開銷作為代價的,甚至可能造成死鎖,所以盡量避免無謂的同步控制。synchronize方法被調用時,直接會把當前對象鎖 了,在方法執(zhí)行完之前其他線程無法調用當前對象的其他方法。所以synchronize的方法盡量小,并且應盡量使用方法同步代替代碼塊同步。

8. 盡量使用StringBuilder和StringBuffer進行字符串連接

這個就不多講了。

9. 盡量不要使用finalize方法

實際上,將資源清理放在finalize方法中完成是非常不好的選擇,由于GC的工作量很大,尤其是回收Young代內存時,大都會引起應用程序暫停,所以再選擇使用finalize方法進行資源清理,會導致GC負擔更大,程序運行效率更差。

10. 盡量使用基本數據類型代替對象

String str = "hello";

上面這種方式會創(chuàng)建一個"hello"字符串,而且JVM的字符緩存池還會緩存這個字符串;

String str = new String("hello");

此時程序除創(chuàng)建字符串外,str所引用的String對象底層還包含一個char[]數組,這個char[]數組依次存放了h,e,l,l,o

11. 單線程應盡量使用HashMap、ArrayList

HashTable、Vector等使用了同步機制,降低了性能。

12. 盡量合理的創(chuàng)建HashMap

當你要創(chuàng)建一個比較大的hashMap時,充分利用另一個構造函數

public HashMap(int initialCapacity, float loadFactor)

避免HashMap多次進行了hash重構,擴容是一件很耗費性能的事,在默認中initialCapacity只有16,而loadFactor是 0.75,需要多大的容量,你最好能準確的估計你所需要的最佳大小,同樣的Hashtable,Vectors也是一樣的道理。

13. 盡量減少對變量的重復計算

并且在循環(huán)中應該避免使用復雜的表達式,在循環(huán)中,循環(huán)條件會被反復計算,如果不使用復雜表達式,而使循環(huán)條件值不變的話,程序將會運行的更快。

14. 盡量避免不必要的創(chuàng)建

15. 盡量在finally塊中釋放資源

程序中使用到的資源應當被釋放,以避免資源泄漏。這最好在finally塊中去做。不管程序執(zhí)行的結果如何,finally塊總是會執(zhí)行的,以確保資源的正確關閉。

16. 盡量使用移位來代替'a/b'的操作

"/"是一個代價很高的操作,使用移位的操作將會更快和更有效

17.盡量使用移位來代替'a*b'的操作

同樣的,對于'*'操作,使用移位的操作將會更快和更有效

18. 盡量確定StringBuffer的容量

StringBuffer 的構造器會創(chuàng)建一個默認大小(通常是16)的字符數組。在使用中,如果超出這個大小,就會重新分配內存,創(chuàng)建一個更大的數組,并將原先的數組復制過來,再 丟棄舊的數組。在大多數情況下,你可以在創(chuàng)建 StringBuffer的時候指定大小,這樣就避免了在容量不夠的時候自動增長,以提高性能。

19. 盡量早釋放無用對象的引用

大部分時,方法局部引用變量所引用的對象 會隨著方法結束而變成垃圾,因此,大部分時候程序無需將局部,引用變量顯式設為null.

20. 盡量避免使用二維數組

二維數據占用的內存空間比一維數組多得多,大概10倍以上。

21. 盡量避免使用split

除非是必須的,否則應該避免使用split,split由于支持正則表達式,所以效率比較低,如果是頻繁的幾十,幾百萬的調用將會耗費大量資源,如果確實需 要頻繁的調用split,可以考慮使用apache的StringUtils.split(string,char),頻繁split的可以緩存結果。

22. ArrayList LinkedList

一 個是線性表,一個是鏈表,一句話,隨機查詢盡量使用ArrayList,ArrayList優(yōu)于LinkedList,LinkedList還要移動指 針,添加刪除的操作LinkedList優(yōu)于ArrayList,ArrayList還要移動數據,不過這是理論性分析,事實未必如此,重要的是理解好2 者得數據結構,對癥下藥。

23. 盡量使用System.arraycopy ()代替通過來循環(huán)復制數組

System.arraycopy() 要比通過循環(huán)來復制數組快的多

24. 盡量緩存經常使用的對象

盡可能將經常使用的對象進行緩存,可以使用數組,或HashMap的容器來進行緩存,但這種方式可能導致系統(tǒng)占用過多的緩存,性能下降,推薦可以使用一些第三方的開源工具,如EhCache,Oscache進行緩存,他們基本都實現了FIFO/FLU等緩存算法。

25. 盡量避免非常大的內存分配

有時候問題不是由當時的堆狀態(tài)造成的,而是因為分配失敗造成的。分配的內存塊都必須是連續(xù)的,而隨著堆越來越滿,找到較大的連續(xù)塊越來越困難。

26. 慎用異常

當創(chuàng)建一個異常時,需要收集一個棧跟蹤(stack track),這個棧跟蹤用于描述異常是在何處創(chuàng)建的。構建這些棧跟蹤時需要為運行時棧做一份快照,正是這一部分開銷很大。當需要創(chuàng)建一個 Exception 時,JVM 不得不說:先別動,我想就您現在的樣子存一份快照,所以暫時停止入棧和出棧操作。棧跟蹤不只包含運行時棧中的一兩個元素,而是包含這個棧中的每一個元素。

如 果您創(chuàng)建一個 Exception ,就得付出代價。好在捕獲異常開銷不大,因此可以使用 try-catch 將核心內容包起來。從技術上講,您甚至可以隨意地拋出異常,而不用花費很大的代價。招致性能損失的并不是 throw 操作--盡管在沒有預先創(chuàng)建異常的情況下就拋出異常是有點不尋常。真正要花代價的是創(chuàng)建異常。幸運的是,好的編程習慣已教會我們,不應該不管三七二十一就 拋出異常。異常是為異常的情況而設計的,使用時也應該牢記這一原則。

(1)。 用Boolean.valueOf(boolean b)代替new Boolean()

包裝類的內存占用是很恐怖的,它是基本類型內存占用的N倍(N2),同時new一個對象也是性能的消耗。

(2)。 用Integer.valueOf(int i)代替new Integer()

和Boolean類似,java開發(fā)中使用Integer封裝int的場合也非常多,并且通常用int表示的數值都非常小。SUN SDK中對Integer的實例化進行了優(yōu)化,Integer類緩存了-128到127這256個狀態(tài)的Integer,如果使用 Integer.valueOf(int i),傳入的int范圍正好在此內,就返回靜態(tài)實例。這樣如果我們使用Integer.valueOf代替new Integer的話也將大大降低內存的占用。

(3)。 用StringBuffer的append方法代替"+"進行字符串相加。

這個已經被N多人說過N次了,這個就不多說了。

(4)。 避免過深的類層次結構和過深的方法調用。

因為這兩者都是非常占用內存的(特別是方法調用更是堆??臻g的消耗大戶)。

(5)。 變量只有在用到它的時候才定義和實例化。

這是初學者最容易犯的錯,合理的使用變量,并且只有在用到它的時候才定義和實例化,能有效的避免內存空間和執(zhí)行性能上的浪費,從而提高了代碼的效率。

(6)。 避免在循環(huán)體中聲明創(chuàng)建對象,即使該對象占用內存空間不大。

這種情況在我們的實際應用中經常遇到,而且我們很容易犯類似的錯誤

采用上面的第二種編寫方式,僅在內存中保存一份對該對象的引用,而不像上面的第一種編寫方式中代碼會在內存中產生大量的對象引用,浪費大量的內存空間,而且增大了垃圾回收的負荷。因此在循環(huán)體中聲明創(chuàng)建對象的編寫方式應該盡量避免。

(7)。 如果if判斷中多個條件用'||'或者''連接,請將出現頻率最高的條件放在表達式最前面。

這個小技巧往往能有效的提高程序的性能,尤其是當if判斷放在循環(huán)體里面時,效果更明顯。

1.JVM管理兩種類型的內存:堆內存(heap),棧內存(stack),堆內在主要用來存儲程序在運行時創(chuàng)建或實例化的對象與變量。而棧內存則是用來存儲程序代碼中聲明為靜態(tài)(static)(或非靜態(tài))的方法。

2.JVM中對象的生命周期,創(chuàng)建階段,應用階段,不可視階段,不可到達階段,可收集階段,終結階段,釋放階段

3.避免在循環(huán)體中創(chuàng)建對象,即使該對象點用內存空間不大。

4.軟引用的主要特點是具有較強的引用功能。只有當內存不夠的時候,才回收這類內存,因此在內存足夠的時候,它們通常不被回收。它可以用于實現一些常用資源的緩存,實現Cache的功能

5.弱引用對象與Soft引用對象最大不同就在于:GC在進行回收時,需要通過算法檢查是否回收Soft引用對象,而對于Weak引用對象,GC總是進行回收。

6.共享靜態(tài)變量存儲空間

7.有時候我們?yōu)榱颂岣呦到y(tǒng)性能,避免重復耗時的操作,希望能夠重用一些創(chuàng)建完成的對象,利用對象池實現。類似JDBC連接池。

8.瞬間值,序列化對象大變量時,如果此大變量又沒有用途,則使用transient聲明,不序列化此變量。同時網絡傳輸中也不傳輸。

9.不要提前創(chuàng)建對象

10 .(1)最基本的建議就是盡早釋放無用對象的引用

A a = new A();

a = null; //當使用對象a之后主動將其設置為空

(2)盡量少用finalize函數。

(3) 如果需要使用經常用到的圖片展,可以使用軟引用。

(4) 注意集合數據類型,包括數組,樹等數據,這些數據結構對GC來說,回收更為復雜,

(5) 盡量避免在類的默認構造器中創(chuàng)建,初始化大量的對象,防止在調用其自類的構造器時造成不必要的內存資源浪費。

(6) 盡量避免強制系統(tǒng)做垃圾內存回收。

(7) 盡量避免顯式申請數組空間。

(8) 盡量在合適的場景下使用對象池技術以提高系統(tǒng)性能,縮減系統(tǒng)內存開銷。

11.當做數組拷貝操作時,采用System.arraycopy()方法完成拷貝操作要比采用循環(huán)的辦法完成數組拷貝操作效率高

12. 盡量避免在循環(huán)體中調用方法,因為方法調用是比較昂貴的。

13. 盡量避免在循環(huán)體中使用try-catch 塊,最好在循環(huán)體外使用try--catch塊以提高系統(tǒng)性能。

14. 在多重循環(huán)中,如果有可能,盡量將最長的循環(huán)放在最內層,最短的循環(huán)放在最外層,以減少循環(huán)層間的變換次數。

15. 在需要線程安全的情況下,使用List list = Collections.synchronizedList(new ArrayList());

16. 如果預知長度,就設置ArrayList的長度。

17. ArrayList 與 LinkedList 選擇,熟悉底層的實現原理,選擇適當的容器。

18. 字符串累加采用StringBuffer.

19. 系統(tǒng)I/O優(yōu)化,采用緩沖和壓縮技術。優(yōu)化性能。

20. 避免在類在構造器的初始化其他類

21 盡量避免在構造中對靜態(tài)變量做賦值操作

22. 不要在類的構造器中創(chuàng)建類的實例

23. 組合優(yōu)化繼承

24. 最好通過Class.forname() 動態(tài)的裝載類

25. JSP優(yōu)化,采用out 對象中的print方法代替println()方法

26 .采用ServletOutputStream 對象代替JSPWriter對象

27. 采用適當的值初始化out 對象緩沖區(qū)的大小

28. 盡量采用forward()方法重定向新的JSP

29. 利用線程池技術處理客戶請求

30.Servlet優(yōu)化

(1) 通過init()方法來緩存一些靜態(tài)數據以提高應用性能。

(2) 用print() 方法取代println()方法。

(3) 用ServletOutputStream 取代 PrintWriter.

(4) 盡量縮小同步代碼數量

31. 改善Servlet應用性能的方法

(1)不要使用SingleThreadModel

(2)使用線程池ThreadPool

32. EJB優(yōu)化

實體EJB:

(1)實體EJB中常用數據緩存與釋放

(2)采用延遲加載的方式裝載關聯(lián)數據

(3)盡可能地應用CMP類型實體EJB

(4)直接采用JDBC技術處理大型數據

33. 優(yōu)化JDBC連接

(1)設置合適的預取行值

(2)采用連接池技術

(3)全合理應用事務

(4)選擇合適的事務隔離層與及時關閉連接對象

34. PreparedStatemetn只編譯解析一次,而Statement每次都編譯解析。

35. 盡可能地做批處理更新

36. 通過采用合適的getXXX方法提高系統(tǒng)性能

37. 采用設計模式。

JAVA。。 如何在以下代碼中調整我所添加按鈕的位置及大小?

代碼太亂,這種生聲明的Button不好更改屬性,最好自己使用JButton button_1=new JButton()聲明一個對象,使用button_1對象來調用各種設置屬性的方法

如果還想設置好看,還需要給該frame設置一中合適的布局(Layout)


網頁題目:java中怎么調整代碼 java調整代碼格式
文章起源:http://weahome.cn/article/hhpods.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部