精華區beta java 關於我們 聯絡資訊
※ 引述《godfat (godfat 真常)》之銘言: : 不知道是廣義 namespace, 還是狹義的 C++ namespace? XD : 前者我不敢下定義,但後者的話我可以舉例 XD 我借用你的例子來講一下, 保證是錯的 (啥!) 我不是啥 SCJP 咩, 用錯誤的概念硬幹出能用的東西是常有的事 : 其實是很單純的觀念啦,我覺得你應該知道是什麼意思才對 : 可能是被太多名詞混淆了…? : 在 C++ 中,所有標準提供的東西都放在 namespace std 下 在 java 中,所有標準提供的東西都放在 rt.jar 的 java 下 : namespace std{ : /* blah blah blah */ : } java\ applet\ awt\ .... /* blah blah blah */ .... : 假設現在裡面有一個 max function 假設現在裡面有一個 max function (好吧, 我真的去找個 max 出來) : namespace std{ : int max(int, int); : } java\ .... /* blah blah blah */ lang\ \Math.class max(int, int) .... /* blah blah blah */ : 那麼你在全域空間(global)中這樣用: : max(5, 10); : 是沒有效果的,因為看不到,compiler 會跟你抱怨 max 是啥? 那麼你在 Java 程式中這樣寫: max(5 ,10); 是沒有效果的,因為看不到,compiler 會跟你抱怨 max 是啥? (The method max(int, int) is undefined for the type) : 正確的用法是: : std::max(5, 10); : 或是 : ::std::max(5, 10); 正確的用法是: java.lang.Math.max(5, 10); 或是 Math.max(1,2) : 前者表示在「現在」這個 namespace 中找到下一層的 std namespace, : 並在其中尋找 max 在哪裡? 前者表示在 \java\lang\ 中找到下一層的 Math.class 並在其中尋找 max 在哪裡? : 後者則是在「global namespace」中尋找 std namespace, : 並在其中尋找 max 在哪裡? 後者則是在 "預設的路徑中找 Math.class, 並在其中尋找 max 在哪裡? : 如果你現在在 global namespace 中建立另外一個 max : void max(double, double); : 假設你現在在 global namespace 中這樣寫: : max(5, 10); : 那麼 compiler 會認定你使用的是 void max(double, double); 如果你現在在程式中建立另外一個 max void max(double, double); 假設你現在在程式中這樣寫: max(5, 10); 那麼 compiler 會認定你使用的是 void max(double, double); : std::max(5, 10); : 則會認定為 std namespace 下的 void max(int, int); Math.max(5, 10); 則會認定為 Math.class 裡的 public static int max(int a, int b); http://java.sun.com/j2se/1.5.0/docs/api/java/lang/Math.html#max(int, int) : 大概就是這樣了…… : 簡單地說,也有點像 file system 的樹狀結構啦 XD 大概就是這樣了…… 簡單地說,也有點像 file system 的樹狀結構啦 XD : 嗯,但是在 C++ 中的話故事還沒有結束 XDD 嗯,但是在 Java 中的話故事就結束了 (大概吧?) : 如果前面再這樣寫: : using namespace std; // 匯入整個 std : 或是 : using std::max; // 匯入 std::max 如果在前面再這樣寫: import java.lang.*; 或是 import java.lang.Math; : 則 : max(5, 10); : 會叫到誰? 則 max(5, 10); 還是抓自建的 max (double, double) 你不打 Math.max 就不認識. : 嗯,我想到一個問題了,雖然這自己測試看看就知道了, : 不過板大說不用客氣是吧…? XD : package test; : 假設放在 ~/fat1/test 下 : package test; : 假設放在 ~/fat2/test 下 : 那麼我執行某個程式,把 ~/fat1 和 ~/fat2 都加入 classpath 下 : 是否會造成衝突?如果是的話,那確實這就是 Java platform 了 @_@ 不會... 依照載入順序. : 所以上面有一篇會說 : String config = Config.getPath(); : import config; : 如此動態決議載入的路徑。 import 的 path 也動態? 這什麼? @_@a -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 163.25.148.49 > -------------------------------------------------------------------------- < 作者: wctang (wctang) 站內: java 標題: Re: [站內] Java 跟 C++ 搞曖昧? Namespace 有用嘛? 時間: Sun Mar 12 20:34:27 2006 ※ 引述《godfat (godfat 真常)》之銘言: : ※ 引述《ogamenewbie (荷蘭爛銀行)》之銘言: : : 我借用你的例子來講一下, 保證是錯的 (啥!) : : 我不是啥 SCJP 咩, 用錯誤的概念硬幹出能用的東西是常有的事 : = =b : 無言以對 XD : : 不會... 依照載入順序. : 這樣問題更大吧? = =b : 連是否不小心重複了都不知道 : : import 的 path 也動態? 這什麼? @_@a : 只是覺得這樣做比較合理而已 : 我不知道實作上是否會有什麼問題, : 只是單純從使用者的角度來看,覺得現在這樣沒有對稱性 : 如果路徑寫死,執行期卻還能搬動位置,這樣有時候會不小心出意外 : 既然執行期才去存取 .class 檔,何不連路徑都動態存取? : String path = UserInput.getString(); : // could be godfat.Widget or : // fatgod.Widget : import path; : Widget keyboard = new Widget(); : 這樣可以動態改變類別庫 之前好像也有談過類似的問題@@ 以我的想法來看,首先就是不要把 package 看成是目錄,雖然他們看起來很像。應該把 package 和 class name 合起來當成是一個 class 完整名稱, import 只是讓你少打些 字的。 你了解 load class 是執行期動態進行的,但要 load 哪一個 class (package+classname) 是編譯期就決定的,執行期 load class 是依 class path 先後 順序來 load (簡化的說法),所以不會有名稱衝突的問題, classpath 在前面的有優先 權。 至於你想要動態改變 load 到的 class ,以你程式的寫法是不行的,也就是 compile 時 就決定你要 load 的 class 的全名,不可以等到執行期決定是 xxx.Aaa 還是 yyy.Aaa 。但 Java 的動態性表現在另一個地方,你可以在執行期改變你的 classpath ,有點類 似你下了不同的 -classpath 參數,但是是在執行期可以改變的。不過一般程式是用 不到這種功能的,有興趣應該去研究 ClassLoader 相關議題。 BTW, 如果想的話,用 ClassLoader 是可以做到從任何地方去 load class ,例如不照 目錄來放,或是從 database 中去 load class ,都是做得到的。這也是我建議不要把 package 想成是目錄的原因。 -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 61.62.106.24