跳到主要內容

StringBuffer & "The Type AbstractStringBuilder is not visible"

在jdk1.5下使用StringBuffer,如果在同一行連續使用append
StringBuffer sb = new StringBuffer();
sb.append("test").append("test2");


有些IDE會出現以下compilation error訊息:
The Type AbstractStringBuilder is not visible.
但如果分開寫就沒有這個error:
<big><br />sb.append("test");<br />sb.append("test2");<br /></big>

原因有兩個
其一是,Java2SE5.0 開始有covariant return types這個新feature,意思大約是「可變回傳型態」,主要是讓子類別在覆寫(override)父類別的某個method時,回傳型態可以是父類別回傳型態的子類別。例如

<br />Parent class{<br /> Parent getObj(...){...}<br />}<br /><br />Child class extends Parent{<br /> Child getObj(...){<br />     ...<br />     return Child;<br /> }<br />


其 二是1.5之後新增了AbstractStringBuilder為StringBuffer, StringBuilder的父類別,但他卻是private類別,甚至從javadoc上也看不到此類別,你只會看到StringBuffer, StringBuilder都繼承自Object。

所以,第一種寫法,StringBuffer append()可能被IDE compiler判定回傳AbstractStringBuilder然後又呼叫其append(),導致發生找不到 AbstractStringBuilder情形,這應該是IDE可以解決的問題,我聽說eclipse好像已經解決,但是若是你用的IDE沒有解決,那 目前看到的解決方法只有改裝1.4 JDK。

Because JavaSE5.0 has supported "covariant return types" and add a new private class "AbstractStringBuilder" as a super class of StringBuilder and StringBuffer. The fist calling append() of StringBuffer object might be treated as returning AbstractStringBuilder by IDE's compiler, so the second calling append() of AbstractStringBuilder cause the compiler error.


留言

這個網誌中的熱門文章

iframe DOM 被移動造成重新載入

如果用 javascript 去搬動 iframe DOM 的位置, 瀏覽器會將其內容重新載入,這是現有 HTML 規格 > When an iframe element is inserted into a document that has a browsing context, the user agent must create a nested browsing context, and then process the iframe attributes for the "first time". 範例: http://jsfiddle.net/pZ23B/ 測試結果: * Safari 3.1 / Win: reload * Opera 9.5 / Win: reload * IE10: reload * IE7 / IE8: not reload (部份摘自 https://bugzilla.mozilla.org/show_bug.cgi?id=254144 ) 參考: * https://bugzilla.mozilla.org/show_bug.cgi?id=254144

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();

Web Dynpro 前後端資料流動機制 (Dataflow)

在Web Dynpro中提供3種資料流機制[1],只要適當地設定,可以不用寫程式就將畫面、中間層控制器(controller)到後端模型物件的資料自動化地、牢靠地綁在一起,使得不管前後端某一方有資料變動,變動部份都會自動地流動來保持一致性,使得前後端都能存取到同一份資料。 context 關鍵元件是 context,每個controller都有一份屬於自己的context,它扮演MVC架構中的M (model),web dynpro的實做方式比較像是該controller的「資料空間」,它由node(資料節點)與attribute(資料屬性)組成,controller可以透過wdContext這個預先產生好的 shortcut variable(捷徑變數)去取得context的資料內容。 context中必須要建立node才可以儲存資料,一個node代表一個collection(集合物件)裡面仍可以含有node, attribute,node裡面的一份資料實體就是一個element,一個node可以有一個或多個element(這部份可以透過cardinality property設定),其結構就是該node所包含的結構。 data binding 此種機制可以將UI元件的資料跟context中的某個node或attribute綁定在一起,context中的改變會自動 更新到UI元件上,UI元件的改變也會自動寫入到綁定的context node(or attribute)中。通常UI元件所綁定的node(attribute)是由component controller對應過來的。 context mapping 每一個controller都有屬於自己的context(資料空間)如果要達到彼此共享資料,則要透過context mapping機制,一旦mapping設定好,則會在另一個context產生一個同樣的結構的node,兩邊的controller會存取到的是同一分資料,任何一邊的資料更動都會散佈到設定好mapping的node。 不過在web dynpro裡,只允許將custom controller or component controller的node對應到view controller去,不允許從view controller對應回來,主因是嚴格遵守MVC...