用頓號將若干個字符串分隔開































posted on 2007-02-27 08:20 我為J狂 閱讀(2736) 評論(15) 編輯 收藏 所屬分類: Java算法
posted on 2007-02-27 08:20 我為J狂 閱讀(2736) 評論(15) 編輯 收藏 所屬分類: Java算法
if ( ! word.equals( "" ))
最好改為!"".equals(word)
因為如果word在前的話很容易引起nullPoint異常 回復 更多評論
真是金玉良言,我會在以后的開發過程中加以改進的。 回復 更多評論
其實要認省點代碼。這樣就不用比較NULL了。
for ( int i = 0 ;i < words.length-1;i ++ ) 回復 更多評論
“永恒之光”的方法真妙!以上的程序改為:
String[] words = { " a " , " b " , " c " } ;
String word = "" ;
int i=0;
for ( i = 0 ;i < words.length-1;i ++ )
{
word+=words[i]+" 、 ";
}
word +=words[i];
不但節省了代碼,而且不用比較NULL了。
對于 Lingo提出的問題“別在循環里用+號”,我不知道其中的原因,請Lingo解釋一下,謝謝。 回復 更多評論
不用+ 的話,就不要用String了,只好用StringBuffer咯
回復 更多評論
是不是將程序改成這樣?
String[] words = { " a " , " b " , " c " } ;
StringBuffer word =new StringBuffer("");
int i=0;
for ( i = 0 ;i < words.length-1;i ++ )
{
word=word.append(new StringBuffer(words[i]).append(" 、 "));
}
word=word.append(words[i]);
如果這樣寫,代碼的可讀性降低,很不好理解。
我想Lingo提出“別在循環里用+號”另有涵義。 回復 更多評論
String[] words = { " a ", " b ", " c " };
StringBuffer word = new StringBuffer("");
int i = 0;
for (i = 0; i < words.length - 1; i++) {
word.append(words[i]).append("、");
}
word.append(words[i]);
這樣不可以嗎?? 回復 更多評論
@我為J狂
Equals的時候盡量用"內容"開頭,這樣不用判斷空
正如Lingo說的不要在循環中使用字符串的+,因為字符串是非可變的對象,使用+基本上等于new StringBuffer() apend() apend() toString。比直接使用StringBuffer多了一次new,如果寫在循環中會很大程度降低效率。
如果是Jdk1.5可以在StringBuilder和StringBuffer之間選擇一下,原因可以看看這里http://www.aygfsteel.com/dreamstone/archive/2006/10/17/75608.html 回復 更多評論
@我為J狂
int i = 0;
for (i = 0; i < words.length - 1; i++) {
word.append(words[i]).append("、");
}
這種寫法不太好,呵呵。因為容易犯復制粘鐵錯誤,如出現
等同于for 循環的迭代好于while循環
這樣比較好點。
for (int i = 0; i < words.length - 1; i++) {
word.append(words[i]).append("、");
}
回復 更多評論
另外關于分割的情況,如果使用、分割有的時候會有些限制,比如用戶恰好輸入了、,這個時候需要轉義,是挺麻煩的事情,有個解決方案是這樣,可以使用用戶不可能輸入的字符來分割,例如(char)1 看上去就是個亂碼,呵呵
你的表真有意思,剛才正好23:00,一頓響,嚇了我一跳一以為中病毒了。 回復 更多評論
@dreamstone
寫成您說的那樣更改:
for (int i = 0; i < words.length - 1; i++) {
word.append(words[i]).append("、");
}
那么我最后一行的代碼:word.append(words[i]);
其中的變量i就沒有定義了,顯然是不行的。
對于您提出的粘貼錯誤問題我能理解;我舉例說明一下,
//代碼1
for(Iterator it=list.iterator();it.hasNext();)
{
}
//代碼2
Iterator it=list.iterator();
while(it.hasNext())
{
}
對于以上兩段代碼,代碼1發生粘貼錯誤的幾率要遠遠小于代碼2。 回復 更多評論
那就這么寫吧
for (int i = 0; i < words.length; i++) {
if(i != 0){
world.append("、");
}
word.append(words[i]);
}
回復 更多評論
只有注冊用戶登錄后才能發表評論。 | ||
![]() |
||
網站導航:
博客園
IT新聞
Chat2DB
C++博客
博問
管理
|
||
相關文章:
|
||