代码如下:
public class test
{
public static void main(String args[])
{
goods f=new fruit();
f.run();
goods d=new drink();
d.run();
}
}
class goods
{
void run()
{
getgoods();
pay();
}
void getgoods()
{
System.out.println("get");
}
void pay()
{
System.out.println("pay");
}
}
class fruit extends goods
{
void getgoods()
{
System.out.println("fruit");
}
}
class drink extends goods
{
void getgoods()
{
System.out.println("drink");
}
}
结果如图:
这样我们就可以避免在子类中涉及具体的算法,只需要将重复的内容已经算法提取到父类即可,降低了耦合。
至此,我们还可以加入一个钩子的机制,即可相应的对一些不需要的算法来进行控制。
代码如下
public class test
{
public static void main(String args[])
{
goods f=new fruit();
f.run();
goods d=new drink();
d.run();
}
}
class goods
{
void run()
{
if(hasGetGoods())
getgoods();
pay();
}
void getgoods()
{
System.out.println("get");
}
boolean hasGetGoods()
{
return false;
}
void pay()
{
System.out.println("pay");
}
}
class fruit extends goods
{
boolean hasGetGoods()
{
return true;
}
void getgoods()
{
System.out.println("fruit");
}
}
class drink extends goods
{
boolean hasGetGoods()
{
return false;
}
void getgoods()
{
System.out.println("drink");
}
}
结果:
联系我:renhanlinbsl@163.com
2016-8-3
21:25