策略模式

策略模式

策略模式定义了一系列的算法,并将每一个算法封装起来,而且使它们还可以相互替换。策略模式让算法独立于使用它的客户而独立变化,即封装变化的算法。

本质是将算法封装起来

下面看一个常见的代码

<?php
/**
 * @param string $driver
 * @param string $msg
 * @datetime 2020/7/17 5:42 PM
 * @author roach
 * @email [email protected]
 */
function log($driver, $msg) {
    switch ($driver) {
        case 'db':
            /**
             * @var \PDO $db
             */
            $stmt = $db->prepare('INSERT INTO `roach`(`msg`)VALUES(?)');
            $stmt->execute([ $msg ]);
        case 'redis':
            /**
             * @var \Redis $redis
             */
            $redis->lPush('roach:log', $msg);
        default:
            file_put_contents('/tmp/roach.log', $msg, FILE_APPEND| LOCK_EX);
    }
}

以上我们实现了记录日志的简单基本功能,调用端提供drivermsg参数即可,调用api很简单,log方法里的实现也就用了一个switch,这里有什么问题呢?

上述代码看着很简单,没什么大问题,但是我们考虑一下,是否对修改关闭了?当我们需要修改某一个driver记录日志的细节时,都需要修改log方法,可见没有对修改关闭;再看一下,如果我们需要增加kafka驱动,还是需要修改log方法,可见也不是对扩展开放,那么怎么修改呢?

这里就用到了策略模式,下面是应用策略模式实现例程

<?php
/**
 * @param string $driver
 * @param string $msg
 * @datetime 2020/7/17 5:42 PM
 * @author roach
 * @email [email protected]
 */
function log($driver, $msg) {
    switch ($driver) {
        case 'db':
            /**
             * @var \PDO $db
             */
            $stmt = $db->prepare('INSERT INTO `roach`(`msg`)VALUES(?)');
            $stmt->execute([ $msg ]);
        case 'redis':
            /**
             * @var \Redis $redis
             */
            $redis->lPush('roach:log', $msg);
        default:
            file_put_contents('/tmp/roach.log', $msg, FILE_APPEND| LOCK_EX);
    }
}

以上代码是一个策略模式的实现例程,调用端如果想记录日志,通过调用LogContextlog方法即可,在调用log方法前需要调用setDriver初始化_driver实例。现在我们再来看是否对修改关闭了,当我们想修改文件日志行为,直接修改类File即可,其他的driver不受影响;再看是否对扩展开放,当我们想把日志记录到Kafka里,我们增加Kafka类即可,其他driver不受影响。

关于策略模式,你学会了吗?

Read more

超快速,使用ChatGPT编写回归和分类算法

超快速,使用ChatGPT编写回归和分类算法

本文将使用一些 ChatGPT 提示,这些提示对于数据科学家在工作时非常重要。 微信搜索关注《Python学研大本营》,加入读者群,分享更多精彩 以下是一些示例ChatGPT 提示的列表以及数据科学家的响应。 ChatGPT 提示 为决策树回归算法生成 python 代码。 下面是使用scikit-learn在 Python 中进行决策树回归的示例代码: import numpy as np import matplotlib.pyplot as plt from sklearn.tree import DecisionTreeRegressor # Generate random data rng = np.random.default_rng() x = 5 * rng.random(100) y = np.sin(x) + 0.

By Ne0inhk
力扣每日一题:993.二叉树的堂兄弟节点 深度优先算法

力扣每日一题:993.二叉树的堂兄弟节点 深度优先算法

993.二叉树的堂兄弟节点 难度:简单 题目: 在二叉树中,根节点位于深度 0 处,每个深度为 k 的节点的子节点位于深度 k+1 处。 如果二叉树的两个节点深度相同,但 父节点不同 ,则它们是一对堂兄弟节点。 我们给出了具有唯一值的二叉树的根节点 root ,以及树中两个不同节点的值 x 和 y 。 只有与值 x 和 y 对应的节点是堂兄弟节点时,才返回 true 。否则,返回 false。 示例: 示例 1: 输入:root = [1,2,3,4], x = 4, y = 3 输出:false

By Ne0inhk
1239.串联字符串的最大长度 关于字符串的回溯算法!

1239.串联字符串的最大长度 关于字符串的回溯算法!

题目: 给定一个字符串数组 arr,字符串 s 是将 arr 某一子序列字符串连接所得的字符串, 如果 s 中的每一个字符都只出现过一次,那么它就是一个可行解。 请返回所有可行解 s 中最长长度。 提示: 1 <= arr.length <= 16 1 <= arr[i].length <= 26 arr[i] 中只含有小写英文字母 示例: 示例 1: 输入:arr = ["un","iq","ue"] 输出:4 解释:所有可能的串联组合是

By Ne0inhk