溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

PHP設(shè)計(jì)模式(5)策略模式

發(fā)布時(shí)間:2020-07-28 07:55:06 來源:網(wǎng)絡(luò) 閱讀:546 作者:shayang88 欄目:web開發(fā)

在此模式中,算法是從復(fù)雜類提取的,因而可以方便地替換。例如,如果要更改搜索引擎中排列頁的方法,則策略模式是一個(gè)不錯(cuò)的選擇。思考一下搜索引擎的幾個(gè)部分 —— 一部分遍歷頁面,一部分對(duì)每頁排列,另一部分基于排列的結(jié)果排序。在復(fù)雜的示例中,這些部分都在同一個(gè)類中。通過使用策略模式,您可將排列部分放入另一個(gè)類中,以便更改頁排列的方式,而不影響搜索引擎的其余代碼。

作為一個(gè)較簡單的示例,清單顯示了一個(gè)用戶列表類,它提供了一個(gè)根據(jù)一組即插即用的策略查找一組用戶的方法。

<?php
//策略接口
interface IStrategy
{
function filter( $record );
}
//定義一種策略繼承接口
class FindAfterStrategy implements IStrategy
{
private $_name;
public function __construct( $name )
{
$this->_name = $name;
}
public function filter( $record )
{
return strcmp( $this->_name, $record ) <= 0;
}
}
//定義另一種策略
class RandomStrategy implements IStrategy
{
public function filter( $record )
{
return rand( 0, 1 ) >= 0.5;
}
}
//定義用戶列表類
class UserList
{
private $_list = array();
public function __construct( $names )
{
if ( $names != null )
{
foreach( $names as $name )
{
$this->_list []= $name;
}
}
}
public function add( $name )
{
$this->_list []= $name;
}
//根據(jù)某個(gè)策略來獲取用戶
public function find( $filter )
{
$recs = array();
foreach( $this->_list as $user )
{
if ( $filter->filter( $user ) )
$recs []= $user;
}
return $recs;
}
}
//初始化用戶列表
$ul = new UserList( array( "Andy", "Jack", "Lori", "Megan" ) );
//根據(jù)第一個(gè)策略獲取用戶
$f1 = $ul->find( new FindAfterStrategy( "J" ) );
echo '<pre>';
print_r( $f1 );
echo '</pre>';
//根據(jù)第二個(gè)策略獲取用戶
$f2 = $ul->find( new RandomStrategy() );
echo '<pre>';
print_r( $f2 );
echo '</pre>';

UserList 類是打包名稱數(shù)組的一個(gè)包裝器。它實(shí)現(xiàn) find 方法,該方法利用幾個(gè)策略之一來選擇這些名稱的子集。這些策略由 IStrategy 接口定義,該接口有兩個(gè)實(shí)現(xiàn):一個(gè)隨機(jī)選擇用戶,另一個(gè)根據(jù)指定名稱選擇其后的所有名稱。運(yùn)行測試代碼時(shí),將得到以下輸出:

PHP設(shè)計(jì)模式(5)策略模式


測試代碼為兩個(gè)策略運(yùn)行同一用戶列表,并顯示結(jié)果。在第一種情況中,策略查找排列在 J 后的任何名稱,所以您將得到 Jack、Lori 和 Megan。第二個(gè)策略隨機(jī)選取名稱,每次會(huì)產(chǎn)生不同的結(jié)果。在這種情況下,結(jié)果為 Andy 和 Megan。

策略模式非常適合復(fù)雜數(shù)據(jù)管理系統(tǒng)或數(shù)據(jù)處理系統(tǒng),二者在數(shù)據(jù)篩選、搜索或處理的方式方面需要較高的靈活性。


向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI