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

java中的枚举

第1部分:引言

枚举在Java中的重要性

枚举在Java中扮演着至关重要的角色,它不仅提高了代码的可读性和可维护性,还增强了类型安全。枚举的使用可以避免使用魔法数字或散列常量,这些在代码中通常难以理解和维护。通过枚举,我们可以将一组相关的常量组织在一起,形成一个清晰的逻辑结构。

第2部分:枚举的属性和方法

枚举常量的属性

枚举常量可以拥有自己的属性,这些属性通常在枚举的构造函数中初始化。属性的使用增强了枚举的表达能力,使得每个枚举实例可以携带更多的信息。

public enum Planet {MERCURY(3.303e+23, 57.9),VENUS(4.869e+24, 243),EARTH(5.976e+24, 149.6),MARS(6.421e+23, 227.9),JUPITER(1.9e+27, 4.23);private final double mass; // 质量,单位:千克private final double radius; // 半径,单位:千米Planet(double mass, double radius) {this.mass = mass;this.radius = radius;}public double getMass() {return mass;}public double getRadius() {return radius;}
}
枚举的方法

枚举类型可以定义自己的方法,这些方法可以访问枚举常量的属性,执行特定的逻辑,或者返回计算结果。

public double getSurfaceGravity() {// 表面重力加速度公式:g = G * mass / radius^2final double G = 6.67300E-11;return G * mass / (radius * radius);
}
枚举的构造函数

枚举的构造函数是私有的,这意味着枚举常量只能在枚举体内被实例化。这保证了枚举常量是唯一的。

private Planet(double mass, double radius) {this.mass = mass;this.radius = radius;
}
枚举的values()方法

values()方法返回枚举类型的所有常量的数组。这个方法通常用于遍历枚举类型的所有常量。

for (Planet p : Planet.values()) {System.out.println(p.name() + " has a mass of " + p.getMass());
}
枚举的valueOf()方法

valueOf()方法接受一个字符串参数,并返回对应的枚举常量。如果字符串不匹配任何枚举常量,将抛出IllegalArgumentException

Planet earth = Planet.valueOf("EARTH");
System.out.println("The radius of " + earth.name() + " is " + earth.getRadius());
枚举与Java反射API

Java的反射API可以用于枚举类型,以获取枚举常量的名称、字段值、方法等信息。这对于编写需要动态操作枚举类型的应用程序非常有用。

for (Planet p : Planet.values()) {Method[] methods = p.getClass().getDeclaredMethods();for (Method method : methods) {if (Modifier.isPublic(method.getModifiers()) && !method.isSynthetic()) {try {System.out.println(p.name() + "." + method.getName() + "() = " + method.invoke(p));} catch (Exception e) {e.printStackTrace();}}}
}
枚举与Java注解

枚举类型可以像其他类一样使用注解。注解可以用于元数据的添加,例如,标记某个枚举常量为“已废弃”。

@Deprecated
public enum OldPlanet {PLUTO;
}
枚举的toString()方法

枚举常量默认的toString()方法返回枚举常量的名称。如果需要自定义返回值,可以重写toString()方法。

@Override
public String toString() {return "Planet{" +"name='" + name() + '\'' +", mass=" + mass +", radius=" + radius +'}';
}

第3部分:枚举与switch语句

简介

Java中的switch语句是一种控制流语句,用于基于不同的情况执行不同的代码块。在Java 7之前,switch语句只能用于基本数据类型(如int、char等),或者字符串。从Java 7开始,switch语句也可以用于枚举类型,这使得基于枚举的代码更加清晰和易于维护。

使用switch语句处理枚举

在枚举类型出现之前,开发者通常使用if-else语句或散列映射来处理一组固定的常量。枚举的出现,使得使用switch语句成为可能,这不仅使代码更加简洁,而且提高了可读性。

