跳到主要內容

JDK CLASSPATH 設定

JDK CLASSPATH 設定 (configure)

Class Path,JRE會依照此路徑的設定去尋找對應的class檔與相關資源(程式要讀取的檔案等)。使用JDK的程式(java.exe or javac.exe),可以不設定classpath,原始會有一個預設值(default class path),就是執行java時的該目錄。
舉例來說,若是要在C:\myproject\下執行Hello.class
java Hello
若Hello有用到C:\myproject\下的其他.class檔都可以被搜尋到,不用另外指定。但是若class包在jar檔則無法被引入。
若找不到執行所需要的class會產生如下錯誤:
Exception in thread "main" java.lang.NoClassDefFoundError:packagename/classname

若用到的class檔較多、不在同一目錄下或包在jar中,則需要設定CLASSPATH。
有三種方式,不管用哪種方式,一旦設定classpath,JRE就不會再參考預設的classpath設定,會完全按照你設定來找尋class,如果設定不對就會出現前面所述的java.lang.NoClassDefFoundError
一是直接設定在windows系統的環境變數中,一開機就設定好比較方便,如果有修改則需要重開機新的設定才會生效。不管哪個版本大致上是從控制臺>系統>進階>環境變數。
可在命令列模式下輸入:
echo %classpath%
系統會顯示目前的classpath設定值
增加一個環境變數為classpath,值可能是:
.;C:\Program Files\Shared\dc.jar;C:\Program Files\Java\jdk1.5.0_15\lib;%JAVA_HOME%\lib\tools.jar
分號分隔的各是一個路徑值,請注意第一個值是一個點".",這個代表執行該class當前的目錄,也就是前述的預設值,但因我們現在已經用系統的環境變數去覆蓋預設值,因此必須要設定當前目錄,這是最常見的錯誤,否則會連一個class都執行不起來。

另外兩種就是JDK手冊上提到的方法:
用set指令去設定,好處是不用重開機就可以生效,但是值不會被存下來,也就是重開機之後就會恢復成系統設定值,而且會覆蓋前述的環境參數值。
C:> set CLASSPATH=classpath1;classpath2...


另一種則是在執行時在指定。
C:> sdkTool -classpath classpath1;classpath2...
sdkTool代表的可能是java, javac等執行檔。

以上兩個方法,如果只是要增加一兩個路徑,可以用
set CLASSPATH= %CLASSPATH%;d:\workspace
java -classpath %CLASSPATH%;d:\workspace
可在保留原系統設定路徑的條件下增加路徑而,%CLASSPATH%代表原有的classpath環境參數值。

相關連結:
http://java.sun.com/j2se/1.5.0/docs/tooldocs/windows/classpath.html
張貼留言

這個網誌中的熱門文章

JavaScript 關掉瀏覽器頁面

如果你直接呼叫 window.close() 來關掉目前的頁面的話,你應該會在 console 看到以下訊息:
Scripts may close only the windows that were opened by it.
( 我在 Chrome, Firefox, IE 11 都試過)
主因就是你並沒有用 JavaScript 開啟這個頁面,所以也不能用 JavaScript 關掉它。這是 HTML window.close() 的規格規定,各家瀏覽器應該都遵循。

隨著瀏覽器安全性增加,以下方法已經不適用了,可參考這個討論


有個變通的辦法就是:
window.open(location, '_self').close();


ZK 教學 - 使用 MVC 或 MVVM?

不管是現在剛開始接觸 ZK 或是用過一陣子的人都可能會遇到的問題是到底要用 MVC 或 MVVM 的方式開發。從 ZK 8 之後又把 MVVM 的能力更佳的擴展,所以 MVVM 會是一個功能更強的開發方式。但 MVC 在使用上比較直覺,仍有其優勢,所以我想決定性的因素會比較是開發者的偏好專案的特性。你可參考下面的比較來決定哪種方式比較適合你。優勢比較MVVMViewModel 較不易受畫面變動影響。
因為 ViewModel 沒有變數直接指向 ZK 元件,因此若是畫面上有元件更改,ViewModel 一般不需要修改ViewModel 較易於在不同頁面中重用。
因為 ViewModel 只包含資料跟業務邏輯,若是不同頁面需要的資料跟業務邏輯相同,就可以重用同一個 ViewModel例如 A 頁面按按鈕執行搜尋,B 頁面點選單執行同樣的搜尋,則可以重用同一個 ViewModel 中的 command,只是兩個頁面 data binding 寫在不同的元件上。畫面較易於重用(易於模組化)。
透過 shadow component 跟 template 機制,可以將一段頁面的片段做成可以接受傳入參數套用 Responsive Design 的成本較低。
通常需要針對不同裝置設計不同版面,但是顯示的資料內容大同小異,因此 ViewModel 多半可以重用易於套用美工所設計的畫面,或是網路上現成的元件。易於整合第三方 javascript library 或 widget。
因為 ZK 8 提供了一個可以讓你透過 javascript 去呼叫 ViewModel 中的 command (client side binding) 的方式來跟後端溝通ViewModel 的可測試性較好。
因為 ViewModel 不需要繼承特定類別跟實作特定介面,可以輕易地執行單元測試MVC操控元件方式直覺好學、易懂。
MVVM 控制元件較不直接,需要了解 zk framework data binding 的行為可以完全使用元件所提供的所有 API。
仍有極少部分 ZK 元件行為沒辦法用 MVVM 控制。例如產生 Messagebox, Listbox.renderAll(), Popup.open()。但這都可以改用直接控制元件的方式來解決,只是就是非 MVVM 的方法,喜歡維持一致的開發模…

ZK 教學中文書 - ZK 教練

2016年開始做了不少場教育訓練,覺得台灣工程師應該會蠻希望有一本中文的教材,因為目前網路上多是零散的文章,英文的文件雖然完整,但是太龐大,大部分的人應該無從下手。因此最近開始撰寫一本教學書:「ZK 教練」(書名是老婆提供的點子),也為自己在這份工作推出一個代表作。
本書會包含以下幾個特點,幫助讀者更有效地學習:
範例專案
本書附帶一個範例專案,裡面包含所有書中提到的範例程式。你可以輕易地將整個專案執行在 jetty 上,透過瀏覽器看到執行結果,有助於了解程式碼。練習專案
執行 maven 指令可以產生一個練習專案,它以範例專案為基礎,但是刻意移除部分程式碼,好讓讀者練習之用。因此你可以產生範例專案來練習,若真的遇到困難再參考完整程式。圖片解說
儘量以各式圖片解說概念。我認同 Head First Design Pattern 一書中提及的理念,學習不是只能靠文字,其他的媒介可以讓大腦得到更多資訊,更增強學習效果。情境 FAQ
ZK 目前已經是個頗為成熟的框架,功能很多,因此不熟悉的人常常不知道實務上某個情境要用什麼功能來解決,這裡會列出各個常用的情境並提供連結指向建議使用的 ZK 特性 當然目前本書尚未完成,歡迎給予回饋。
去看看 ZK 教練