java 编程 求数组的无序排列次数
2014-02-23 13:59
183 查看
在Java中,使用抽象类来实现接口,并不是毫无作用。相反,有时间有很大的作用。
当你只想实现接口中的个别方法(不是所有方法)时,你可以先写一个抽象类来实现该接口,并实现除了你想要的方法之外的所有方法(方法体为空)。接着再用你的类继承这个抽象类,这个类中就只用实现你需要的方法了,这样就可以达到你的需要了。但是,如果你直接实现接口的话,你就需要实现接口的所有方法。
通过下面例子,可以很好的理解:
例:有一个接口Window,有三个方法,draw(),putColor(),setPosition()三个方法,程序员在设计页面时只关注对其进行位置定位(画图draw()和着色putColor()则由美工实现),所以他只需要实现setPosition()方法,而其余两个不用实现。则设计如下:
//接口
interface Window{
public void draw();
public void putColor();
public void setPosition();
}
/**
*抽象类,不实现需要的方法。而实现的不需要的方法的方法体设为空,
*/
abstract class DesignedPage implements Window{
public void draw(){}
public void putColor(){}
}
/**
* 具体实现类,实现特定的方法,该类中只有需要的方法
*/
public class DesingedPageA extends DesignedPage{
public void setPosition(){
//set the window position
}
}
通常情况下,如果我们需要在具体实现类中实现draw()方法时,都是调用父类的draw()方法(super.draw())。
当你只想实现接口中的个别方法(不是所有方法)时,你可以先写一个抽象类来实现该接口,并实现除了你想要的方法之外的所有方法(方法体为空)。接着再用你的类继承这个抽象类,这个类中就只用实现你需要的方法了,这样就可以达到你的需要了。但是,如果你直接实现接口的话,你就需要实现接口的所有方法。
通过下面例子,可以很好的理解:
例:有一个接口Window,有三个方法,draw(),putColor(),setPosition()三个方法,程序员在设计页面时只关注对其进行位置定位(画图draw()和着色putColor()则由美工实现),所以他只需要实现setPosition()方法,而其余两个不用实现。则设计如下:
//接口
interface Window{
public void draw();
public void putColor();
public void setPosition();
}
/**
*抽象类,不实现需要的方法。而实现的不需要的方法的方法体设为空,
*/
abstract class DesignedPage implements Window{
public void draw(){}
public void putColor(){}
}
/**
* 具体实现类,实现特定的方法,该类中只有需要的方法
*/
public class DesingedPageA extends DesignedPage{
public void setPosition(){
//set the window position
}
}
通常情况下,如果我们需要在具体实现类中实现draw()方法时,都是调用父类的draw()方法(super.draw())。
相关文章推荐
- 编程:用java 语言实现,输入一个数,就相应地输出的几维数组!||用1、2、2、3、4、5这六个数字,用java写一个函数,打印出所有不同的排列,要求:"4"不能在第三位,"3"与"5"不能相连
- 第2章 Java编程基础——FAQ2.26 如何实现数组的复制?
- 数组中出现次数超过一半的数字 -java
- java 找出n个元素数组中重复次数最多的数(假设出现次数大于n/2)
- JAVA里实现一个数组全排列的方法
- 两个数组[n] [m] n>m 第一个数组的数字无序排列 第二个数组为空 取出第一个数组的最小值 放到第二个数组中第一个位置, 依次类推. 不能改变A数组,不能对之进行排序,也不可以倒到别的数组中。
- JAVA 多个数组之间的排列组合
- 剑指Offer:面试题29——数组中出现次数超过一半的数字(java实现)
- 剑指Offer(Java版):数字在排序数组中出现的次数
- 编程练习——求无序数组第k小的数
- Java笔记1 Java编程基础<2>循环语句、函数(重载)、变量和数组的内存结构
- JAVA: 数组中出现次数超过一半的数字
- 【小程序】JAVA实现从10~50中随机生成50个数,统计出现的数字及次数,输出出现最多的次数及对应的数字,按数字升序排列。
- java 实现从无序数组中 找出第k大的数, 无序数组充许有重复元素
- 《Java 编程技巧1001条》 第382+283条: 了解数组的长度和引用
- 《Java 编程技巧1001条》 第389条: 了解不平衡数组
- 《Java 编程技巧1001条》 第400条: 使用数组复制
- 算法 - 有两个相同大小数组均已按升序排列好,编程计算这两个数组的中位数(C++)
- java编程思想--数组
- 五十道编程小题目 --- 11 排列与组合(阶乘) java