Java-马士兵设计模式学习笔记-策略模式-模拟Comparable接口
一、情况
1.目标:要在专门用于排序数据的DataSorter.java中实现对所有A类,B类,C类,D类等等的排序
2.初步想法:DataSorter.java的代码如下
public class DataSorter {
	public static void sort(A a){
	}
	public static void sort(B a){
	}
	public static void sort(C c){
	}
	//...................
}
3.这样会造成DataSorter的可扩展性差,要支持对新类的排序时,要修改代码。更好的思路是:既然DataSorter是要根据不同的类的采取不同的方法实现排序,那么具体实现排序的方法交由子类去实现,且都实现同一个接口Comparable,那么DataSorter只需对Comparable排序,而无需理会具体要排序的是什么类(多态)
4.有如下几个类:
(1)DataSorter.java
(2)接口Comparable.java
(3)Student.java
(4)Teacher.java
(5)Test.java

5.代码如下:
(1)DataSorter.java
public class DataSorter {
	public static void sort(Comparable [] a) {
		int index;							//保存每次比较,最大值的下标;
		for(int i = 1; i < a.length; i++){	//控制外循环次数
			index = 0;
			for(int j = 1; j <= a.length - i ; j++){
				if(a[j].compareTo(a[index]) == 1){
					index = j;
				}
			}
			swap(a, index, a.length -i);
		}
	}
	private static void swap(Comparable[] a, int x, int y) {
		Comparable tmp = a[x];
		a[x] = a[y];
		a[y] = tmp;
	}
	//输出数组元素
	public static void show(Comparable[] a) {
		for(int i = 0; i < a.length; i++){
			System.out.println(a[i]);
		}
	}
}
(2)Comparable.java
public interface Comparable<T> {
	public int compareTo(T o);
}
(3)Teacher.java
public class Teacher implements Comparable<Teacher> {
	private int title;
	public Teacher(int title) {
		super();
		this.title = title;
	}
	public int getTitle() {
		return title;
	}
	public void setTitle(int title) {
		this.title = title;
	}
	@Override
	public int compareTo(Teacher o) {
		if(this.title > o.getTitle()){
			return 1;
		}else if(this.title == o.getTitle()){
			return 0;
		}else{
			return -1;
		}
	}
	@Override
	public String toString() {
		return "teacher--" +title+" ";
	}
}
(4)Student.java
public class Student implements Comparable<Student> {
	private int mark;
	public int getMark() {
		return mark;
	}
	public void setMark(int mark) {
		this.mark = mark;
	}
	public Student(int mark) {
		super();
		this.mark = mark;
	}
	@Override
	public String toString() {
		return "student" +mark+" ";
	}
	@Override
	public int compareTo(Student o) {
		if(this.mark > o.getMark()){
			return 1;
		}else if(this.mark == o.getMark()){
			return 0;
		}else{
			return -1;
		}
	}
}
(5)Test.java
public class Test {
	public static void main(String[] args) {
		//int [] a = {9,2,1,8,0,3};
		Student [] ss = {new Student(59),new Student(30),new Student(90)};
		DataSorter.sort(ss);
		DataSorter.show(ss);
		Teacher [] ts = {new Teacher(10),new Teacher(3),new Teacher(12)};
		DataSorter.sort(ts);
		DataSorter.show(ts);
	}
}
测试结果

Java-马士兵设计模式学习笔记-策略模式-模拟Comparable接口的更多相关文章
- Java-马士兵设计模式学习笔记-策略模式-模拟 Comparator接口
		续上一篇 <Java 模拟 Comparable接口> 一.Teacher类及Student类的比较大小方式是不固定的,比如老师除了比较职称外,还可比较工龄大小,年龄大小等.则定义Com ... 
- Java-马士兵设计模式学习笔记-工厂模式-模拟Spring读取Properties文件
		一.目标:读取properties文件,获得类名来生成对象 二.类 1.Movable.java public interface Movable { void run(); } 2.Car.java ... 
