《C++设计模式》策略模式

文章目录

  • 1、引言
    • 1.1 什么是策略模式
    • 1.2 策略模式的应用场景
    • 1.3 本文结构概览
  • 2、策略模式的基本概念
    • 2.1 定义与结构
    • 2.2 核心角色解析
      • 2.2.1 策略接口(Strategy)
      • 2.2.2 具体策略实现(ConcreteStrategy)
      • 2.2.3 上下文(Context)
  • 3、C++中的策略模式实现
    • 3.1 示例场景设定
    • 3.2 策略接口定义
    • 3.3 具体策略实现
      • 3.3.1 策略A实现:信用卡支付
      • 3.3.2 策略B实现:现金支付
    • 3.4 上下文类设计
    • 3.5 完整代码示例
  • 4、策略模式的优点与缺点
    • 4.1 优点
      • 4.1.1 算法自由切换
      • 4.1.2 开闭原则支持
      • 4.1.3 简化单元测试
    • 4.2 缺点
      • 4.2.1 策略类数量膨胀
      • 4.2.2 客户端需要了解策略接口
  • 5、策略模式的应用实例
    • 5.1 电商平台的促销策略
    • 5.2 游戏中的AI行为选择
    • 5.3 图像处理中的滤镜选择
  • 6、策略模式与其他设计模式的比较
    • 6.1 与状态模式的对比
    • 6.2 与模板方法模式的对比
    • 6.3 与装饰者模式的对比
  • 7、高级话题与最佳实践
    • 7.1 使用智能指针管理策略对象
    • 7.2 策略工厂模式简化策略创建
    • 7.3 线程安全考虑
  • 8、总结
    • 8.1 策略模式的核心价值
    • 8.2 何时使用策略模式
    • 8.3 后续学习资源推荐
  • 9、参考文献与进一步阅读
    • 9.1 相关书籍推荐

1、引言

1.1 什么是策略模式

策略模式(Strategy Pattern) 是一种行为型设计模式,它定义了一系列算法,并将每一个算法封装起来,使它们可以互换。策略模式使得算法可以独立于使用它的客户端而变化。策略模式让算法的变化 独立 于使用算法的客户。
在策略模式中,一个类的行为或其算法可以在运行时更改。这种类型的设计模式属于行为型模式,因为算法或行为是通过其上下文(Context)来选择的。
简单来说,策略模式就是定义了一系列的算法,并将每一个算法封装起来,使它们可以相互替换。策略模式使得算法可独立于使用它的客户而变化,即算法本身和使用算法的客户端代码是解耦的。

1.2 策略模式的应用场景

策略模式在软件开发中有着广泛的应用场景,包括但不限于以下几种情况:
(1)多种算法的实现:当存在多种算法,而这些算法的实现又需要频繁地更换或扩展时,可以考虑使用策略模式。通过定义不同的策略类来实现不同的算法,客户端可以根据需要选择具体的策略。
(2)条件分支语句的替代:在程序中,如果存在大量的条件分支语句(如if-else或switch-case),并且这些条件分支语句的实现逻辑比较复杂或容易变化时,可以考虑使用策略模式来替代这些条件分支语句。通过定义不同的策略类来实现不同的分支逻辑,客户端可以根据条件选择具体的策略。
(3)算法与数据结构的分离:在某些情况下,算法和数据结构是紧密相关的,但有时候我们可能需要将算法与数据结构进行分离,以便能够独立地修改或扩展它们。这时,可以使用策略模式来将算法封装成独立的策略类,从而实现算法与数据结构的分离。
(4)可配置的行为:在某些系统中,某些行为可能需要根据配置或用户的选择来改变。这时,可以使用策略模式来定义不同的策略类,并根据配置或用户的选择来选择具体的策略。

1.3 本文结构概览

