友情提示:如果本网页打开太慢或显示不完整,请尝试鼠标右键“刷新”本网页!
Java编程思想第4版[中文版](PDF格式)-第59部分
快捷操作: 按键盘上方向键 ← 或 → 可快速上下翻页 按键盘上的 Enter 键可回到本书目录页 按键盘上方向键 ↑ 可回到本页顶部! 如果本书没有阅读完,想下次继续接着阅读,可使用上方 "收藏到我的浏览器" 功能 和 "加入书签" 功能!
boolean lessThan(Object lhs; Object rhs);
boolean lessThanOrEqual(Object lhs; Object rhs);
} ///:~
对这两种方法来说,lhs代表本次比较中的“左手”对象,而 rhs 代表“右手”对象。
可创建Vector 的一个子类,通过 pare 实现“快速排序”。对于这种算法,包括它的速度以及原理等等,
在此不具体说明。欲知详情,可参考Binstock 和 Rex 编著的《Practical Algorithms for Programmers》,
由Addison…Wesley 于 1995 年出版。
//: SortVector。java
// A generic sorting vector
package c08;
import java。util。*;
public class SortVector extends Vector {
private pare pare; // To hold the callback
public SortVector(pare p) {
pare = p;
}
public void sort() {
quickSort(0; size() 1);
}
private void quickSort(int left; int right) {
if(right 》 left) {
Object o1 = elementAt(right);
int i = left 1;
int j = right;
while(true) {
while(pare。lessThan(
elementAt(++i); o1))
;
while(j 》 0)
if(pare。lessThanOrEqual(
elementAt(……j); o1))
229
…………………………………………………………Page 231……………………………………………………………
break; // out of while
if(i 》= j) break;
swap(i; j);
}
swap(i ; right);
quickSort(left; i…1);
quickSort(i+1; right);
}
}
private void swap(int loc1; int loc2) {
Object tmp = elementAt(loc1);
setElementAt(elementAt(loc2); loc1);
setElementAt(tmp; loc2);
}
} ///:~
现在,大家可以明白“回调”一词的来历,这是由于quickSort()方法“往回调用”了pare 中的方法。
从中亦可理解这种技术如何生成通用的、可重复利用(再生)的代码。
为使用 SortVector,必须创建一个类,令其为我们准备排序的对象实现pare。此时内部类并不显得特别
重要,但对于代码的组织却是有益的。下面是针对 String 对象的一个例子:
//: StringSortTest。java
// Testing the generic sorting Vector
package c08;
import java。util。*;
public class StringSortTest {
static class Stringpare implements pare {
public boolean lessThan(Object l; Object r) {
return ((String)l)。toLowerCase()。pareTo(
((String)r)。toLowerCase()) 《 0;
}
public boolean
lessThanOrEqual(Object l; Object r) {
return ((String)l)。toLowerCase()。pareTo(
((String)r)。toLowerCase())
快捷操作: 按键盘上方向键 ← 或 → 可快速上下翻页 按键盘上的 Enter 键可回到本书目录页 按键盘上方向键 ↑ 可回到本页顶部!
温馨提示: 温看小说的同时发表评论,说出自己的看法和其它小伙伴们分享也不错哦!发表书评还可以获得积分和经验奖励,认真写原创书评 被采纳为精评可以获得大量金币、积分和经验奖励哦!