当前位置: 首页 > news >正文

设计模式 --- 观察者模式

设计模式 --- 观察者模式

  • 什么是观察者模式
  • 观察者模式典型应用 --- C#中的事件
  • 使用观察者模式实现事件处理机制

什么是观察者模式

  • 观察者模式(Observer Pattern)是一种行为型设计模式,用于在对象之间建立一对多的依赖关系。当一个对象(称为“主题”Subject)的状态发生改变时,所有依赖它的对象(称为“观察者”Observer)会自动收到通知并更新。这种模式的核心是解耦主题和观察者,让它们可以独立变化。
  • 核心思想
    主题(Subject):维护一个观察者列表,提供注册、注销和通知机制。
    观察者(Observer):定义统一的更新接口,当主题状态变化时被调用。
    松耦合:主题不需要知道观察者的具体实现,只需通过接口通知

观察者模式典型应用 — C#中的事件

事件是什么?

  • 事件(Event)是 C# 中的一种语言机制,允许一个对象(发布者)在特定动作发生时,通知其他对象(订阅者)执行响应逻辑。
    它本质上是基于委托(Delegate)的封装,提供了一种安全、可控的观察者模型
  • 核心特点
  • 主题定义事件:声明事件并决定何时触发。
  • 观察者注册方法:将方法绑定到事件,事件触发时自动调用。
  • 解耦设计:主题和观察者无需直接依赖彼此的具体实现。

事件的原理

  • 底层机制:委托 + 观察者模式
  • 委托(Delegate)
    事件本质是一个多播委托MulticastDelegate),可以存储多个方法引用。当事件触发时,所有绑定的方法会被依次调用。

  • 观察者模式(Observer Pattern)

    • 发布者(Subject):维护一个订阅者列表(通过委托链实现),提供订阅(+=)和取消订阅(-=)接口。
    • 订阅者(Observer):向发布者注册事件处理方法,事件触发时自动执行。

完整示例:温度监控系统

  • 场景描述
  • 发布者TemperatureMonitor 类,监控温度变化。
  • 订阅者
    • AlertSystem:温度过高时触发警报。
    • Logger:记录温度事件到日志。
  • 关键流程:
  • 定义事件:使用 event 关键字声明一个委托类型的事件。
  • 订阅事件:通过 += 将方法添加到事件的委托链。
  • 触发事件:在特定条件下调用事件,执行所有订阅的方法。

代码实现