本文旨在详细介绍C++中的策略模式,包括其基本概念、实现方法、优缺点以及应用场景等方面。文章将分为以下几个部分:
引言:介绍策略模式的基本概念、应用场景以及本文的结构概览。
策略模式的基本概念:详细解释策略模式的定义、结构以及核心角色。
C++中的策略模式实现:通过具体的代码示例来展示如何在C++中实现策略模式。
策略模式的优缺点:分析策略模式的优点和缺点,以便更好地理解其适用场景和限制。
策略模式的应用实例:介绍一些实际项目中应用策略模式的例子,以便读者更好地理解其应用价值。
总结与展望:总结本文的主要内容,并对策略模式的发展和应用前景进行展望。
希望本文能够帮助读者深入理解C++中的策略模式,并能够在实际项目中灵活运用该模式来解决实际问题。

2、策略模式的基本概念

2.1 定义与结构

策略模式(Strategy Pattern),又称为政策模式(Policy),是一种对象行为型模式。其定义了一系列算法,并将每个算法封装起来,使它们可以相互替换,且算法的变化不会影响使用算法的客户。策略模式把算法的使用放到环境类中,而算法的实现移到具体策略类中,实现了二者的分离。
从软件设计角度看,策略模式在一个任务中,将算法部分封装成独立的接口,和任务分离,以便可以动态选用不同算法。策略模式使得可以定义新的算法,而不引起任务本身的代码变动。这里的算法可以是数学上的算法,也可以是一个处理具体问题的方案。

2.2 核心角色解析

策略模式通常包含以下三个核心角色:

2.2.1 策略接口(Strategy)

定义:策略接口定义了一组算法或行为的公共接口,所有具体策略类都需要实现这个接口。这个接口的实现各不相同,每个实现对应一种具体的算法或行为。
作用:为所支持的算法声明了抽象方法,是所有策略类的父类。它可以是抽象类或具体类,也可以是接口。环境类通过策略接口中声明的方法在运行时调用具体策略类中实现的算法。

2.2.2 具体策略实现(ConcreteStrategy)

定义:具体策略类实现了策略接口中声明的算法。
作用:在运行时,具体策略类将覆盖在环境类中定义的策略接口对象,使用一种具体的算法实现某个业务功能。

2.2.3 上下文(Context)

定义:上下文是使用算法的角色,它在解决某个问题(即实现某个功能)时可以采用多种策略。
作用:
封装了具体策略的执行逻辑,提供给客户端使用的接口。
维持一个对策略接口的引用实例,用于定义所采用的策略。
可以在运行时动态地更换策略,从而改变算法的行为。上下文对象不需要了解算法的细节,只需调用策略接口即可。
通过以上三个角色的协同工作,策略模式实现了算法的灵活切换和扩展,提高了代码的可维护性和复用性。

3、C++中的策略模式实现

3.1 示例场景设定

为了演示C++中的策略模式,我们设定一个简单的支付系统场景。在这个系统中,用户可以选择不同的支付方式来完成支付,如信用卡支付、现金支付和支付宝支付。每种支付方式对应一个具体的策略,而支付系统则作为上下文类,根据用户的选择来执行相应的支付策略。

3.2 策略接口定义

首先,我们定义一个策略接口PaymentStrategy,它包含一个纯虚函数pay,用于执行支付操作。

#include <iostream>
#include <memory>// 策略接口
class PaymentStrategy {
public:virtual ~PaymentStrategy() = default;virtual void pay(double amount) const = 0;
};

3.3 具体策略实现

接下来,我们实现三个具体的支付策略:信用卡支付CreditCardPayment、现金支付CashPayment和支付宝支付AlipayPayment。

3.3.1 策略A实现:信用卡支付

// 信用卡支付策略
class CreditCardPayment : public PaymentStrategy {
public:void pay(double amount) const override {std::cout << "Paid " << amount << " using Credit Card." << std::endl;}
};

3.3.2 策略B实现:现金支付

// 现金支付策略
class CashPayment : public PaymentStrategy {
public:void pay(double amount) const override {std::cout << "Paid " << amount << " using Cash." << std::endl;}
};
(注:为了简洁,这里只展示了两个具体策略的实现,支付宝支付的实现方式类似,可以作为练习留给读者。)

3.4 上下文类设计

上下文类PaymentContext持有一个指向PaymentStrategy的指针(或智能指针),用于在运行时选择具体的支付策略。

