我有一个练习要解决,但我无法理解它。所以问题是:下面的程序按升序打印一系列字符串。观察 sort 仅对字符串数组进行排序。重写它,以便对 T 类型的对象进行排序,其中 T 在排序头中作为泛型类型名称引入,而 T 实现 Comparable。更改应仅限于修改排序的标题和正文。所以我给出的代码是:
class SortNames {
static void sort(String[] s) {
for (int i = 0; i<s.length; i++) {
for (int j = i+1; j < s.length; j++) {
if (s[i].compareTo(s[j])>0) {
String t;
t = s[i]; s[i] = s[j]; s[j] = t;
}
}
}
}
public static void main(String[] args) {
String[] names = {"Pete","Jill","May","Anne","Tim"};
sort(names);
for (String s:names){
System.out.println(s);
}
}
所以我所做的是:
class TestSort{
static void sort(T[] s) {
for (int i = 0; i<s.length; i++) {
for (int j = i+1; j < s.length; j++) {
if (s[i].compareTo(s[j])>0) {
Object t;
t = s[i]; s[i] = s[j]; s[j] = t;
}
}
}
}
public static void main(String[] args) {
int[] numbers = {3,6,2,7,9,1,8};
sort(numbers);
for (int a:numbers){
System.out.println(a);
}
}
现在当我编译我的代码时,我得到:
TestSort.java:3: error: cannot find symbol
static void sort(T[] s) {
^
symbol: class T
location: class TestSort
1 error
怎么了?:( 谁能推荐我一些好的阅读资源?我明天有考试 :( 提前谢谢!