1. 程式人生 > >測者的測試技術筆記:揭開java method的一個祕密--巨型函式

測者的測試技術筆記:揭開java method的一個祕密--巨型函式

相信,很多人都不知道Java的Method的上限為64K。本文將超過這個上限的函式叫做巨型函式。

巨型函式的問題

1、如果程式碼超過了這個限制,Java編譯器就報"Code too large to complier"的錯誤。 2、程式碼並沒有超過64K的限制,但是在執行時由於其他工具或者library使得對應的程式碼超過了64K的限制,那麼Java會給我們一個java.lang.VerifyError的錯誤。

巨型函式是怎麼來的

如下一些僅僅是一些可能導致出現巨型函式的常見情況,還有很多其他情況就不一一列舉了。

一些工具生成的程式碼

很多大函式並不是人手動寫出來的,是一些程式碼生成工具生成的,例如ANTLR(ANother Tool for language Recognition)就有可能生成巨大的Method。

初始化函式

Initialization方法就很容易變成巨型函式,尤其是一些GUI的初始化函式,很容易在一個程式碼段中塞進去很多對應的GUI的佈局定義程式碼和attaching listener程式碼,導致巨型函式的產生。

陣列初始化

測者在工作中也遇見過static final 陣列編譯器使用load或者sotre的指令初始化陣列。這有時候也會導致出現巨型函式。

很長的JSP頁面

很多JSP的編譯器也會將所有的JSP程式碼編譯到一個函式中,導致巨型函式的出現。

如何解決巨型函式的問題

最好也是最根本的解決巨型函式的方法就是拆分。無論是程式碼生成工具還是JSP都允許我們進行程式碼的拆分。但是其他一些例如呼叫第三方工具或者library導致的這個問題,很多時候就不能通過粗暴的程式碼拆分解決問題了,需要重新設計,優化演算法等方式避免巨型函式的出現。也有很多時候我們沒有辦法避免巨型函式的64K限制,我們最終的根本方法還是寄希望於Java自身接觸64K的限制。