// 上下文类
class PaymentContext {
private:std::unique_ptr<PaymentStrategy> strategy;public:PaymentContext(std::unique_ptr<PaymentStrategy> strategy): strategy(std::move(strategy)) {}void setStrategy(std::unique_ptr<PaymentStrategy> newStrategy) {strategy = std::move(newStrategy);}void pay(double amount) const {strategy->pay(amount);}
};

3.5 完整代码示例

下面是一个完整的代码示例,展示了如何在C++中使用策略模式来实现支付系统。

#include <iostream>
#include <memory>// 策略接口
class PaymentStrategy {
public:virtual ~PaymentStrategy() = default;virtual void pay(double amount) const = 0;
};// 信用卡支付策略
class CreditCardPayment : public PaymentStrategy {
public:void pay(double amount) const override {std::cout << "Paid " << amount << " using Credit Card." << std::endl;}
};// 现金支付策略
class CashPayment : public PaymentStrategy {
public:void pay(double amount) const override {std::cout << "Paid " << amount << " using Cash." << std::endl;}
};// 上下文类
class PaymentContext {
private:std::unique_ptr<PaymentStrategy> strategy;public:PaymentContext(std::unique_ptr<PaymentStrategy> strategy): strategy(std::move(strategy)) {}void setStrategy(std::unique_ptr<PaymentStrategy> newStrategy) {strategy = std::move(newStrategy);}void pay(double amount) const {strategy->pay(amount);}
};int main() {// 创建具体的支付策略对象auto creditCard = std::make_unique<CreditCardPayment>();auto cash = std::make_unique<CashPayment>();// 创建上下文对象,并设置初始的支付策略为信用卡支付PaymentContext context(std::move(creditCard));// 执行支付操作context.pay(100.0);  // 输出: Paid 100 using Credit Card.// 动态更改支付策略为现金支付context.setStrategy(std::move(cash));// 再次执行支付操作context.pay(200.0);  // 输出: Paid 200 using Cash.return 0;
}

在这个示例中,我们首先定义了策略接口PaymentStrategy,然后实现了两个具体的支付策略CreditCardPayment和CashPayment。接着,我们设计了上下文类PaymentContext,它持有一个指向PaymentStrategy的智能指针,用于在运行时选择具体的支付策略。最后,在main函数中,我们演示了如何创建具体的支付策略对象、设置上下文对象的支付策略,并执行支付操作。

4、策略模式的优点与缺点

4.1 优点

4.1.1 算法自由切换

策略模式使得算法可以独立于使用它的客户端而变化。这意味着客户端可以在运行时根据需要动态地选择不同的算法,而无需修改客户端的代码。这种灵活性有助于在不影响其他部分的情况下对系统进行扩展和修改。

4.1.2 开闭原则支持

策略模式遵循开闭原则,即对扩展开放,对修改关闭。通过增加新的策略类而不是修改已有的类来实现功能的扩展,这使得系统更加易于维护和扩展。

4.1.3 简化单元测试

由于策略模式将算法封装在独立的类中,因此可以针对每个策略类进行单独的单元测试。这有助于确保每个算法的正确性,并降低整体系统的测试复杂度。

4.2 缺点

4.2.1 策略类数量膨胀

当系统中存在大量的算法或行为时,使用策略模式可能会导致策略类的数量急剧增加。这会增加系统的复杂性和维护成本,因为需要管理大量的类和接口。

4.2.2 客户端需要了解策略接口

在使用策略模式时,客户端需要了解并选择合适的策略类。这要求客户端具有一定的了解和判断能力,以便在运行时选择最合适的算法或行为。如果客户端对策略接口的了解不足,可能会导致选择错误的策略类,从而影响系统的正确性和性能。

5、策略模式的应用实例

5.1 电商平台的促销策略

在电商平台中,促销策略是吸引用户、提高转化率的重要手段。传统的促销策略往往依赖于经验和直觉,缺乏数据支撑和精准度。随着大数据和人工智能技术的快速发展,电商促销策略也迎来了新的变革。通过策略模式,电商平台可以根据用户行为、商品属性、市场趋势等数据,构建更精准、更有效的促销策略。例如,根据用户的浏览历史、购买记录等信息,推荐个性化的商品和促销活动;或者通过分析用户对不同促销活动的响应情况,优化促销活动的时间、力度和内容。

