PHP设计模式-策略模式

策略模式属于行为类模式中的一个类型

适用场景:
当我们实用的类比较简单,但是有相互不关联,只是在特定行为上有所差异的场景下,策略模式就会十分有用。

在策略模式中,从一个接口扩展出许多具体的类,这些具体的类用于一些特定的对象。

策略模式的三个角色:
1.抽象策略角色
2.具体策略角色
3.环境角色(对抽象策略角色的引用)

举个例子:
对多维数组进行排序,并且使用对象来实现它。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
<?php
/**
 * 策略模式实现数组排序
 * Created by PhpStorm.
 * User: shiwuhao
 * Date: 15/11/5
 * Time: 23:49
 */


/**
 * 排序的接口定义sort方法
 * Interface iSort
 */

interface iSort{

    function sort(array $list);
}

/**
 * 多维数组按字符串排序
 * Class MultiAlphaSort
 */

class MultiAlphaSort implements iSort {

    // 排序方式
    private $_order;

    // 排序索引
    private $_index;

    public function __construct($index, $order = 'ascending')
    {
        $this->_index = $index;
        $this->_order = $order;
    }

    // 实现排序功能
    public function sort(array $list)
    {
        if ($this->_order == 'ascending') {
            uasort($list, array($this, 'ascSort'));
        } else {
            uasort($list, array($this, 'descSort'));
        }
        return $list;
    }

    // 按自然排序法升序排序
    public function ascSort($x, $y)
    {
        return strnatcmp($x[$this->_index], $y[$this->_index]);
    }

    // 按自然排序法降序排序
    public function descSort($x, $y)
    {
        return strnatcmp($y[$this->_index], $x[$this->_index]);
    }
}

/**
 * 多维数组按照数字排序
 * Class MultiNumberSort
 */

class MultiNumberSort implements iSort
{

    // 排序索引
    private $_index;

    // 排序方式
    private $_order;

    public function __construct($index, $order = 'ascending')
    {
        $this->_index = $index;
        $this->_order = $order;
    }

    // 实现排序功能
    public function sort(array $list)
    {
        if ($this->_order == 'ascending') {
            uasort($list, array($this, 'ascSort'));
        } else {
            uasort($list, array($this, 'descSort'));
        }
        return $list;
    }

    // 比较两个值大小 升序排序
    public function ascSort($x, $y)
    {
        return $x[$this->_index] > $y[$this->_index];
    }

    // 比较两个值大小 降序排序
    public function descSort($x, $y)
    {
        return $x[$this->_index] < $y[$this->_index];
    }
}

阅读更多