public enum TrafficSignal {GREEN, YELLOW, RED;
}public void reactToTrafficSignal(TrafficSignal signal) {switch (signal) {case GREEN:System.out.println("Go");break;case YELLOW:System.out.println("Slow down");break;case RED:System.out.println("Stop");break;}
}
switch语句的优势
  • 可读性switch语句的结构清晰,易于理解。
  • 维护性:当枚举类型中的常量发生变化时,IDE可以帮助开发者快速定位到所有使用该枚举的地方,进行相应的修改。
  • 性能:Java编译器可能会将switch语句优化为跳转表,从而提高执行效率。
枚举常量作为switch语句的表达式

除了使用枚举变量作为switch语句的控制表达式外,也可以直接使用枚举常量。

switch (TrafficSignal.GREEN) {case GREEN:System.out.println("Proceed with caution");break;// 其他情况可以省略,因为GREEN是唯一的入口点
}
枚举方法与switch语句的结合

枚举可以定义方法,这些方法可以与switch语句结合使用,实现更复杂的逻辑。

public enum Operation {PLUS {public double apply(double x, double y) { return x + y; }},MINUS {public double apply(double x, double y) { return x - y; }},TIMES {public double apply(double x, double y) { return x * y; }},DIVIDE {public double apply(double x, double y) {if (y != 0) return x / y;else throw new IllegalArgumentException("Division by zero.");}};public abstract double apply(double x, double y);
}public double performOperation(Operation op, double a, double b) {return op.apply(a, b);
}
switch语句与枚举的局限性

尽管switch语句与枚举的结合非常强大,但它也有一些局限性。例如,如果枚举常量很多,switch语句可能会变得非常长,难以维护。此外,如果需要基于多个条件进行判断,switch语句可能不如策略模式等设计模式灵活。

示例:模拟交通信号灯

假设我们需要模拟一个交通信号灯的控制系统,使用枚举和switch语句可以清晰地表达信号灯的状态变化。

public class TrafficLightController {private TrafficSignal signal = TrafficSignal.RED;public void changeSignal() {switch (signal) {case RED:signal = TrafficSignal.GREEN;System.out.println("The traffic light is now GREEN.");break;case GREEN:signal = TrafficSignal.YELLOW;System.out.println("The traffic light is now YELLOW.");break;case YELLOW:signal = TrafficSignal.RED;System.out.println("The traffic light is now RED.");break;}}
}

第4部分:枚举的迭代

枚举迭代简介

迭代枚举类型是Java中一种常见的操作,它允许开发者遍历枚举类型中的所有常量。Java为枚举类型提供了内置的迭代机制,使得遍历枚举变得异常简单和高效。

使用values()方法进行迭代

values()方法返回枚举类型的所有常量数组,可以用于传统的for循环迭代。

public enum Weekday {MONDAY, TUESDAY, WEDNESDAY, THURSDAY, FRIDAY;
}public void listWeekdays() {for (Weekday day : Weekday.values()) {System.out.println(day);}
}
使用for-each循环迭代枚举

除了使用values()方法外,Java的for-each循环可以直接迭代枚举类型。

for (Weekday day : Weekday.values()) {System.out.println(day);
}
枚举迭代的应用场景

枚举迭代在多种场景下都非常有用,例如配置管理、状态机实现、日志级别控制等。

示例:配置管理

假设有一个应用程序,需要根据不同的配置级别来调整日志记录的详细程度。

public enum LogLevel {DEBUG, INFO, WARN, ERROR;public boolean shouldLog(LogLevel level) {return compareTo(level) >= 0;}
}public class Logger {private LogLevel currentLevel = LogLevel.INFO;public void log(LogLevel level, String message) {if (currentLevel.shouldLog(level)) {System.out.println(level + ": " + message);}}
}
示例:状态机实现

使用枚举迭代可以方便地实现状态机的状态转换。

