Java源自C,擁有跨平台、面向對象、泛型編程的特性,非常受企業的喜歡。
其次,Java語言還具有較高的安全特性,因此Java經常被用在網路環境中。
同時,Java對通過網路下載的類具有一個安全防範機制(類ClassLoader),如分配不同的名字空間以防替代本地的同名類、位元組代碼檢查,並提供安全管理機制(類SecurityManager)讓Java應用設置安全哨兵。
Python是一種解釋型腳本語言,其在設計上也堅持了清晰劃一的風格,這使得Python成為易讀、易維護的語言。
相比於其他語言,Python中的語言語法和語義要簡單得多,而且代碼也具可讀性。在大多數情況下,為了解決某一特定的問題,Python編寫所需代碼,要比其他流行語言所需的代碼少得多。
而且Python中的模塊化體系結構,使得導入和使用模塊不是編寫大塊代碼,一個成熟的模塊生態系統就已經可以幫你解決問題。
因此,對於新手來說,Python是一種很容易上手,並便於維護的語言
1.Python比Java簡單,學習成本低,開發效率高
2.Java運行效率高於Python,尤其是純Python開發的程序,效率極低
3.Java相關資料多,尤其是中文資料
4.Java版本比較穩定,Python2和3不兼容導致大量類庫失效
5.Java開發偏向於軟體工程,團隊協同,Python更適合小型開發
6.Java偏向於商業開發,Python適合於數據分析
7.Java是一種靜態類型語言,Python是一種動態類型語言
8.Java中的所有變數需要先聲明(類型)才能使用,Python中的變數不需要聲明類型
9.Java編譯以後才能運行,Python直接就可以運行;
10.JAVA 里的塊用大括弧對包括,Python 以冒號 + 四個空格縮進表示。
11.JAVA 的類型要聲明,Python 的類型不需要。
12.JAVA 每行語句以分號結束,Python 可以不寫分號。
13.實現同一功能時,JAVA 要敲的鍵盤次數一般要比 Python 多。
推薦課程:Python基礎(周莫煩)
② 如何通俗易懂地解釋編譯原理中語法分析的過程
分成詞法分析,語法分析(LL演算法,遞歸下降演算法,LR演算法),語義分析,運行時環境,中間代碼,代碼生成,代碼優化這些部分。其實現在很多編譯原理的教材都是按照85,86出版的那本龍書來安排教學內容的,所以那本龍書的內容格式幾乎成了現在編譯原理教材的定式,包括國內的教材也是如此。一般來說,大學裡面的本科教學是不可能把上面的所有部分都認真講完的,而是比較偏重於前面幾個部分。像代碼優化那部分東西,就像個無底洞一樣,如果要認真講,就是單獨開一個學期的課也不可能講得清楚。所以,一般對於本科生,對詞法分析和語法分析掌握要求就相對要高一點了。
詞法分析相對來說比較簡單。可能是詞法分析程序本身實現起來很簡單吧,很多沒有學過編譯原理的人也同樣可以寫出各種各樣的詞法分析程序。不過編譯原理在講解詞法分析的時候,重點把正則表達式和自動機原理加了進來,然後以一種十分標準的方式來講解詞法分析程序的產生。這樣的做法道理很明顯,就是要讓詞法分析從程序上升到理論的地步。
語法分析部分就比較麻煩一點了。現在一般有兩種語法分析演算法,LL自頂向下演算法和LR自底向上演算法。LL演算法還好說,到了LR演算法的時候,困難就來了。很多自學編譯原理的都是遇到LR演算法的理解成問題後就放棄了自學。其實這些東西都是只要大家理解就可以了,又不是像詞法分析那樣非得自己寫出來才算真正的會。像LR演算法的語法分析器,一般都是用工具Yacc來生成,實踐中完全沒有比較自己來實現。對於LL演算法中特殊的遞歸下降演算法,因為其實踐十分簡單,那麼就應該要求每個學生都能自己寫。當然,現在也有不少好的LL演算法的語法分析器,不過要是換在非C平台,比如Java,Delphi,你不能運用YACC工具了,那麼你就只有自己來寫語法分析器。
③ JAVA中的異常處理機制的原理
對於可能出現異常的代碼,有兩種處理辦法:
第一、在方法中用try...catch語句捕獲並處理異常,catach語句可以有多個,用來匹配多個異常。例如:
public void p(int x){
try{
...
}catch(Exception e){
...
}finally{
...
}
}
第二、對於處理不了的異常或者要轉型的異常,在方法的聲明處通過throws語句拋出異常。例如:
public void test1() throws MyException{
...
if(....){
throw new MyException();
}
}
如果每個方法都是簡單的拋出異常,那麼在方法調用方法的多層嵌套調用中,Java虛擬機會從出現異常的方法代碼塊中往回找,直到找到處理該異常的代碼塊為止。然後將異常交給相應的catch語句處理。如果Java虛擬機追溯到方法調用棧最底部main()方法時,如果仍然沒有找到處理異常的代碼塊,將按照下面的步驟處理:
第一、調用異常的對象的printStackTrace()方法,列印方法調用棧的異常信息。
第二、如果出現異常的線程為主線程,則整個程序運行終止;如果非主線程,則終止該線程,其他線程繼續運行。
通過分析思考可以看出,越早處理異常消耗的資源和時間越小,產生影響的范圍也越小。因此,不要把自己能處理的異常也拋給調用者。
還有一點,不可忽視:finally語句在任何情況下都必須執行的代碼,這樣可以保證一些在任何情況下都必須執行代碼的可靠性。比如,在資料庫查詢異常的時候,應該釋放JDBC連接等等。finally語句先於return語句執行,而不論其先後位置,也不管是否try塊出現異常。finally 語句唯一不被執行的情況是方法執行了System.exit()方法。System.exit()的作用是終止當前正在運行的 Java 虛擬機。finally語句塊中不能通過給變數賦新值來改變return的返回值,也建議不要在finally塊中使用return語句,沒有意義還容易導致錯誤。
最後還應該注意一下異常處理的語法規則:
第一、try語句不能單獨存在,可以和catch、finally組成 try...catch...finally、try...catch、try...finally三種結構,catch語句可以有一個或多個,finally語句最多一個,try、catch、finally這三個關鍵字均不能單獨使用。
第二、try、catch、finally三個代碼塊中變數的作用域分別獨立而不能相互訪問。如果要在三個塊中都可以訪問,則需要將變數定義到這些塊的外面。
第三、多個catch塊時候,Java虛擬機會匹配其中一個異常類或其子類,就執行這個catch塊,而不會再執行別的catch塊。
第四、throw語句後不允許有緊跟其他語句,因為這些沒有機會執行。
第五、如果一個方法調用了另外一個聲明拋出異常的方法,那麼這個方法要麼處理異常,要麼聲明拋出。
那怎麼判斷一個方法可能會出現異常呢?一般來說,方法聲明的時候用了throws語句,方法中有throw語句,方法調用的方法聲明有throws關鍵字。
④ java如何生成位元組碼文件
java生成位元組碼文件全過程:
Java 源碼編譯由以下三個過程組成:
1、分析和輸入到符號表
2、註解處理
3、語義分析和生成class文件
流程圖如下所示:
最後生成的class文件由以下部分組成:
結構信息。包括class文件格式版本號及各部分的數量與大小的信息
元數據。對應於Java源碼中聲明與常量的信息。包含類/繼承的超類/實現的介面的聲明信息、域與方法聲明信息和常量池
方法信息。對應Java源碼中語句和表達式對應的信息。包含位元組碼、異常處理器表、求值棧與局部變數區大小、求值棧的類型記錄、調試符號信息