5.2 游戏中的AI行为选择

在策略游戏中,AI的行为选择对于游戏的平衡性和趣味性至关重要。通过策略模式,游戏开发者可以为AI设计多种不同的行为策略,并在游戏运行时根据战局情况动态选择最合适的策略。例如,在战斗场景中,AI可以根据敌人的数量和类型、自身的资源和能力等因素,选择进攻、防御或撤退等不同的行为策略。这种灵活性使得游戏更加具有挑战性和趣味性。

5.3 图像处理中的滤镜选择

在图像处理软件中,滤镜是常用的功能之一。通过策略模式,可以将不同的滤镜算法封装成独立的策略类,并提供统一的接口供用户选择。这样,用户可以根据需要选择不同的滤镜来处理图像,例如模糊、锐化、颜色调整等。这种设计方式使得图像处理软件更加灵活和易于扩展,同时也提高了用户的操作体验和满意度。
综上所述,策略模式是一种强大的设计模式,它允许在运行时根据不同的策略选择不同的算法或行为。虽然它也有一些缺点,但在适当的场景下使用策略模式可以带来显著的优点和好处。

6、策略模式与其他设计模式的比较

6.1 与状态模式的对比

结构差异:
策略模式在结构上相对简单,通常包含一个环境类(Context),它持有一个策略接口(Strategy)的引用,以及多个实现了该接口的具体策略类(ConcreteStrategy)。
状态模式则更为复杂,它包含了一系列的状态对象(State),这些状态对象可以持有自己的数据,并定义了在不同状态下对象应该采取的行为。状态模式中的环境类(Context)通常持有一个当前状态对象的引用,并委托给该状态对象处理请求。
行为变化:
策略模式关注的是算法或行为的变化,这些算法或行为是独立且可替换的。客户端可以在运行时选择不同的策略对象,以实现不同的行为。
状态模式则关注的是对象在不同状态下的行为变化,以及状态之间的切换。它允许对象在内部状态改变时自动改变其行为。
使用场景:
策略模式适用于系统中存在多种算法或行为,且这些算法或行为可以独立变化的情况。
状态模式适用于对象的行为随其内部状态改变而改变,且这些状态之间的切换逻辑较为复杂的情况。

6.2 与模板方法模式的对比

结构差异:
策略模式包含环境类、策略接口和具体策略实现类。
模板方法模式则包含一个抽象类(AbstractClass),该类中定义了一个算法的骨架,并包含了一些抽象方法或钩子方法(Hook),这些方法的具体实现由子类提供。
关注点:
策略模式关注的是算法或行为的替换和选择,它允许客户端在运行时动态地选择不同的策略对象。
模板方法模式关注的是算法的骨架和具体步骤的延迟实现。它提供了一个算法的总体结构,但允许子类根据需要重写或扩展某些步骤。
使用场景:
策略模式适用于需要动态选择不同算法或行为的情况。
模板方法模式适用于算法或行为的基本结构固定,但具体实现因子类而异的情况。

6.3 与装饰者模式的对比

结构差异:
策略模式和装饰者模式在结构上有所不同。策略模式主要包含环境类、策略接口和具体策略实现类。
装饰者模式则包含一个基本的组件类(Component)和多个装饰者类(Decorator),每个装饰者类都持有一个组件的引用,并可以在该组件的基础上添加额外的行为或功能。
关注点:
策略模式关注的是算法或行为的替换和选择。
装饰者模式关注的是在不改变类结构的情况下,动态地为对象添加额外的功能或行为。
使用场景:
策略模式适用于需要动态选择不同算法或行为的情况。
装饰者模式适用于需要在不修改原有类代码的情况下,为对象添加新的功能或行为的情况。

7、高级话题与最佳实践

7.1 使用智能指针管理策略对象