using System;// 1. 定义事件参数(传递温度数据)
public class TemperatureEventArgs : EventArgs
{public double Temperature { get; }public TemperatureEventArgs(double temperature){Temperature = temperature;}
}// 2. 发布者(Subject)
public class TemperatureMonitor
{// 声明事件(基于泛型 EventHandler<T> 委托)// EventHandler<T> 是 .NET 内置的泛型委托,定义形式为:  // delegate void EventHandler<TEventArgs>(object sender, TEventArgs e)public event EventHandler<TemperatureEventArgs> TemperatureExceeded;private double _currentTemperature;public double Threshold { get; set; } = 30.0;public void UpdateTemperature(double newTemperature){_currentTemperature = newTemperature;Console.WriteLine($"当前温度: {_currentTemperature}°C");// 触发条件:温度超过阈值if (_currentTemperature > Threshold){OnTemperatureExceeded(new TemperatureEventArgs(_currentTemperature));}}// 触发事件的方法(protected virtual 便于派生类扩展)protected virtual void OnTemperatureExceeded(TemperatureEventArgs e){// 线程安全:临时保存事件引用,避免多线程下订阅者被移除导致的空引用var handler = TemperatureExceeded;handler?.Invoke(this, e); // 等同于 if (handler != null) handler(this, e);}
}// 3. 订阅者(Observer)
public class AlertSystem
{public void HandleHighTemperature(object sender, TemperatureEventArgs e){Console.WriteLine($"警报!温度过高: {e.Temperature}°C");}
}public class Logger
{public void LogTemperatureEvent(object sender, TemperatureEventArgs e){Console.WriteLine($"[日志] 温度事件: {e.Temperature}°C");}
}// 4. 使用示例
class Program
{static void Main(){var monitor = new TemperatureMonitor();var alert = new AlertSystem();var logger = new Logger();// 订阅事件monitor.TemperatureExceeded += alert.HandleHighTemperature;monitor.TemperatureExceeded += logger.LogTemperatureEvent;// 模拟温度变化monitor.UpdateTemperature(25); // 不触发monitor.UpdateTemperature(32); // 触发事件monitor.UpdateTemperature(28); // 不触发monitor.UpdateTemperature(35); // 再次触发// 取消订阅monitor.TemperatureExceeded -= logger.LogTemperatureEvent;monitor.UpdateTemperature(40); // 仅触发警报}
}

输出结果

当前温度: 25°C
当前温度: 32°C
警报!温度过高: 32°C
[日志] 温度事件: 32°C
当前温度: 28°C
当前温度: 35°C
警报!温度过高: 35°C
[日志] 温度事件: 35°C
当前温度: 40°C
警报!温度过高: 40°C
  • 观察者模式
  • TemperatureMonitor 是 Subject,维护订阅者列表(通过 TemperatureExceeded 事件的委托链)。
  • AlertSystemLogger` 是 Observers,通过订阅事件实现解耦。

总结

  • C# 中的事件是基于委托的观察者模式实现,通过 event 关键字提供安全的订阅机制。它广泛用于:
  • GUI 编程(如按钮点击)
  • 异步通知等场景,是解耦代码的关键工具

使用观察者模式实现事件处理机制

以下是一个使用 Java 手动实现事件处理机制的完整示例,基于观察者模式自定义接口,支持线程安全的订阅、取消订阅和事件触发功能。


事件对象(Event

public class Event {private String message;private long timestamp;public Event(String message) {this.message = message;this.timestamp = System.currentTimeMillis();}public String getMessage() {return message;}public long getTimestamp() {return timestamp;}
}

事件监听器接口(EventListener

@FunctionalInterface
public interface EventListener {void onEvent(Event event);
}

事件发布者(EventPublisher

import java.util.concurrent.CopyOnWriteArrayList;
import java.util.List;public class EventPublisher {// 使用线程安全的集合存储监听器private final List<EventListener> listeners = new CopyOnWriteArrayList<>();// 订阅事件public void subscribe(EventListener listener) {listeners.add(listener);System.out.println("订阅成功: " + listener);}// 取消订阅public void unsubscribe(EventListener listener) {listeners.remove(listener);System.out.println("取消订阅: " + listener);}// 触发事件public void publishEvent(String message) {Event event = new Event(message);System.out.println("触发事件: " + event.getMessage());for (EventListener listener : listeners) {try {listener.onEvent(event);} catch (Exception e) {System.err.println("监听器处理异常: " + e.getMessage());}}}
}

定义具体监听器

public class Main {public static void main(String[] args) {EventPublisher publisher = new EventPublisher();// 监听器1:Lambda表达式实现EventListener listener1 = event -> System.out.printf("[Listener1] 收到事件: %s (时间: %d)%n",event.getMessage(), event.getTimestamp());// 监听器2:匿名类实现EventListener listener2 = new EventListener() {@Overridepublic void onEvent(Event event) {System.out.printf("[Listener2] 处理事件: %s%n", event.getMessage());}};// 订阅publisher.subscribe(listener1);publisher.subscribe(listener2);// 触发事件publisher.publishEvent("Hello World!");// 取消订阅listener2后再次触发publisher.unsubscribe(listener2);publisher.publishEvent("Another Message");}
}

输出结果

订阅成功: Main$$Lambda$1/0x0000000800b8a440@6d311334
订阅成功: Main$1@75bd9247
触发事件: Hello World!
[Listener1] 收到事件: Hello World! (时间: 1717500000000)
[Listener2] 处理事件: Hello World!
取消订阅: Main$1@75bd9247
触发事件: Another Message
[Listener1] 收到事件: Another Message (时间: 1717500001000)

关键设计解析

  • 3.1 线程安全
  • CopyOnWriteArrayList
    使用线程安全的集合存储监听器,确保在遍历过程中(如触发事件时)修改监听器列表不会导致 ConcurrentModificationException
  • 无锁设计
    添加/删除监听器时自动处理并发,无需显式加锁。
  • 观察者模式
  • Subject(主题)EventPublisher 维护监听器列表并提供订阅/取消订阅接口。
  • Observer(观察者)EventListener 接口的实现类,定义事件响应逻辑。

如果需要,可改为异步事件处理

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;public class AsyncEventPublisher extends EventPublisher {private final ExecutorService executor = Executors.newCachedThreadPool();@Overridepublic void publishEvent(String message) {Event event = new Event(message);System.out.println("触发事件: " + event.getMessage());for (EventListener listener : listeners) {executor.submit(() -> {try {listener.onEvent(event);} catch (Exception e) {System.err.println("监听器处理异常: " + e.getMessage());}});}}
}

相关文章:

设计模式 --- 观察者模式

设计模式 --- 观察者模式 什么是观察者模式观察者模式典型应用 --- C#中的事件使用观察者模式实现事件处理机制 什么是观察者模式 观察者模式&#xff08;Observer Pattern&#xff09;是一种行为型设计模式&#xff0c;用于在对象之间建立一对多的依赖关系。当一个对象&#x…...

组播网络构建:IGMP、PIM 原理及应用实践

IP组播基础 组播基本架构 组播IP地址 一个组播IP地址并不是表示具体的某台主机&#xff0c;而是一组主机的集合&#xff0c;主机声明加入某组播组即标识自己需要接收目的地址为该组播地址的数据IP组播常见模型分为ASM模型和SSM模型ASM&#xff1a;成员接收任意源组播数据&…...

Java常见的23种设计模式

Java常见的23种设计模式 大家好&#xff0c;我是钢板兽&#xff01; 本文将系统梳理 Java 的设计模式&#xff0c;涵盖创建型、结构型和行为型三大类&#xff0c;结合定义、原理、优点、应用场景、示例代码&#xff0c;帮助你初步了解常见的23种设计模式。 一、设计模式分类…...

兔单B细胞单抗制备服务

1.兔单B细胞技术原理 兔单B细胞技术是近年来新发展的一类快速制备单克隆抗体的技术&#xff0c;是一种通过分离和单克隆化兔子体内的B细胞来制备单一来源的高特异性抗体的方法。基于流式细胞分选技术进行单B细胞单抗制备&#xff0c;利用每个B细胞只含有一个功能性重链可变区D…...

MySQL基础 [六] - 内置函数+复合查询+表的内连和外连

内置函数一般要用select调用 内置函数 日期函数 current_date函数 current_date函数用于获取当前的日期。如下&#xff1a; current_time函数 current_time函数用于获取当前的时间。如下&#xff1a; now函数 now函数用于获取当前的日期时间。如下&#xff1a; date函数 dat…...

nginx路径匹配的优先级

在 Nginx 配置中&#xff0c;当请求 /portal/agent/sse 时&#xff0c;会匹配 location ~* /sse$ 规则&#xff0c;而不是 location /portal。原因如下&#xff1a; 匹配规则解析 location ~* /sse$ ~* 表示 不区分大小写的正则匹配/sse$ 表示以 /sse 结尾的路径匹配结果&#…...

tcp/ip攻击及防范

作为高防工程师&#xff0c;我每天拦截数以万计的恶意流量&#xff0c;其中TCP/IP协议层攻击是最隐蔽、最具破坏性的威胁之一。常见的攻击手法包括&#xff1a; 1. SYN Flood攻击&#xff1a;攻击者发送大量伪造的SYN包&#xff0c;耗尽服务器连接资源&#xff0c;导致正常用…...

2025年3月中国电子学会青少年软件编程(Python)等级考试试卷(一级)答案 + 解析

更多真题在线练习系统&#xff1a;历年真题在线练习系统 一、单选题 1、下列哪个软件不能运行 Python 程序&#xff1f;&#xff08; &#xff09; A、JupyterNotebook B、Pycharm C、原版的Scratch D、IDLE 正确答案&#xff1a;C 答案解析&#xff1a;本题考察的 Pyt…...

TreeMap 核心知识点与面试题解析

TreeMap 核心知识点与面试题解析 一、TreeMap 基础概念 TreeMap 是 Java 集合框架中基于 红黑树&#xff08;Red-Black Tree&#xff09; 实现的 Map&#xff0c;具有以下特点&#xff1a; 有序性&#xff1a;默认按 key 的自然顺序&#xff08;Comparable&#xff09;或自定…...

深入理解 DevOps 与 CI/CD:概念、流程及优势

在当今快速发展的数字化时代,软件开发和交付的速度与质量成为企业在激烈竞争中脱颖而出的关键因素。DevOps 和 CI/CD 作为现代软件开发领域的重要理念和实践,正深刻地改变着软件开发生命周期的运作方式。本文将深入探讨 DevOps 的概念,详细解析 CI/CD 的内涵、管道阶段以及实…...

Flutter BloC 架构入门指南

BLoC (Business Logic Component) 是 Flutter 中一种流行的状态管理架构&#xff0c;它可以帮助你将业务逻辑与 UI 分离&#xff0c;使代码更清晰、可测试性更强。 核心概念 1. BloC 的核心组件 Events&#xff1a;用户交互或系统事件&#xff08;如按钮点击、网络请求完成&…...

OpenHarmony-AI调研

OpenHarmony-AI调研 文章目录 OpenHarmony-AI调研前言一、当前版本部署组件二、AI架构1.mindspore-lite2.ai_engine3.neural_network_runtime4.intelligent_voice_framework5.HDI驱动 三、应用1.命令行以及web运行deepseek-r12.与deepseek通过语音进行交互3.物品识别4.人脸识别…...

zk基础—zk实现分布式功能

1.zk实现数据发布订阅 (1)发布订阅系统一般有推模式和拉模式 推模式&#xff1a;服务端主动将更新的数据发送给所有订阅的客户端。 拉模式&#xff1a;客户端主动发起请求来获取最新数据(定时轮询拉取)。 (2)zk采用了推拉相结合来实现发布订阅 首先客户端需要向服务端注册自己关…...

Tips:用proxy解决前后端分离项目中的跨域问题

在前后端分离项目中&#xff0c;"跨域问题"是浏览器基于同源策略&#xff08;Same-Origin Policy&#xff09;对跨域请求的安全限制。当你的前端&#xff08;如运行在 http://localhost:3000 &#xff09;和后端&#xff08;如运行在 http://localhost:8080 &#…...

JMeterPlugins-Standard-1.4.0 插件详解:安装、功能与使用指南

JMeterPlugins-Standard-1.4.0 是 Apache JMeter&#xff08;一款流行的开源负载和性能测试工具&#xff09;的插件包&#xff0c;它扩展了 JMeter 的功能&#xff0c;提供了更多监听器&#xff08;Listeners&#xff09;、采样器&#xff08;Samplers&#xff09;和辅助组件&a…...

JMeter 中,Token 和 Cookie 的区别及实际应用

在 JMeter 中,Token 和 Cookie 都是用于处理用户会话和身份验证的机制,但它们的 工作原理、存储方式 和 应用场景 有显著区别。以下是详细对比和实际应用指南: 1. 核心区别 特性Token (如 JWT、OAuth)Cookie存储位置通常存储在 HTTP 请求头(如 Authorization: Bearer <t…...

蓝桥杯真题——好数、R格式

目录 蓝桥杯2024年第十五届省赛真题-好数 【模拟题】 题目描述 输入格式 输出格式 样例输入 样例输出 提示 代码1&#xff1a;有两个案例过不了&#xff0c;超时 蓝桥杯2024年第十五届省赛真题-R 格式 【vector容器的使用】 题目描述 输入格式 输出格式 样例输入…...

JavaScript惰性加载优化实例

这是之前的一位朋友的酒桌之谈&#xff0c;他之前负责的一个电商项目&#xff0c;刚刚开发万&#xff0c;首页加载时间特别长&#xff0c;体验很差&#xff0c;所以就开始排查&#xff0c;发现是在首页一次性加载所有js导致的问题&#xff0c;这个问题在自己学习的时候并不明显…...

0_Pytorch中的张量操作

[引言]张量的概念 1.基本概念 张量是一个通用的多维数组&#xff0c;可以表示标量&#xff08;0 维&#xff09;、向量&#xff08;1 维&#xff09;、矩阵&#xff08;2 维&#xff09;以及更高维度的数据。张量是 PyTorch 中的核心数据结构&#xff0c;用于表示和操作数据。…...

Java面试43-常见的限流算法有哪些?

限流算法是一种系统保护策略&#xff0c;主要是避免在流量高峰导致系统被压垮&#xff0c;造成系统不可用的问题。 常见的限流算法有五种&#xff1a; 计数器限流&#xff0c;一般用在单一维度的访问频率限制上&#xff0c;比如短信验证码每隔60s只能发送一次&#xff0c;或者…...

牛客网:树的高度 ← 根节点为 0 号节点

【题目来源】 https://www.nowcoder.com/questionTerminal/4faa2d4849fa4627aa6d32a2e50b5b25 【题目描述】 现在有一棵合法的二叉树&#xff0c;树的节点都是用数字表示&#xff0c;现在给定这棵树上所有的父子关系&#xff0c;求这棵树的高度。 【输入格式】 输入的第一行表…...

Linux:进程程序替换execl

目录 引言 1.单进程版程序替换 2.程序替换原理 3.6种替换函数介绍 3.1 函数返回值 3.2 命名理解 3.3 环境变量参数 引言 用fork创建子进程后执行的是和父进程相同的程序(但有可能执行不同的代码分支)&#xff0c;我们所创建的所有的子进程&#xff0c;执行的代码&#x…...

⑩数据中心M-LAG 实战

一、配置指导自己去看今天操作的是M-LAG 基础实验 二、配置代码信息回顾 ### 1、配置 M-LAG 系统 MAC 地址<H3C>system-view[H3C]m-lag system-mac ?H-H-H MAC address2a7a-53ee-0100 Bridge MAC address[H3C]m-lag system-mac### 2、配置 M-LAG 系统编号…...

delphi idtcpserver 搭建tcp ,ssl协议服务端

如果想用indy idtcpserver实现tcp ssl,那么正是你需要的 首先生成证书: 2、windows生成pem证书 - 站着说话不腰疼 - 博客园 有证书后 idtcpserver 用的三个证书, IdServerIOHandlerSSLOpenSSL1.SSLOptions.CertFile = ca.crt IdServerIOHandlerSSLOpenSSL1.SSLOptions.…...

如何实现外观模式?

一、模式理解&#xff08;用快递驿站比喻&#xff09; 想象你网购了5件商品&#xff0c;分别来自不同快递公司。 外观模式就像小区门口的快递驿站&#xff0c;你不需要知道中通怎么分拣、顺丰怎么运输&#xff0c;只要到驿站报取件码就能拿到所有包裹。 在前端开发中&#xf…...

深入解析 Linux 文件系统权限:从基础到高级实践

引言 在 Linux 系统中&#xff0c;文件系统权限是保障数据安全和多用户协作的核心机制。想象这样一个场景&#xff1a; 你的服务器上有多个团队共享项目文件 财务数据必须严格保密&#xff0c;仅允许指定人员访问 开发团队需要共同编辑代码&#xff0c;但禁止随意删除他人文…...

GZ036区块链卷一 EtherStore合约漏洞详解

题目 pragma solidity >0.8.3;contract EtherStore {mapping(address > uint) public balances;function deposit() public payable {balances[msg.sender] msg.value;emit Balance(balances[msg.sender]);}function withdraw() public {uint bal balances[msg.sender…...

医药流通行业批发公司IT运维转型:Prometheus+Grafana监控Spring Boot 3应用实践

一、引言&#xff1a;医药流通行业IT运维挑战与工具换代需求 在医药流通行业批发领域&#xff0c;业务的核心在于供应链的高效运转、订单处理的精准及时以及库存管理的动态平衡。随着互联网医疗的兴起和电商平台的渗透&#xff0c;传统医药批发企业正加速向数字化、智能化转型…...

编程助手fitten code使用说明(超详细)(vscode)

这两年 AI 发展迅猛&#xff0c;作为开发人员&#xff0c;我们总是追求更快、更高效的工作方式&#xff0c;AI 的出现可以说改变了很多人的编程方式。 AI 对我们来说就是一个可靠的编程助手&#xff0c;给我们提供了实时的建议和解决方&#xff0c;无论是快速修复错误、提升代…...

金融大模型

FinGPT 数据集&#xff1a;https://github.com/AI4Finance-Foundation/FinGPT/tree/master/fingpt/FinGPT-v3 FinGPT v3 系列是在新闻和微博情绪分析数据集上使用 LoRA 方法进行微调的LLM&#xff0c;在大多数金融情绪分析数据集上取得了最佳分数。 FinGPT v3.1 使用 chatgl…...

【Pandas】pandas DataFrame infer_objects

Pandas2.2 DataFrame Conversion 方法描述DataFrame.astype(dtype[, copy, errors])用于将 DataFrame 中的数据转换为指定的数据类型DataFrame.convert_dtypes([infer_objects, …])用于将 DataFrame 中的数据类型转换为更合适的类型DataFrame.infer_objects([copy])用于尝试…...

011_异常、泛型和集合框架

异常、泛型和集合框架 异常Java的异常体系异常的作用 自定义异常异常的处理方案异常的两种处理方式 泛型泛型类泛型接口泛型方法、通配符和上下限泛型支持的类型 集合框架集合体系结构Collection Collection集合Collection的遍历方式认识并发修改异常问题解决并发修改异常问题的…...

QTSql全解析:从连接到查询的数据库集成指南

概览 与数据库的有效集成是确保数据管理效率和应用性能的关键&#xff0c;Qt框架就提供了强大的QtSql模块&#xff0c;使得开发者能够轻松地进行数据库操作&#xff0c;包括连接、查询执行以及结果处理等 一、引入QtSql模块 首先&#xff0c;需要在项目中引入QtSql模块&…...

docker快捷打包脚本(ai版)

直接进入主题&#xff1a; 用这个脚本前提是你本地可以拉镜像仓库的镜像&#xff0c;并且在 本地有了&#xff0c;然后将所有的镜像tag写在一个文件中&#xff0c;和下面docker_tags.txt 对应&#xff0c;文件叫什么&#xff0c;脚本里对应改什么&#xff0c;给小白说的 #!/bi…...

分布式防护节点秒级切换:实战配置与自动化运维

摘要&#xff1a;针对DDoS攻击导致节点瘫痪的问题&#xff0c;本文基于群联AI云防护的智能调度系统&#xff0c;详解如何实现节点健康检查、秒级切换与自动化容灾&#xff0c;并提供Ansible部署脚本。 一、分布式节点的核心价值 资源分散&#xff1a;攻击者难以同时击溃所有节…...

TBE(TVM的扩展)

算子 张量 一个张量只有一种数据类型 在内存中只能线性存储&#xff0c;最终形成一个长的一维数组 晟腾AI的数据格式 AIPP是对我们常见的数据格式转化成AI core支持的数据格式 广播机制 TVM TBE的第一种开发方式&#xff1a;DSL TBE的第二种开发方式&#xff1a;TVM TBE的第…...

Jenkins配置的JDK,Maven和Git

1. 前置 在配置前&#xff0c;我们需要先把JDK&#xff0c;Maven和Git安装到Jenkins的服务器上。 &#xff08;1&#xff09;需要进入容器内部&#xff0c;执行命令&#xff1a;docker exec -u root -it 容器号/容器名称&#xff08;2选1&#xff09; bash -- 容器名称 dock…...

核心案例 | 湖南汽车工程职业大学无人机操控与编队技术实验室

核心案例 | 湖南汽车工程职业大学无人机操控与编队技术实验室 为满足当今无人机行业应用需求&#xff0c;推动无人机技术的教育与实践深度融合&#xff0c;北京卓翼智能科技有限公司旗下品牌飞思实验室与湖南汽车工程职业大学强强联手&#xff0c;共同建设无人机操控与编队技术…...

【阻抗匹配】

自动匹配的实现&#xff1a; 检测反射信号&#xff1a;通过传感器&#xff08;如定向耦合器&#xff09;监测反射功率或驻波比&#xff08;SWR&#xff09;&#xff0c;判断是否失配。控制单元&#xff1a;利用微控制器或专用芯片&#xff08;如FPGA&#xff09;分析检测数据&a…...

micro常用快捷键

micro常用快捷键 以下是 micro 编辑器 的常用快捷键整理&#xff0c;按功能分类清晰&#xff0c;方便快速查阅&#xff1a; 1. 基础操作 快捷键功能​Ctrl S​保存文件​Ctrl Q​退出编辑器​Ctrl O​打开文件​Ctrl E​打开命令栏&#xff08;输入命令&#xff09;​Ctr…...

DNS域名解析服务

目录 DNS系统 DNS系统的作用 DNS系统的类型&#xff08;服务器分类&#xff09; 1. ‌递归解析器&#xff08;Recursive Resolver&#xff09;‌ 2. ‌根域名服务器&#xff08;Root Name Server&#xff09;‌ 3. ‌顶级域服务器&#xff08;TLD Name Server&#xff09;…...

Linux的目录结构

倒根树状结构 【注意】 / 表示根目录&#xff0c;相当于Windows的C盘 进入跟目录命令&#xff1a; cd / /bin&#xff1a;存放的系统命令或二进制文件&#xff0c;如&#xff1a;cd ls cp等 /sbin /usr/bin /dev&#xff1a;存放的设备节点文件 &#xff0c; 驱动文件 /…...

【Python】Python 100题 分类入门练习题 - 新手友好

Python 100题 分类入门练习题 - 新手友好篇 - 整合篇 一、数学问题题目1&#xff1a;组合数字题目2&#xff1a;利润计算题目3&#xff1a;完全平方数题目4&#xff1a;日期天数计算题目11&#xff1a;兔子繁殖问题题目18&#xff1a;数列求和题目19&#xff1a;完数判断题目21…...

Three.js 系列专题 7:性能优化与最佳实践

内容概述 随着 3D 场景复杂度的增加,性能优化变得至关重要。Three.js 项目可能因几何体数量、纹理大小或渲染设置而变慢。本专题将介绍减少 draw call、优化纹理和使用调试工具的最佳实践。 学习目标 学会减少 draw call 和几何体复杂度。掌握纹理压缩与内存管理。使用 Stat…...

特权FPGA之Johnson移位

完整代码&#xff1a; module johnson(clk,rst_n,led,sw1_n,sw2_n,sw3_n);input clk; //时钟信号&#xff0c;50MHz input rst_n; //复位信号&#xff0c;低电平有效 output[3:0] led; //LED控制&#xff0c;1--灭&#xf…...

聊聊 CSS

先补充一些概念 C/S&#xff08;客户端/服务器&#xff09;&#xff1a;要下载到本地才能用 需要安装、偶尔更新、不跨平台 B/S&#xff08;浏览器/服务器&#xff09;&#xff1a;在浏览器输入网址就可以使用 无需安装、无需更新、可跨平台 [!NOTE] B/S 架构优点如此之多&am…...

域名系统DNS

一 概述 域名系统DNS是互联网使用的命名系统&#xff0c;用来把便于人们使用的机器名称转换为IP地址&#xff0c;比如我们熟知的www.baidu.com,www.sina.com&#xff0c;这些域名的背后都对应着一个又一个的IP地址。由域名转换为IP的过程我们称为解析&#xff0c;解析的过程大…...

大模型ui设计SVG输出

你是一位资深 SVG 绘画设计师&#xff0c;现需根据以下产品需求创建SVG方案&#xff1a; 产品需求 约拍app 画板尺寸&#xff1a; 宽度&#xff1a;375px&#xff08;基于提供的HTML移动设计&#xff09;高度&#xff1a;812px&#xff08;iPhone X/XS 尺寸&#xff09; 配…...

利用securecrt的tftp服务器功能传递文件

日常经常能用到需要调测一些openwrt设备&#xff0c;要互相拷贝文件&#xff0c;没有开启ftp功能时&#xff0c;这时可以用到crt的tftp内置服务器功能&#xff0c;利用tftp功能传递文件。 配置方法&#xff1a; 打开设置→全局配置→终端→tftp配置设置c上内置tftp服务器时&a…...

基于STM32、HAL库的IP2736U快充协议芯片简介及驱动程序设计

一、简介: IP2736U是一款高性能的USB Type-C和Power Delivery(PD)控制器芯片,支持最新的USB PD 3.0规范。它具有以下特点: 支持USB Type-C和PD 3.0协议 内置MCU,可编程配置 支持多种供电角色(Source/Sink/DRP) 支持PPS可编程电源 支持多种快充协议(PD/QC/AFC/FCP/SCP等) I…...