`
wdt1988520
  • 浏览: 15521 次
社区版块
存档分类
最新评论

策略模式Strategy

 
阅读更多

策略模式和状态模式比较类似。

状态模式是以状态驱动行为的模式,而策略模式则以算法驱动行为的模式,某个类存在着不同的状态且不同状态类的行为不同,则选择状态模式,如某个类的行为有几种不同的实现方式,则选择策略模式。

GOF定义:定义一族算法,将每个算法分别封装起来,并且相互之间可以替换。策略模式可以使不同算法之间的替换独立于使用算法的客户。策略模式是非常常用的模式。

 

角色分析:

Context(环境类)

  环境类是使用算法的角色,它用于解决问题时决定采用不同的策略,在环境类中维护一个抽象策略的引用。

AbstractStrategy(抽象策略类)

 用于定义算法的抽象,它是所有策略的父类,及对外提供的算法接口。

ConcreteStrategy(具体策略实现类)

 具体算法策略的实现。

 

 

例:排序算法

 

 

 

 

 

//环境角色
package context;

import abstract_algorich.AbstractSort;

/**
 *create by datao.wang 2014-2-7-下午2:44:11	
 */
public class SortContext {
	   public AbstractSort sort;
	   
	   public int[] sort(int[] array){
		   return sort.sort(array);
	   }
	
	   public void setSort(AbstractSort sort) {
		   this.sort = sort;
	   }
	   
   
}

 

//抽象策略
package abstract_algorich;


/**
 *create by datao.wang 2014-2-7-下午2:41:43	
 */
public interface AbstractSort {
 
	 public abstract int[] sort(int[] array);
}

 

//具体策略实现
package concrete_algorich;

import abstract_algorich.AbstractSort;

/**
 *create by datao.wang 2014-2-7-下午4:53:54	
 * 冒泡排序
 * 原理:不断重复进行元素的比较
 * 对于元素较多的数据不适用
 */
public class BubbleSort implements AbstractSort {

	@Override
	public int[] sort(int[] array) {
        for(int i=0;i<array.length;i++){
        	for(int j=i+1;j<array.length;j++){
        		int tmp;
        		if(array[i]>array[j]){
        			tmp=array[i];
        			array[i]=array[j];
        			array[j]=tmp;
        		}
        	}
        }
		return array;
	}

}

package concrete_algorich;

import abstract_algorich.AbstractSort;

/**
 *create by datao.wang 2014-2-7-下午4:04:29	
 *插入排序
 *原理:
 *  1、前两个元素,先第一个元素与第二元素比较,如果第一个元素大于第二元素则交换位置
 *  2、前三个元素进行排序
 *  3、前四个元素进行排序
 *  4、以此类推,一直到最后一个元素
 */
public class InsertionSort implements AbstractSort {

	@Override
	public int[] sort(int[] array) {
        int len=array.length;
        for(int i=1;i<len;i++){
        	int j;
        	int temp=array[i];
        	for(j=i;j>0;j--){
        		if(array[j-1]>temp){
        			array[j]=array[j-1];
        		}else{
        			break;
        		}
        	}
        	array[j]=temp;
        }
		return array;
	}

}

package concrete_algorich;

import abstract_algorich.AbstractSort;

/**
 *create by datao.wang 2014-2-7-下午3:04:49	
 *原理:
 *  1、在要排列的数组中寻找一个基数
 *  2、分区操作,将小于基数的放在前端,将大于基数的放在后端,等于基数放任意一端
 *  3、递归分区,分别前端和后端的数组再次进行分区操作,直到每端只有一个数。
 */
public class QuickSort implements AbstractSort {

	@Override
	public int[] sort(int[] array) {
        sort(array,0,array.length-1);
		return array;
	}
	
	/**
	 * create by datao.wang  2014-2-7
	 * @param a
	 * @param i
	 * @param j
	 * 交换数组的两个位置
	 */
	private void swap(int[] a,int i,int j){
		int t=a[i];
		a[i]=a[j];
		a[j]=t;
	}
	
	/**
	 * create by datao.wang  2014-2-7
	 * @param array
	 * @param p
	 * @param r
	 * @return
	 * 分区操作
	 */
	private int partition(int[] array ,int p,int r){
		int x=array[r]; //最后一个数作为基数
		int j=p-1;
		for(int i=p;i<=r-1;i++){
			if(array[i]<=x){ //将其他数与基数进行比较,如果比基数小则交换位置
				j++;
				swap(array,j,i);
			}
		}
		swap(array,j+1,r);
		return j+1;
	}
    
	/**
	 * create by datao.wang  2014-2-7
	 * @param array
	 * @param p
	 * @param r
	 * 排序
	 */
	private void sort(int array[],int p,int r){
		int q=0;
		if(p<r){
			q=partition(array, p, r);
			sort(array, p, q-1);
			sort(array,q+1,r);
		}
	}
}


package concrete_algorich;

import abstract_algorich.AbstractSort;

/**
 *create by datao.wang 2014-2-7-下午2:46:00	
 *选择排序
 *原理:在一个数组中先假设第一元素为最小(大)元素,然后将这个元素与剩余的元素进行比较
 *      如果遇上有元素比假设的值更小,则进行交换,否则不交换,将比较后较小的元素放在该
 *      数组(已排序)的后面,以此类推进行比较。
 */
public class SelectSort implements AbstractSort {

	@Override
	public int[] sort(int[] array) {
         int len=array.length;
         int temp;
         for(int i=0;i<len;i++){
        	 temp=array[i];//第一个假设值
        	 int j;
        	 int samllestLocation=i;
        	 for(j=i+1;j<len;j++){//剩余的元素
        		 if(array[j]<temp){
        			 temp=array[j];//进行比较交换
        			 samllestLocation=j;
        		 }
        	 }
        	 array[samllestLocation]=array[i];//交换元素位置
        	 array[i]=temp;//存放元素值
         }
		return array;
	}

}

 

import concrete_algorich.SelectSort;
import context.SortContext;

/**
 *create by datao.wang 2014-2-7-下午5:08:16	
 *客户端调用
 */
public class Client {
   public static void main(String[] args) {
	
	   int array[]=new int[]{1,3,5,2,3,5,3};
	   SortContext context=new SortContext();
	   context.setSort(new SelectSort());//这里的设置还可以配置到XML文件中
	   context.sort(array);
	   System.out.println(array.toString());
   }
}

 

优点:灵活,使使用者和具体的实现者之间解耦,使用不需要知道具体的算法。

缺点:使用者必须知道存在的策略,策略的增加会带来类的增加。

 

 

 

分享到:
评论

相关推荐

    策略模式 Strategy Pattern

    ### 策略模式 Strategy Pattern #### 概述 策略模式是一种行为设计模式,它使得算法可以在运行时被更改。这种模式允许一个类的行为或其算法在运行时根据需要进行改变,通过这种方式,我们可以轻松地扩展不同的算法...

    【Java设计模式】(2)策略模式Strategy

    策略模式(Strategy)是软件设计模式中的一种行为模式,它使你能在运行时改变对象的行为。在Java中,策略模式通常涉及定义一系列算法,并将每个算法封装起来,使得它们可以相互替换,同时使得算法的变化独立于使用它...

    每天感悟总结-策略模式Strategy

    2009-03-9 策略模式Strategy:当解决一个问题的途径(策略)有很多种的时候,每一种处理方式都可以做为一种处理策略,通过管理类来切换调用不同的策略。

    (行为型模式) Strategy 策略模式

    C#面向对象设计模式 (行为型模式) Strategy 策略模式 视频讲座下载

    策略(strategy)模式

    策略模式是一种行为设计模式,它使你能在运行时改变对象的行为。在策略模式中,一个类的行为或其算法可以在运行时更改。这种类型的设计模式属于行为模式。 在策略模式中,我们创建表示各种策略的对象和一个行为根据...

    走进设计模式之 策略模式(Strategy)

    策略模式是一种行为设计模式,它使你能在运行时改变对象的行为。在软件设计中,有时我们需要根据不同的场景或条件选择不同的算法或行为。策略模式允许我们将这些算法封装成独立的类,每个类代表一种策略,然后在运行...

    设计模式C++学习之策略模式(Strategy)

    在`Demo1_Strategy`这个示例中,可能包含了多个C++源文件,分别实现了策略模式的不同方面,例如定义了策略接口、具体策略类以及上下文类的实现。通过分析这些源代码,我们可以更深入地理解策略模式的用法和优势。 ...

    PHP设计模式之 策略模式Strategy详解【对象行为型】

    本文实例讲述了PHP设计模式之 策略模式Strategy。分享给大家供大家参考,具体如下: 1.概述  在软件开发中也常常遇到类似的情况,实现某一个功能有多种算法或者策略,我们可以根据环境或者条件的不同选择不同的算法...

    设计模式之策略模式(Strategy Pattern)

    在策略模式中,有三个主要角色:策略接口(Strategy Interface)、具体策略类(Concrete Strategy Classes)和上下文(Context)。策略接口定义了所有支持的算法的公共接口,这样上下文就可以通过这个接口来调用这些...

    策略模式(strategy)

    策略模式的核心组成部分包括策略(Strategy)、上下文(Context)和具体策略(Concrete Strategies)。策略定义了算法家族,而上下文则使用这些策略,但并不知道具体的实现细节。具体策略是实现了策略接口的具体算法...

    设计模式之策略模式(Strategy Pattern)

    策略模式的主要组成部分包括上下文(Context)、策略接口(Strategy Interface)和具体策略类(Concrete Strategy Classes)。上下文维护一个对策略对象的引用,并使用这个引用来调用策略对象的算法。策略接口定义了...

    Java 设计模式-策略模式(Strategy)Android讲解

    首先,策略模式由三个主要组成部分构成:上下文(Context)、策略(Strategy)接口和具体策略(Concrete Strategy)。上下文是使用策略的对象,它维护一个对策略的引用,并调用策略的接口来执行算法。策略接口定义了一组...

    C#面向对象设计模式纵横谈(23):(行为型模式) Strategy 策略模式

    策略模式的核心组成部分包括上下文(Context)、策略(Strategy)和具体策略(Concrete Strategy)。上下文是使用策略的对象,它定义了客户所期望的接口,并负责调用具体策略对象的算法。策略是所有具体策略的抽象接口,它...

    设计模式-策略模式(Strategy)

    策略模式是一种行为设计模式,它使你能在运行时改变对象的行为。这种模式允许你使用算法族,而无需在代码中硬编码这些算法。通过将算法封装到具有共同接口的独立对象中,策略模式使得你可以根据需要灵活地切换算法,...

    [行为模式] head first 设计模式之策略模式(strategy)

    在提供的`strategy.h`文件中,可能包含了策略模式的C++实现。文件中可能定义了策略接口和几个具体策略类的声明,以及上下文类的接口。为了进一步了解其内容,我们需要查看源代码。由于实际的代码没有提供,这里只能...

    详解SpringBoot结合策略模式实战套路

    SpringBoot结合策略模式实战套路 策略模式是一种常用的设计模式,它可以使我们的代码更加灵活、可维护和可扩展。在SpringBoot项目中,策略模式可以与依赖注入机制相结合,实现更加灵活的业务逻辑处理。在本文中,...

    strategy策略模式源码

    策略模式是一种行为设计模式,它使你能在运行时改变对象的行为。...在提供的压缩包文件"strategy"中,可能包含了关于策略模式的示例代码或者详细解释,你可以解压后查看,进一步理解和学习策略模式的实现和应用。

    策略模式(Strategy)

    策略模式是一种行为设计模式,它使你能在运行时改变对象的行为。在软件设计中,我们经常遇到需要根据不同的条件或策略来执行不同操作的情况。策略模式提供了一种将算法族封装到各自独立的对象中,使得它们可以在运行...

Global site tag (gtag.js) - Google Analytics