在C++等语言中,使用智能指针(如std::shared_ptr或std::unique_ptr)来管理策略对象可以自动处理内存分配和释放,避免内存泄漏和悬挂指针等问题。智能指针通过引用计数或其他机制来确保对象在不再被需要时自动销毁。
使用智能指针管理策略对象时,需要注意以下几点:
确保策略对象被正确地创建和初始化。
避免在多个线程之间共享同一个智能指针,除非该智能指针是线程安全的。
在不再需要策略对象时,确保它能够被正确地销毁和释放。

7.2 策略工厂模式简化策略创建

为了简化策略对象的创建过程,可以使用工厂模式(如简单工厂、工厂方法或抽象工厂)来封装策略对象的创建逻辑。这样,客户端只需要与工厂接口交互,而无需了解具体策略类的实现细节。
使用策略工厂模式时,需要注意以下几点:
工厂类应该提供一个统一的接口来创建不同类型的策略对象。
工厂类应该能够处理策略对象的创建和初始化过程中的任何异常或错误。
客户端应该通过工厂接口来获取策略对象,而不是直接实例化具体策略类。

7.3 线程安全考虑

在多线程环境中使用策略模式时,需要考虑线程安全问题。如果策略对象的状态在多个线程之间共享,那么需要采取适当的同步机制来确保线程安全。
以下是一些常见的线程安全考虑:
使用线程安全的智能指针来管理策略对象。
在策略对象的方法中添加适当的同步机制(如互斥锁或读写锁)。
避免在多个线程之间共享可变的状态信息,除非使用了适当的同步机制。
在设计策略模式时,尽量将状态信息封装在策略对象内部,并通过不可变对象或线程安全的集合来传递状态信息。
总之,在使用策略模式时,需要根据具体的应用场景和需求来选择合适的设计和实现方式,并关注线程安全、内存管理等高级话题和最佳实践。

8、总结

8.1 策略模式的核心价值

策略模式的核心价值在于提供了一种灵活且可扩展的方式来处理算法或行为的变化。它将算法或行为封装成独立的策略类,使得这些策略可以互换,而客户端代码则可以根据需要动态地选择不同的策略。这种设计使得系统更加灵活,易于维护和扩展。策略模式的核心价值主要体现在以下几个方面:
提高了系统的灵活性和可扩展性:通过封装不同的算法或行为,策略模式使得系统可以轻松地添加新的策略,而无需修改现有的客户端代码。
简化了客户端代码:客户端代码只需要与抽象策略类进行交互,而无需关心具体的策略实现,从而简化了客户端代码。
实现了算法或行为的可重用性:不同的策略类可以共享相同的接口或抽象类,这使得算法或行为可以在不同的上下文中重用。
增强了系统的可维护性:由于策略模式将算法或行为封装在独立的类中,因此当某个算法或行为需要修改时,只需要修改相应的策略类即可,而不会影响到其他部分的代码。

8.2 何时使用策略模式

策略模式适用于以下场景:
算法或行为有多种变体:当系统需要实现多种算法或行为,并且这些算法或行为之间可以互换时,可以使用策略模式。
避免使用多重条件语句:如果系统中的算法或行为选择依赖于多个条件语句,这会导致代码难以理解和维护。此时,可以使用策略模式将不同的算法或行为封装成独立的类,从而消除多重条件语句。
需要动态选择算法或行为:当系统中的算法或行为需要在运行时动态选择时,可以使用策略模式。客户端代码可以根据需要选择不同的策略类,从而实现动态的行为选择。
需要封装复杂的算法或行为:如果系统中的某个算法或行为非常复杂,需要将其封装起来以便更好地理解和维护,那么可以使用策略模式。

8.3 后续学习资源推荐

为了深入学习策略模式及其在实际项目中的应用,以下是一些推荐的学习资源:
《设计模式:可复用面向对象软件的基础》(Erich Gamma等著):这本书是设计模式领域的经典之作,详细介绍了包括策略模式在内的多种设计模式。
《重构:改善既有代码的设计》(Martin Fowler著):这本书提供了许多实用的重构技巧,其中也包括对策略模式的讨论和应用。

9、参考文献与进一步阅读

9.1 相关书籍推荐