public enum State {INITIALIZING, RUNNING, PAUSED, STOPPED;public State next() {switch (this) {case INITIALIZING:return RUNNING;case RUNNING:return PAUSED;case PAUSED:return RUNNING;case STOPPED:return null;default:throw new IllegalStateException("Unknown state: " + this);}}
}public class StateMachine {private State currentState = State.INITIALIZING;public void nextState() {currentState = currentState.next();System.out.println("Transitioned to state: " + currentState);}
}
枚举迭代与Java 8的Stream API

Java 8引入了Stream API,它提供了一种声明式处理集合数据的方式。枚举类型也可以与Stream API结合使用,实现更高级的数据处理。

import java.util.stream.Stream;public void processWeekdays() {Stream.of(Weekday.values()).filter(Weekday::isAfterMonday).forEach(System.out::println);
}// 在Weekday枚举中添加一个方法
public boolean isAfterMonday() {return ordinal() > MONDAY.ordinal();
}
枚举迭代与反射

虽然不推荐在枚举中使用反射进行迭代,但在某些动态场景下,反射可以用来获取枚举类型的所有常量。

public void listWeekdaysUsingReflection() {Object[] days = Weekday.class.getEnumConstants();for (Object day : days) {System.out.println(day);}
}
枚举迭代的局限性

尽管枚举迭代非常强大,但它也有局限性。例如,迭代过程中不能修改枚举常量的列表,也不能在迭代过程中添加或删除枚举常量。

第5部分:枚举与单例模式

单例模式简介

单例模式是一种常用的软件设计模式,它确保一个类只有一个实例,并提供一个全局访问点。在Java中,实现单例模式有多种方法,但使用枚举来实现单例是最简单和最安全的方式之一。

使用枚举实现单例

Java语言规范保证每个枚举常量只会被实例化一次,这使得枚举成为实现单例模式的理想选择。

