文档详情

Java简明教程第三四版课件-上课版5选编.ppt

发布:2017-04-15约6.63千字共38页下载文档
文本预览下载声明
第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 接
显示全部
相似文档