《设计模式:可复用面向对象软件的基础》:这本书是设计模式领域的权威之作,详细阐述了各种设计模式的概念、原理和应用场景。对于想要深入理解策略模式及其在其他设计模式中的关系的读者来说,这本书是不可或缺的。
《重构:改善既有代码的设计》:这本书提供了许多实用的重构技巧和方法,其中也包括对策略模式的讨论和应用。通过这本书,你可以学习如何在现有代码中应用策略模式来改善代码的可读性和可维护性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/66060.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Spring源码分析之事件机制——观察者模式(一)

目录 事件基类定义 事件监听器接口 事件发布者接口及实现 事件广播器实现 小小总结 Spring源码分析之事件机制——观察者模式&#xff08;一&#xff09;-CSDN博客 Spring源码分析之事件机制——观察者模式&#xff08;二&#xff09;-CSDN博客 Spring源码分析之事件机制…

Spring Security(maven项目) 3.0.2.4版本

前言&#xff1a; 通过实践而发现真理&#xff0c;又通过实践而证实真理和发展真理。从感性认识而能动地发展到理性认识&#xff0c;又从理性认识而能动地指导革命实践&#xff0c;改造主观世界和客观世界。实践、认识、再实践、再认识&#xff0c;这种形式&#xff0c;循环往…

stm32 移植RTL8201F(正点原子例程为例)

最近在工作中需要使用RTL8201F&#xff0c;在网上找了很多帖子&#xff0c;没有找到合适的&#xff0c;自己翻资料移植了一个。 模板工程使用的是正点原子的f407探索版的例程&#xff0c;原子使用的是LAN8720,需要把他的驱动修改成为我们自己用的RTL8201F。 1.将PHY_TYPE改成我…

Unity学习笔记(四)如何实现角色攻击、组合攻击

前言 本文为Udemy课程The Ultimate Guide to Creating an RPG Game in Unity学习笔记 实现动画 首先实现角色移动的动画&#xff0c;动画的实现过程在第二篇&#xff0c;这里仅展示效果 attack1 触发攻击动画 实现脚本 接下来我们通过 Animator 编辑动画之间的过渡&#…

redis的集群模式与ELK基础

一、redis的集群模式 1.主从复制 &#xff08;1&#xff09;概述 主从模式&#xff1a;这是redis高可用的基础&#xff0c;哨兵和集群都是建立在此基础之上。 主从模式和数据库的主从模式是一样的&#xff0c;主负责写入&#xff0c;然后把写入的数据同步到从服务器&#xff…

一套比较简单的仓储系统

自己编写的一套比较简单的仓储系统&#xff0c;多仓库&#xff0c;入库、出库、明细、统计等相关功能 基于偌依的单体架构&#xff1a;springbootvueuniapp 后端&#xff1a;https://download.csdn.net/download/qq_30641447/90214834 前端&#xff1a;https://download.csdn…

网络IP协议

IP&#xff08;Internet Protocol&#xff0c;网际协议&#xff09;是TCP/IP协议族中重要的协议&#xff0c;主要负责将数据包发送给目标主机。IP相当于OSI&#xff08;图1&#xff09;的第三层网络层。网络层的主要作用是失陷终端节点之间的通信。这种终端节点之间的通信也叫点…

设计模式 创建型 原型模式(Prototype Pattern)与 常见技术框架应用 解析

原型模式&#xff08;Prototype Pattern&#xff09;是一种创建型设计模式&#xff0c;其核心思想在于通过复制现有的对象&#xff08;原型&#xff09;来创建新的对象&#xff0c;而非通过传统的构造函数或类实例化方式。这种方式在需要快速创建大量相似对象时尤为高效&#x…

MySQL(二)MySQL DDL数据库定义语言