public enum DatabaseConnection {INSTANCE;private String connectionString;private DatabaseConnection() {// 初始化数据库连接字符串connectionString = "jdbc:mysql://localhost:3306/mydb";}public String getConnectionUrl() {return connectionString;}
}
枚举单例的优势
  • 线程安全:枚举实例的创建是线程安全的。
  • 序列化安全:枚举类型是序列化安全的,每个枚举常量在反序列化时都会返回枚举本身。
  • 防止反射攻击:枚举类型不允许通过反射创建枚举实例。
枚举单例的使用示例
public class DatabaseUtil {public static void printConnectionUrl() {System.out.println(DatabaseConnection.INSTANCE.getConnectionUrl());}
}
枚举单例与延迟初始化

虽然枚举单例在实例化时会立即初始化,但可以通过构造函数参数或方法来实现延迟初始化。

public enum Config {INSTANCE;private String configValue;private Config() {// 延迟加载配置值loadConfig();}private void loadConfig() {configValue = "Some configuration value loaded at runtime";}public String getConfigValue() {return configValue;}
}
枚举单例与多例模式

虽然枚举天然支持单例模式,但也可以扩展为支持多例模式,即每个枚举实例持有不同的状态。

public enum Counter {COUNTER1, COUNTER2, COUNTER3;private int count = 0;public void increment() {count++;}public int getCount() {return count;}
}
枚举单例与依赖注入

枚举单例可以作为依赖注入的实现方式之一,尤其是在需要全局访问点的场景中。

public enum DependencyInjector {INSTANCE;private SomeService service;private DependencyInjector() {service = new SomeServiceImpl();}public SomeService getService() {return service;}
}
枚举单例与Java 8的Optional类

枚举单例可以与Java 8的Optional类结合使用,提供更优雅的API。

public enum ResourceHolder {INSTANCE;private Resource resource;public Optional<Resource> getResource() {return Optional.ofNullable(resource);}public void setResource(Resource resource) {this.resource = resource;}
}
枚举单例的局限性

尽管枚举单例提供了许多优势,但它也有一些局限性,例如枚举类型不能被继承,这限制了某些设计模式的应用。

第6部分:枚举与Java集合框架

枚举与集合框架简介

Java集合框架是Java中用于存储和操作集合数据的一套丰富接口和类。枚举类型可以作为集合元素,与集合框架结合使用,实现高效的数据存储和操作。

枚举作为集合元素

由于枚举类型在Java中是单例的,它们可以安全地用作集合的元素,而不必担心重复或不一致的问题。

示例:使用枚举管理权限
public enum Permission {READ, WRITE, DELETE, ADMIN;
}public class User {private Set<Permission> permissions = new HashSet<>();public void grantPermission(Permission permission) {permissions.add(permission);}public void revokePermission(Permission permission) {permissions.remove(permission);}public boolean hasPermission(Permission permission) {return permissions.contains(permission);}
}
枚举集合的性能考量

由于枚举实例是固定的,枚举作为集合元素时,可以提供非常快速的查找、插入和删除操作。

示例:枚举集合的性能测试
public class EnumSetPerformanceTest {public static void main(String[] args) {EnumSet<Permission> permissions = EnumSet.noneOf(Permission.class);long startTime = System.nanoTime();for (int i = 0; i < 1000000; i++) {permissions.add(Permission.ADMIN);}long endTime = System.nanoTime();System.out.println("Time taken: " + (endTime - startTime) + " ns");}
}
枚举与不可变集合

枚举的不变性使得它们非常适合用作不可变集合的元素,这样可以确保集合的状态不会因为外部修改而改变。

示例:创建不可变的权限集合
public class ImmutablePermissions {private final Set<Permission> permissions;public ImmutablePermissions(Set<Permission> permissions) {this.permissions = Collections.unmodifiableSet(new HashSet<>(permissions));}public Set<Permission> getPermissions() {return permissions;}
}
枚举与Java 8的Stream API

结合Java 8的Stream API,枚举可以用于创建更声明式的数据处理流程。

示例:使用Stream API处理权限
public class PermissionStreamProcessor {public static void main(String[] args) {List<Permission> permissions = Arrays.asList(Permission.values());permissions.stream().filter(Permission::isDangerous).forEach(p -> System.out.println("Permission granted: " + p));}
}// 在Permission枚举中添加一个方法
public boolean isDangerous() {return this == Permission.ADMIN || this == Permission.DELETE;
}
枚举与自定义集合类

开发者可以创建自定义的集合类,使用枚举类型作为元素,以满足特定的需求。

示例:自定义枚举集合类
public class EnumMap<K extends Enum<K>, V> {private final Map<K, V> map = new HashMap<>();public void put(K key, V value) {map.put(key, value);}public V get(K key) {return map.get(key);}
}
枚举与集合的序列化

枚举类型是序列化安全的,这意味着枚举集合也可以安全地进行序列化和反序列化。

示例:序列化枚举集合
public class SerializableEnumSet {private EnumSet<Permission> permissions;public SerializableEnumSet(EnumSet<Permission> permissions) {this.permissions = permissions;}private Object readResolve() {return EnumSet.copyOf(permissions);}
}

欢迎关注VX
在这里插入图片描述

相关文章:

java中的枚举

第1部分&#xff1a;引言 枚举在Java中的重要性 枚举在Java中扮演着至关重要的角色&#xff0c;它不仅提高了代码的可读性和可维护性&#xff0c;还增强了类型安全。枚举的使用可以避免使用魔法数字或散列常量&#xff0c;这些在代码中通常难以理解和维护。通过枚举&#xff…...

各种开发语言运行时占用内存情况比较

随着科技的发展&#xff0c;编程语言种类繁多&#xff0c;不同的编程语言在运行时的内存占用情况各不相同。了解这些差异对于开发者选择合适的编程语言尤为重要。本文将讨论几种主流编程语言在运行时的内存占用情况&#xff0c;包括C、C、Java、Python和Go等。 1. C语言 内存…...

【基础知识10】label与input标签

label标签说明 HTML元素表示用户界面中某个元素的说明 将一个和一个元素相关联主要有这些优点&#xff1a; 标签文本不仅与其相应的文本输入元素在视觉上相关联&#xff0c;程序中也是如此。这意味着&#xff0c;当用户聚焦到这个表单输入元素时&#xff0c;屏幕阅读器可以读…...

【SDV让汽车架构“和而不同”】

昔日以“排气管数量”和“发动机动力”为骄傲的荣耀已然成为过往。在这个崭新的时代&#xff0c;特斯拉、理想、蔚来、小鹏、零跑等新兴的汽车制造商纷纷推出了搭载可交互大屏、实现万物互联、软件功能持续更新的新车型&#xff0c;它们被誉为“车轮上的智能手机”。同时&#…...

面试经验分享 | 驻场安全服务工程师面试

所面试的公司&#xff1a;某安全厂商 所在城市&#xff1a;浙江宁波 面试职位&#xff1a;驻场安全服务工程师 面试官的问题&#xff1a; 1、信息收集如何处理子域名爆破的泛解析问题&#xff1f; 泛域名解析是&#xff1a;*.域名解析到同一IP。域名解析是&#xff1a;子域…...

SpringBoot 学习笔记

文章目录 SpringBoot1 SpringBoot 的纯注解配置&#xff08;了解&#xff09;1.1 环境搭建1.1.1 jdbc配置1.1.2 mybatis配置1.1.3 transactional配置1.1.4 service配置1.1.5 springmvc配置1.1.6 servlet配置1.1.7 存在的问题 1.2 新注解说明1.2.1 Configuration1.2.2 Component…...

Android 13 为应用创建快捷方式

参考 developer.android.google.cn 创建快捷方式 来自官网的说明&#xff1a; 静态快捷方式 &#xff1a;最适合在用户与应用互动的整个生命周期内使用一致结构链接到内容的应用。由于大多数启动器一次仅显示四个快捷方式&#xff0c;因此静态快捷方式有助于以一致的方式执行…...

PTA—C语言期末复习(选择题)

1. 按照标识符的要求&#xff0c;&#xff08;A&#xff09;不能组成标识符。 A.连接符 B.下划线 C.大小写字母 D.数字字符 在大多数编程语言中&#xff0c;标识符通常由字母&#xff08;包括大写和小写&#xff09;、数字和下划线组成&#xff0c;但不能以数字开头&#xff0c…...

基于STM32的智能家用空气净化系统

目录 引言环境准备智能家用空气净化系统基础代码实现&#xff1a;实现智能家用空气净化系统 4.1 数据采集模块4.2 数据处理与分析4.3 控制系统实现4.4 用户界面与数据可视化应用场景&#xff1a;空气净化管理与优化问题解决方案与优化收尾与总结 1. 引言 智能家用空气净化系…...

计算机图形学入门18:阴影映射

1.前言 前面几篇关于光栅化的文章中介绍了如何计算物体表面的光照&#xff0c;但是着色并不会进行阴影的计算&#xff0c;阴影需要单独进行处理&#xff0c;目前最常用的阴影计算技术之一就是Shadow Mapping技术&#xff0c;也就是俗称的阴影映射技术。 2.阴影映射 Shadow Map…...

电机应用相关名词介绍

1.电机转速 定义&#xff1a;电机转速指电机工作时旋转的速度&#xff0c;是衡量电机性能的重要指标之一。 单位&#xff1a; 每分钟转数&#xff08;RPM&#xff09;&#xff1a;即Revolutions Per Minute&#xff0c;表示电机每分钟旋转的圈数。 每秒转数&#xff08;RPS…...

哈尔滨等保测评解读

哈尔滨的信息系统安全等级保护测评&#xff08;简称“等保测评”&#xff09;是中国网络安全法规的一部分&#xff0c;旨在确保关键信息基础设施和其他重要信息系统的安全。下面是对哈尔滨等保测评的解读&#xff1a; 测评目的 等保测评的主要目的是评估信息系统是否满足国家规…...

python接口自动化的脚本

使用Requests库进行GET请求 Requests是Python中最常用的HTTP库,用于发送HTTP请求。下面是一个简单的GET请求示例,用于从API获取数据。 import requests url = "https://api.example.com/data" response = requests.get(url) if response.status_code == 200:prin…...

pdf转换成cad,这几个cad转换小妙招快码住!

在数字设计领域&#xff0c;PDF&#xff08;Portable Document Format&#xff09;和CAD&#xff08;Computer-Aided Design&#xff09;文件格式各有其独特之处。PDF常用于文件共享和打印&#xff0c;而CAD则是工程师和设计师们进行精确绘图和建模的必备工具。然而&#xff0c…...

计算机组成原理——系统总线

题目:计算机使用总线结构便于增减外设,同时__C____。 A.减少了信息传送量 B.提高了信息传输速度 C.减少了信息传输线的条数 1. 总线的分类 1.1. 片内总线 芯片内部的总线 在CPU芯片内部,寄存器与寄存器之间、寄存器与逻辑单元ALU之间 1.1.1. 数据总线 双向传输总线 数…...

2024年6月大众点评广州餐饮店铺POI分析20万家

2024年6月大众点评广州餐饮店铺POI共有199175家 店铺POI点位示例&#xff1a; 店铺id k9uiFADtAvs9EdPC 店铺名称 点都德(聚福楼店) 十分制服务评分 8.6 十分制环境评分 8.3 十分制划算评分 8.5 人均价格 77 评价数量 41673 店铺地址 惠福东路470号(富临食府对面) 大…...

【最佳实践】前端如何搭建自己的cli命令行工具,让自己编码的时候如虎添翼

作为前端开发人员&#xff0c;搭建自己的前端CLI工具是一个有趣且有意义的事情。以下是一篇详细的教程&#xff0c;包括使用场景和案例。 使用场景 假设你是一个前端团队的一员&#xff0c;需要频繁地在不同的项目中执行一些标准化的任务&#xff0c;比如&#xff1a; 根据模…...

未来一周比特币价格及数字货币市场预测

荷月的比特币市场就像过山车一样&#xff0c;仅仅六月下旬就跌去-12%&#xff0c;本周更是暴跌-6%&#xff0c;至 58,378美元。在这种市场表现&#xff0c;应有的踩踏如期而至。德国政府今日宣布再出售750 比特币的行为继续打击多头&#xff0c;但是小编认为这恰恰预示着市场可…...

Qt Quick 教程(二)

文章目录 今天分析一段代码1. 注册单例类型2. 注册普通QML类型3. 注册C++类型到Qt元对象系统4.总结,具体解释5.如何在QML中使用这些注册的类型参考今天分析一段代码 // Register typesqmlRegisterSingletonType(QUrl("qrc:/StyleSheet.qml"), "Librum.style&qu…...

10个实用的Python编程实例,助你快速掌握Python技巧!

作为一门简洁易学且强大的编程语言&#xff0c;Python广泛应用于各个领域。本文将向大家介绍10个实用的Python编程实例&#xff0c;通过详细的实例代码帮助读者快速掌握Python的基础知识和常用技巧。 1. 计算阶乘 def factorial(n):if n 0:return 1else:return n * factorial…...

Docker 离线安装指南

参考文章 1、确认操作系统类型及内核版本 Docker依赖于Linux内核的一些特性&#xff0c;不同版本的Docker对内核版本有不同要求。例如&#xff0c;Docker 17.06及之后的版本通常需要Linux内核3.10及以上版本&#xff0c;Docker17.09及更高版本对应Linux内核4.9.x及更高版本。…...

java调用dll出现unsatisfiedLinkError以及JNA和JNI的区别

UnsatisfiedLinkError 在对接硬件设备中&#xff0c;我们会遇到使用 java 调用 dll文件 的情况&#xff0c;此时大概率出现UnsatisfiedLinkError链接错误&#xff0c;原因可能有如下几种 类名错误包名错误方法名参数错误使用 JNI 协议调用&#xff0c;结果 dll 未实现 JNI 协…...

理解 MCP 工作流:使用 Ollama 和 LangChain 构建本地 MCP 客户端

&#x1f31f; 什么是 MCP&#xff1f; 模型控制协议 (MCP) 是一种创新的协议&#xff0c;旨在无缝连接 AI 模型与应用程序。 MCP 是一个开源协议&#xff0c;它标准化了我们的 LLM 应用程序连接所需工具和数据源并与之协作的方式。 可以把它想象成你的 AI 模型 和想要使用它…...

LeetCode - 394. 字符串解码

题目 394. 字符串解码 - 力扣&#xff08;LeetCode&#xff09; 思路 使用两个栈&#xff1a;一个存储重复次数&#xff0c;一个存储字符串 遍历输入字符串&#xff1a; 数字处理&#xff1a;遇到数字时&#xff0c;累积计算重复次数左括号处理&#xff1a;保存当前状态&a…...

蓝桥杯 2024 15届国赛 A组 儿童节快乐

P10576 [蓝桥杯 2024 国 A] 儿童节快乐 题目描述 五彩斑斓的气球在蓝天下悠然飘荡&#xff0c;轻快的音乐在耳边持续回荡&#xff0c;小朋友们手牵着手一同畅快欢笑。在这样一片安乐祥和的氛围下&#xff0c;六一来了。 今天是六一儿童节&#xff0c;小蓝老师为了让大家在节…...

CMake 从 GitHub 下载第三方库并使用

有时我们希望直接使用 GitHub 上的开源库,而不想手动下载、编译和安装。 可以利用 CMake 提供的 FetchContent 模块来实现自动下载、构建和链接第三方库。 FetchContent 命令官方文档✅ 示例代码 我们将以 fmt 这个流行的格式化库为例,演示如何: 使用 FetchContent 从 GitH…...

学校时钟系统,标准考场时钟系统,AI亮相2025高考,赛思时钟系统为教育公平筑起“精准防线”

2025年#高考 将在近日拉开帷幕&#xff0c;#AI 监考一度冲上热搜。当AI深度融入高考&#xff0c;#时间同步 不再是辅助功能&#xff0c;而是决定AI监考系统成败的“生命线”。 AI亮相2025高考&#xff0c;40种异常行为0.5秒精准识别 2025年高考即将拉开帷幕&#xff0c;江西、…...

【Redis】笔记|第8节|大厂高并发缓存架构实战与优化

缓存架构 代码结构 代码详情 功能点&#xff1a; 多级缓存&#xff0c;先查本地缓存&#xff0c;再查Redis&#xff0c;最后才查数据库热点数据重建逻辑使用分布式锁&#xff0c;二次查询更新缓存采用读写锁提升性能采用Redis的发布订阅机制通知所有实例更新本地缓存适用读多…...

MinIO Docker 部署:仅开放一个端口

MinIO Docker 部署:仅开放一个端口 在实际的服务器部署中,出于安全和管理的考虑,我们可能只能开放一个端口。MinIO 是一个高性能的对象存储服务,支持 Docker 部署,但默认情况下它需要两个端口:一个是 API 端口(用于存储和访问数据),另一个是控制台端口(用于管理界面…...

Matlab实现任意伪彩色图像可视化显示

Matlab实现任意伪彩色图像可视化显示 1、灰度原始图像2、RGB彩色原始图像 在科研研究中&#xff0c;如何展示好看的实验结果图像非常重要&#xff01;&#xff01;&#xff01; 1、灰度原始图像 灰度图像每个像素点只有一个数值&#xff0c;代表该点的​​亮度&#xff08;或…...