- Java-马士兵设计模式学习笔记-命令模式
		一.概述 命令模式 二.代码 1.Client.java public class Client { public void request(Server server){ server.addCom ... 
- Java-马士兵设计模式学习笔记-桥接模式
		一.概述 1.桥接模式的应用情况:(1)两个维度扩展(2)排列组合 二.代码 1.Gift.java public class Gift { protected GiftImpl giftImpl; ... 
- Java-马士兵设计模式学习笔记-工厂模式-抽象工厂模式
		一.概述 1.抽象工厂:当情况是需要产生一系列产品,若需更换产品,则要求一系列产品一起换,且要控制一系列产品的产生过程,此时可考虑抽象工厂模式.例:小明装修屋子,把电视.冰箱都替换掉,他这次需要把电视 ... 
- Java-马士兵设计模式学习笔记-工厂模式-简单工厂
		一.概述 1.目标:要控制任意类型交通工具的生产模式 2.目标有两层意思(1)任意类型 (2)生产模式,所以对应的,要这两个层面上抽象(Movable,VehicleFactory),利用接口,实现多 ... 
- Java-马士兵设计模式学习笔记-迭代器模式-模仿Collectin ArrayList LinckedList
		Java Iterator模式 Java Iterator模式, 模仿Collectin ArrayList LinckedList 一.有如下几个类 1.接口Collection.java 2.接口 ... 
- Java-马士兵设计模式学习笔记-代理模式-聚合与继承方式比较
		一.概述 1.目标:要在Tank的move()方法做时间代理及日志代理(可以设想以后还要增加很多代理处理),且代理间的顺序可活更换 2.思路: (1)聚合:代理类聚合了被代理类,且代理类及被代理类都实 ... 
- Java-马士兵设计模式学习笔记-代理模式-动态代理 调用Proxy.newProxyInstance()
		一.概述 1.目标:不自己写代理类,利用Proxy.newProxyInstance()动态生成 2.用到的知识点: (1)//编译源码,生成class,注意编译环境要换成jdk才有compiler, ... 
随机推荐
- [Luogu4177][CEOI2008]order
			luogu sol 这题有点像网络流24题里面的太空飞行计划啊. 最大收益=总收益-最小损失. 先令\(ans=\sum\)任务收益. 源点向每个任务连容量为收益的边. 每个机器向汇点连容量为购买费用 ... 
- 西瓜书概念整理(chapter 1-2)熟悉机器学习术语
			括号表示概念出现的其他页码, 如有兴趣协同整理,请到issue中认领章节 完整版见我的github:ahangchen 觉得还不错的话可以点个star ^_^ 第一章 绪论 Page2: 标记(lab ... 
- 前端跨域问题,以及ajax,jsonp,json的区别
			看了很多网上的资料,小七感觉都没有完全解决我的疑惑以及问题,所以特意拿出通俗易懂的话讲解跨域问题,以及ajax,jsonp,json的区别.首先先说跨域问题什么时候需要跨域?[1]域名不同(即网址不同 ... 
- phpstorm win/mac git配置 破解
			http://blog.csdn.net/fenglailea/article/details/53350080 phpstorm中git配置教程: http://blog.csdn.net/knig ... 
- System.Data.SQLite.dll控件常规安装方法
			原文地址:http://www.jb51.net/dll/System.Data.SQLite.dll.html 文件运行必须安装 Microsoft Visual C++ 2010 SP1 Re ... 
- 安装成功的nginx如何添加未编译模块?
			在重启nginx后发生了错误,错误如下: nginx: [emerg] the "ssl" parameter requires ngx_http_ssl_module in /u ... 
- MyBatis的高级映射之多对一
			使用传统方式的形式 使用MyBatis的方式 这样会产生两条语句 使用ResultMap的方式,对结果进行映射和转换,自己控制 两条语句变成一条语句,然后进行映射,这时Student类中包含一个 Cl ... 
- Spring MVC配置详解(2)---bai
			web.xml <?xml version="1.0" encoding="UTF-8"?> <web-app version="2 ... 
- 关于python+django操作数据库中的表
			数据库中的表示这样设计的 class C(models.Model): name = models.CharField(max_length=32) class B(models.Model): na ... 
- 关于RandomizedSearchCV 和GridSearchCV(区别:参数个数的选择方式)
			# -*- coding: utf-8 -*- """ Created on Tue Aug 09 22:38:37 2016 @author: Administrato ... 
