Java简明教程第三四版课件-上课版5选编.ppt
文本预览下载声明
第5章 接口和包 ;5.1 接口 ;5.1.1 接口的定义和应用 ;5.1.1 接口的定义和应用(续);5.1.1 接口的定义和应用(续);// 程序5-1
interface Sortable{ // 定义一个接口
int Compare(Sortable s);
}?;class Sort{ // 定义一个排序类,仅有一个静态的方法
public static void SelectSort(Sortable a[ ]){
int i, j, k;
Sortable temp;
for(i=0;ia.length-1;i++){ // 选择排序
k=i;
for(j=i+1;ja.length;j++)
if(a[k].Compare(a[j])0) k=j;
temp=a[i]; a[i]=a[k]; a[k]=temp;
}
}
} ;class Student implements Sortable{ // 定义一个学生类
private int score;
Student(int x){ score=x; }
// 实现接口Sortable中的方法
public int Compare(Sortable s){
Student st=(Student)s; // 类型强制转换
return score-st.score;
}
public String toString( ){ return score=+score; }
} ;class Rectangle implements Sortable{ // 矩形类也实现了接口
private int length,width;
Rectangle(int x,int y){ length=x; width=y; }
int area( ){return length*width;}
public int Compare(Sortable s){ // 实现接口
Rectangle rec=(Rectangle)s; // 类型强制转换
return area( )-rec.area( );
}
public String toString( ){ return area=+area( ); }
} ;public class interfaceTest {
public static void main(String args[ ]) {
Student stud[ ]=new Student[20];
int i;?
for( i=0;istud.length;i++)
stud[i]=new Student(
(int)(Math.random( )*100));
Sort.SelectSort(stud); // 排序
for( i=0;istud.length;i++)
System.out.println(stud[i].toString( )); ; Rectangle R[ ]=new Rectangle[10];
for( i=0;iR.length;i++) R[i]=new Rectangle(
(int)(Math.random( )*10),
(int)(Math.random( )*10));
Sort.SelectSort( R ); // 排序
for( i=0;iR.length;i++)
System.out.println(R[i].toString( ));
}
} ;5.1.1 接口的定义和应用(续);5.1.1 接口的定义和应用(续);interface inter { // 接口
void methodA( );
}?
abstract class Derived1 implements inter {
// 此处不需要写出methodA( )的原型
}
?
class Derived2 extends Derived1{
public void methodA( ) { // 实现方法
System.out.println(Hi,methodA);
}
} ;5.1.2 接口和抽象类的异同点 ;5.1.2 接
显示全部