1. MySQL DDL数据库定义语言 1.1. MySQL定义语言 进入MySQL mysql -u root -p(回车后输入密码&#xff0c;即可进入mysq1)1.1.1. 数据库操作 &#xff08;1&#xff09;查看数据库 mysql>show databases;注:MySQL语句分隔符为“&#xff1b;”   mysql库很重要它里面有…

前端页面上传文件:解决 ERR_UPLOAD_FILE_CHANGED

文章目录 引言I 问题 ERR_UPLOAD_FILE_CHANGED问题重现步骤原因II 解决方法将文件转换为base64再转回file检测文件内容是否发生变更III 知识扩展发送一个包含文件和文本的multipart/form-data请求签名优化引言 文件上传应用场景:船舶设备的新增导入(基础信息:出厂编号)船舶…

学术写作中的各种流程图如何利用Kimi进行辅助构建?

目录 1.学术论文中的流程图 2.一些小实践 3.论文中严谨的实践流程 近期小编在思考使用AI工具制作流程图和思维导图&#xff0c;结果发现Kimi现在支持流程图了&#xff0c;Kimi在学术写作中的应用变得更加广泛和深入。随着AIGC技术的不断进步&#xff0c;Kimi的功能将更加强大…

竞品分析对于ASO优化的重要性

产品要想在拥有上千万款App的App Store中脱颖而出的话&#xff0c;要有绝对优势和运营方案&#xff0c;才有可能获得用户的关注。我们要分析和自身产品相似的功能&#xff0c;了解用户获取的途径等&#xff0c;从中获取对竞品有利的因素&#xff0c;明确自身产品的增加和优化方…

什么是485专用屏蔽线

文章目录 一,485屏蔽线基本概念二,485屏蔽线结构及工作原理1、结构2、工作原理三,485屏蔽线的应用一,485屏蔽线基本概念 485屏蔽线,顾名思义,是一种应用于RS-485通信系统的屏蔽线缆。RS_485是一种常用的有线通信协议,具有长距离、高速率、低成本等优点,广泛应用于工业自…

JavaScript BOMDOM

BOM window、document、location、navigator 和 screen等&#xff0c;把它们统称为BOM&#xff08;Browser Object Model&#xff0c;浏览器对象模型&#xff09; window对象 window对象位于BOM的顶层。由浏览器创建&#xff0c;也对应JavaScript本地对象Global &#xff1…

nginx高可用集群搭建

本文介绍nginx高可用集群的搭建。利用keepalived实时检查nginx进程是否存活、keepalived的虚拟ip技术&#xff0c;达到故障转移的目的。终端用户通过访问虚拟ip&#xff0c;感知不到实际发生的故障。架构图如下&#xff1a; 0、环境 Ubuntu&#xff1a;22.04.2 ltsnginx: 1.…

【开源】创建自动签到系统—QD框架

1. 介绍 QD是一个 基于 HAR 编辑器和 Tornado 服务端的 HTTP 定时任务自动执行 Web 框架。 主要通过抓包获取到HAR来制作任务模板&#xff0c;从而实现异步响应和发起HTTP请求 2. 需要环境 2.1 硬件需求 CPU&#xff1a;至少1核 内存&#xff1a;推荐 ≥ 1G 硬盘&#xff1a;推…

【数据结构Ⅰ复习题】

如有错误欢迎指正&#xff0c;题目根据教材----------严蔚敏数据结构&#xff08;c语言版 第2版&#xff09;人民邮电电子版 数据结构Ⅰ复习题 一、填空题1&#xff0e;算法应该具备的5个重要特性有___有穷性___、确定性、可行性、输入和输出。2&#xff0e;非空单链表L中*p是头…

python爬虫--小白篇【selenium自动爬取文件】

一、问题描述 在学习或工作中需要爬取文件资源时&#xff0c;由于文件数量太多&#xff0c;手动单个下载文件效率低&#xff0c;操作麻烦&#xff0c;采用selenium框架自动爬取文件数据是不二选择。如需要爬取下面网站中包含的全部pdf文件&#xff0c;并将其转为Markdown格式。…

Edge Scdn的应用场景有哪些?

酷盾安全Edge Scdn 具备强大的安全防护能力&#xff0c;通过多层防御机制&#xff0c;如防火墙、DDoS 攻击防护、入侵检测和防御、数据加密等&#xff0c;有效抵御各种网络攻击&#xff0c;包括 DDoS 攻击、CC 攻击、SQL 注入攻击、XSS 跨站脚本攻击等&#xff0c;保障网站和应…