204、RabbitMQ 之 使用 topic 类型的 Exchange 实现通配符路由

news2025/2/27 2:38:38

目录

  • ★ 使用topic实现通配符路由
  • 代码演示
  • topic通配符类型的Exchange代码演示:
    • ConstantUtil
    • ConnectionUtil
    • Producer
    • Consumer01
    • 执行结果
      • 生产者
      • 消费者01
      • 消费者02
  • 完整代码:
    • ConstantUtil
    • ConnectionUtil
    • Producer
    • Consumer01
    • Consumer02
    • pom.xml

★ 使用topic实现通配符路由

▲ topic类型的Exchange支持在路由key中使用通配符,路由key一般由一个或者多个单词组成,多个单词之间以“.”分割。

通配符支持星号(*)和井号(#):

 *:匹配一个单词。
 #:匹配零个或多个单词。

Q1绑定的路由key模式为*.crazyit.*,
因此它可以匹配www.crazyit.org,www.crazyit.cn、edu.crazyit.org等路由key。

Q2绑定了两个key模式,其中*.org可以匹配crazyit.org、fkjava.org等路由key,
但不能匹配www.crazyit.org、www.fkjava.org等(*只能匹配一个单词);
而edu.#则可匹配edu.crazyit.org、edu.fkjava.org、edu.fkjava、edu.org等(#可匹配多个单词)。

在这里插入图片描述

代码演示

需求如图:演示通配符

Exchange绑定queue的带通配符的key:
ROUTING_PATTERNS = {"*.crazyit.*", "*.org", "edu.#"};

发送消息到Exchange的路由key:
ROUTING_KEYS = {  "www.crazyit.org" ,  "www.crazyit.cn" , "edu.crazyit.org" , 
                  "crazyit.org"  ,      "fkjava.org" ,   "edu.crazyit.org" , 
                   "edu.fkjava"   ,     "edu.org"};


exchange 和 Q1 绑定的*.crazyit.*,符合的路由key有: 
    "www.crazyit.org"     "www.crazyit.cn"    "edu.crazyit.org"
    匹配到的key是3 个
    
exchange 和 Q2 绑定的 *.org"  和  "edu.#"  ,符合的路由key有: 
   *.org"  -->  "crazyit.org"  ,   "fkjava.org" ,    "edu.org"
   "edu.#" -->  "edu.crazyit.org" , "edu.crazyit.org"  , "edu.fkjava" ,  "edu.org"
   因为 匹配的key中有两个 "edu.org"  , 所以最终匹配到的key 是6个。

如图:
在这里插入图片描述

topic通配符类型的Exchange代码演示:

ConstantUtil

1、先设置一些常量
在这里插入图片描述

ConnectionUtil

2、RabbitMQ的相关连接
在这里插入图片描述

Producer

3、重点是消息生产者

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

Consumer01

消费者没啥好说的,两个消费者除了指定消费哪个消息队列不同外,其他代码都一样。
声明消息队列,
生产者和消费者声明消息队列的作用是一样的。
都是为了防止先启动消费者或者先启动生产者时,
对应的消息队列还没创建而导致消息被丢弃的问题。
个人理解:一般都是生产者需要声明消息队列,
消费者声明消息队列的影响不大
在这里插入图片描述
在这里插入图片描述

执行结果

与期望值一致

生产者

在这里插入图片描述

在这里插入图片描述

消费者01

    exchange 和 Q1 绑定的*.crazyit.*,符合的路由key有: 
    "www.crazyit.org"     "www.crazyit.cn"    "edu.crazyit.org"
    匹配到的key是3 个

在这里插入图片描述

消费者02

   exchange 和 Q2 绑定的 *.org"  和  "edu.#"  ,符合的路由key有: 
   *.org"  -->  "crazyit.org"  ,   "fkjava.org" ,    "edu.org"
   "edu.#" -->  "edu.crazyit.org" , "edu.crazyit.org"  , "edu.fkjava" ,  "edu.org"
   因为 匹配的key中有两个 "edu.org"  , 所以最终匹配到的key 是6个。

在这里插入图片描述




生产者或消费者声明 Exchagne的作用解释:
在这里插入图片描述

完整代码:

ConstantUtil

package cn.ljh.rabbitmq.util;

//常量
public class ConstantUtil
{
    // ------------topic类型的Exchange,需要的相关常量----------
    public final static String QUEUET01 = "qt_01";
    public final static String QUEUET02 = "qt_02";

    // topic 通配符类型的 Exchange
    public static final String EXCHANGE_NAME_TOPIC = "myex03.topic";

    // Exchange 绑定 Queue 队列的路由key  ,通配符类型      *:匹配一个单词。#:匹配零个或多个单词。
    public static final String[] ROUTING_TOPIC_PATTERNS = {"*.crazyit.*", "*.org", "edu.#"};

    // 生产者发送消息给Excahnge携带的路由key
    public static final String[] ROUTING_TOPIC_KEYS = { "www.crazyit.org", "www.crazyit.cn",
            "edu.crazyit.org", "crazyit.org", "fkjava.org", "edu.fkjava.org", "edu.fkjava", "edu.org"};

    //-------------------------------------------------------

    // 消息队列的名称
    public final static String QUEUE01 = "queue_01";
    public final static String QUEUE02 = "queue_02";
    // Exchange的名称
    public static final String EXCHANGE_NAME = "myex02.direct";
    // 三个路由key定义成一个数组的名称
    public static final String[] ROUTING_KEYS = {"info", "error", "warning"};

}

ConnectionUtil

package cn.ljh.rabbitmq.util;

import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;

import java.io.IOException;
import java.util.concurrent.TimeoutException;

//连接工具
public class ConnectionUtil
{
    //获取连接的方法
    public static Connection getConnection() throws IOException, TimeoutException
    {
        //创建连接工厂----这个ConnectionFactory源码可以看出有构造器,所以直接new一个出来
        ConnectionFactory connectionFactory =  new ConnectionFactory();
        //设置连接信息
        connectionFactory.setHost("localhost");
        connectionFactory.setPort(5672);
        connectionFactory.setUsername("ljh");
        connectionFactory.setPassword("123456");
        connectionFactory.setVirtualHost("/"); //连接虚拟主机
        //从连接工厂获取连接
        Connection connection = connectionFactory.newConnection();
        //返回连接
        return connection;
    }
}

Producer

package cn.ljh.rabbitmq.producer;

import cn.ljh.rabbitmq.util.ConnectionUtil;
import cn.ljh.rabbitmq.util.ConstantUtil;
import com.rabbitmq.client.BuiltinExchangeType;
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;

import java.io.IOException;
import java.nio.charset.StandardCharsets;
import java.util.concurrent.TimeoutException;

//消息生产者--使用 topic 类型的exchange------就是通配符
public class Producer
{
    public static void main(String[] args) throws IOException, TimeoutException
    {
        //1、创建连接
        Connection conn = ConnectionUtil.getConnection();
        //2、通过Connection获取Channel。
        Channel channel = conn.createChannel();

        //3、调用exchangeDeclare()方法声明Exchange,--------调用queueDeclare()方法声明队列,并完成队列与Exchange的绑定
        channel.exchangeDeclare(ConstantUtil.EXCHANGE_NAME_TOPIC,/* Exchange名字 */
                BuiltinExchangeType.TOPIC,/* Exchange 类型--通配符 */
                true,/* 是否持久化 */
                false,/* 是否自动栅除 */
                false,/* 是否为内部的 Exchange */
                null /* 指定 Exchange 的额外属性 */
        );


        //调用queueDeclare()方法声明队列----声明多个消息队列------声明第1个消息队列---------路由key是 通配符 *.crazyit.*
        channel.queueDeclare(ConstantUtil.QUEUET01, true, false, false, null);


        //把 Exchange 和 Queue 绑定起来,绑定第一个消息队列,路由key是通配符
        channel.queueBind(ConstantUtil.QUEUET01, ConstantUtil.EXCHANGE_NAME_TOPIC,
                ConstantUtil.ROUTING_TOPIC_PATTERNS[0], /* exchange类型是 topic,这里指定路由key --> *.crazyit.*/
                null /* 指定 Exchange 的额外属性 */);

        //声明第2个消息队列--------这个exchange绑定这个queue,绑定了2个路由key---通配符: "*.org", "edu.#"
        channel.queueDeclare(ConstantUtil.QUEUET02, true, false, false, null);

        //用循环为第2个消息队列绑定2个路由key
        for (int i = 1; i < ConstantUtil.ROUTING_TOPIC_PATTERNS.length; i++)
        {
            //把 Exchange 和 Queue 绑定起来,绑定第2个消息队列
            channel.queueBind(
                    ConstantUtil.QUEUET02,
                    ConstantUtil.EXCHANGE_NAME_TOPIC,
                    ConstantUtil.ROUTING_TOPIC_PATTERNS[i]  /* 循环绑定路由key */,
                    null  /* 指定 Exchange 的额外属性 */);
        }


        //有几个路由key,生产者就发送几条消息
        for (int i = 0; i < ConstantUtil.ROUTING_TOPIC_KEYS.length; i++)
        {
            //获取路由key,用于下面动态指定路由key的代码简洁点
            String routingKey = ConstantUtil.ROUTING_TOPIC_KEYS[i];

            //要发送的消息
            String message = "生产者发送的第【 " + (i+1) + " 】条消息的内容";

            //4、调用Channel 的 basicPublish() 方法发送消息
            channel.basicPublish(
                    ConstantUtil.EXCHANGE_NAME_TOPIC /* 指定向这个Exchange发送消息 */,
                    routingKey /* 动态指定路由key */,
                    null /*指定额外的消息的属性*/,
                    message.getBytes(StandardCharsets.UTF_8)/*消息体必须是字节数组类型-->byte[]*/
            );
            System.out.println("生产者发送【 " + (i+1) + " 】条消息完成,发送到Exchange的路由key是:"+routingKey);
        }
        //5、关闭资源
        //关闭通道
        channel.close();
        //关闭连接
        conn.close();
    }
}

Consumer01

package cn.ljh.rabbitmq.consumer;

import cn.ljh.rabbitmq.util.ConnectionUtil;
import cn.ljh.rabbitmq.util.ConstantUtil;
import com.rabbitmq.client.*;

import java.io.IOException;
import java.util.concurrent.TimeoutException;
// 使用 RabbitMQ Java Client 开发 消息消费者 的大致步骤如下:
//(1)创建ConnectionFactory连接工厂,设置连接信息,再通过ConnectionFactory获取Connection连接。
//(2)通过Connection获取Channel。
//(3)根据需要、调用Channel的queueDeclare()方法声明队列,  Declare:声明、宣布
//    如果声明的队列已存在,该方法直接获取已有的队列;如果声明的队列还不存在,该方法将会创建新的队列。
//(4)调用Channel 的 basicConsume()方法开始处理消息,调用该方法时需要传入一个Consumer参数,该参数相当于JMS中的消息监听器。

//消息消费者1
public class Consumer01
{

    public static void main(String[] args) throws IOException, TimeoutException
    {
        //1、创建连接工厂,设置连接信息,然后再通过连接工厂获取连接
        Connection conn = ConnectionUtil.getConnection();

        //2、通过Connection获取Channel 消息通道
        Channel channel = conn.createChannel();

        //3、调用 Channel 的 queueDeclare() 方法声明队列,
        //   如果声明的队列已存在,该方法直接获取已有的队列;如果声明的队列还不存在,该方法将会创建新的队列
        channel.queueDeclare(ConstantUtil.QUEUET01, /* 声明的队列名 */
                true,    /* 消息队列是否持久化 */
                false,  /* 是否只允许该消息消费者消费该队列的消息,独占 */
                false, /* 是否自动删除 */
                null   /* 指定消息队列额外的属性 */);


        //4、调用Channel 的 basicConsume()方法开始处理消费消息
        channel.basicConsume(
                ConstantUtil.QUEUET01 /*消费这个消费队列里面的消息*/,
                true /*消息的确认模式:是否自动确认该消息已经被消费完成并返回确认消息给消息队列*/,
                new DefaultConsumer(channel)
                {
                    //处理消息:当这个消息队列收到消息的时候,这个方法就会被触发。重写这个方法:
                    @Override
                    public void handleDelivery(String consumerTag,
                                               Envelope envelope /*消息所在的信封,存放消息的exchange、路由key这些*/,
                                               AMQP.BasicProperties properties /*消息的那些属性*/,
                                               byte[] body /*body:消息的消息体*/) throws IOException
                    {
                        //把消息体中的消息拿出来
                        String message = new String(body, "UTF-8");
                        //printf:格式化输出函数   %s:输出字符串  %n:换行
                        System.err.printf("P2PConsumer收到来自Exchange为【%s】、路由key为【%s】的消息,消息内容为%s%n",
                                envelope.getExchange(),envelope.getRoutingKey(),message);

                    }
                }
        );
    }
}

Consumer02

package cn.ljh.rabbitmq.consumer;

import cn.ljh.rabbitmq.util.ConnectionUtil;
import cn.ljh.rabbitmq.util.ConstantUtil;
import com.rabbitmq.client.*;

import java.io.IOException;
import java.util.concurrent.TimeoutException;

//消息消费者2
public class Consumer02
{
    public static void main(String[] args) throws IOException, TimeoutException
    {
        //1、创建连接工厂,设置连接信息,然后再通过连接工厂获取连接
        Connection conn = ConnectionUtil.getConnection();

        //2、通过Connection获取Channel 消息通道
        Channel channel = conn.createChannel();

        //3、调用 Channel 的 queueDeclare() 方法声明队列,
        //   如果声明的队列已存在,该方法直接获取已有的队列;如果声明的队列还不存在,该方法将会创建新的队列
        channel.queueDeclare(ConstantUtil.QUEUET02, /* 声明的队列名 */
                true,    /* 消息队列是否持久化 */
                false,  /* 是否只允许该消息消费者消费该队列的消息,独占 */
                false, /* 是否自动删除 */
                null   /* 指定消息队列额外的属性 */);

        //4、调用Channel 的 basicConsume()方法开始处理消费消息
        channel.basicConsume(
                ConstantUtil.QUEUET02 /*消费这个名字的消费队列里面的消息*/,
                true/*消息的确认模式:是否自动确认该消息已经被消费完成并返回确认消息给消息队列*/,
                new DefaultConsumer(channel)
                {
                    //处理消息:当这个消息队列收到消息的时候,这个方法就会被触发。重写这个方法:
                    @Override
                    public void handleDelivery(String consumerTag,
                                               Envelope envelope /*消息所在的信封,存放消息的exchange、路由key这些*/,
                                               AMQP.BasicProperties properties /*消息的那些属性*/,
                                               byte[] body /*body:消息的消息体*/) throws IOException
                    {
                        //把消息体中的消息拿出来
                        String message = new String(body, "UTF-8");
                        //printf:格式化输出函数   %s:输出字符串  %n:换行
                        System.err.printf("P2PConsumer收到来自Exchange为【%s】、路由key为【%s】的消息,消息内容为%s%n",
                                envelope.getExchange(),envelope.getRoutingKey(),message);
                    }
                }
        );
    }


}

pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>cn.ljh</groupId>
    <artifactId>topic</artifactId>
    <version>1.0.0</version>
    <name>topic</name>

    <!--  属性  -->
    <properties>
        <maven.compiler.source>11</maven.compiler.source>
        <maven.compiler.target>11</maven.compiler.target>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <java.version>11</java.version>
    </properties>

    <!--  依赖  -->
    <dependencies>
        <!-- RabbitMQ 的依赖库 -->
        <dependency>
            <groupId>com.rabbitmq</groupId>
            <artifactId>amqp-client</artifactId>
            <version>5.13.0</version>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.16</version>
            <scope>compile</scope>
        </dependency>

    </dependencies>


</project>

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

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

相关文章

Linux系统移植框架简介

一、系统移植简介 系统移植就是给开发板安装一个linux系统。需要从官方下载u-boot源码&#xff0c;linux内核源码&#xff0c;根文件系统的源码&#xff0c;对源码进行配置和编译&#xff0c;生成对应的源码的镜像文件&#xff0c;将镜像文件部署到开发板中&#xff0c;使开发…

上海亚商投顾:沪指高开高走 锂电等新能源赛道大反攻

上海亚商投顾前言&#xff1a;无惧大盘涨跌&#xff0c;解密龙虎榜资金&#xff0c;跟踪一线游资和机构资金动向&#xff0c;识别短期热点和强势个股。 一.市场情绪 沪指昨日高开后强势震荡&#xff0c;创业板指盘中一度翻绿&#xff0c;随后探底回升再度走高。碳酸锂期货合约…

制药行业中的设备管理系统和CSV最佳实践

在制药行业&#xff0c;合规性和质量是关键要素&#xff0c;而设备管理和计算机化系统验证&#xff08;CSV&#xff09;是确保这些要素的关键。之前我们介绍过设备健康管理系统如何帮助制药企业实现CSV合规性>>PreMaint设备健康管理系统&#xff1a;实现制药企业的CSV合规…

Activiti 8.0.0 发布,业务流程管理与工作流系统

导读Activiti 8.0.0 现已发布。Activiti 是一个业务流程管理 (BPM) 和工作流系统&#xff0c;适用于开发人员和系统管理员。其核心是超快速、稳定的 BPMN2 流程引擎。Activiti 可以在任何 Java 应用程序、服务器、集群或云中运行&#xff0c;与 Spring 完美集成。 具体更新内容…

声音克隆,定制自己的声音,使用最新版Bert-VITS2的云端训练+推理记录

说明 本次训练服务器使用Google Colab T4 GPUBert-VITS2库为&#xff1a;https://github.com/fishaudio/Bert-VITS2&#xff0c;其更新较为频繁&#xff0c;使用其2023.10.12的commit版本&#xff1a;主要参考&#xff1a;B站诸多大佬视频&#xff0c;CSDN:https://blog.csdn.…

Visual Studio主题颜色及字体

一、打开VS上方的工具 二、选择“选项” 三、在“常规”中选择“颜色主题” 一共四个颜色供大家参考&#xff1a; ①深色 ②浅色 ③蓝色 ④蓝&#xff08;额外对比度&#xff09; 四、字体设置 左边环境中下划

【实训项目】“优品果园”-线上水果商城小程序

1.项目背景 随着现代人对消费水平的追求以及对食物安全的需要&#xff0c;无污染、产地直销的有机水果受到越来越多市民的喜欢。交易过程的简洁化是现代消费者的追求&#xff0c;产地直销也是近期流行的一种新型的交易模式。产地直销的交易模式使得交易过程更加简便快捷&#…

产业集群的转型升级需要各个方面的协同转型——以河北吉力宝为例

随着全球经济的不断演进&#xff0c;产业集群的转型升级已经成为确保企业持续竞争力的必经之路。产业集群是一种由相关产业企业在相对密集的地理区域内紧密互联的经济组织形式&#xff0c;它们通常共享类似的供应链、市场和技术基础。其中&#xff0c;河北吉力宝是中国鞋业产业…

【教学类-32-04】20231013十二生肖4.0(标记+1位数字+排序+左右分类)(大班:《我是中国人》偏科学-数)

作品展示 一位数字、汉字对齐排列 背景需求&#xff1a; 1、优化教案&#xff0c;参与比赛 10月份有一个幼儿园原创教案比赛&#xff0c;我把这个活动《十二生肖排排队》上报了。 2、把两位数序号改成一位数。 “老师&#xff0c;我觉得猴子最大&#xff0c;他是90”。 因…

关于Vue+webpack使用unocss编写CSS,打包后CSS没加前缀

关于Vuewebpack使用unocss编写CSS&#xff0c;打包后CSS没加前缀&#xff0c;封装了一个插件去解决了这个问题 unocss-postcss-webpack-plugin unocss在vite中使用配置&#xff0c;关于unocss在vite中使用&#xff0c;自行查阅官网 https://unocss.dev/integrations/vite ,vi…

Jetson ORIN NX安装Ubuntu20.04,配置CUDA,cuDNN 等注意事项

大体准备工作与流程与博客英伟达官方源Jetson Xavier NX安装Ubuntu20.04&#xff0c;配置CUDA&#xff0c;cuDNN&#xff0c;Pytorch等环境教程&#xff08;基于NVIDIA官方教程&#xff0c;理论适用其它Jetson设备&#xff09;一致&#xff0c;主要在步骤二、三处有一些区别&am…

专利分为哪些?如何查询一个公司的专利信息?

今天来分享专利的相关知识。 专利从字面上是指专有的权利和利益。“专利”一词来源于拉丁语Litterae patentes&#xff0c;意为公开的信件或公共文献&#xff0c;是中世纪的君主用来颁布某种特权的证明&#xff0c;后来指英国国王亲自签署的独占权利证书。专利在现代一般是由政…

湖南省政协副主席赖明勇一行莅临麒麟信安调研

10月11日下午&#xff0c;湖南省政协副主席、民建湖南省委会主委赖明勇&#xff0c;省政协提案委主任袁海平&#xff0c;民建省委会专职副主委、一级巡视员段安娜等长沙先进计算及信息安全产业调研组领导莅临麒麟信安调研国产操作系统企业发展情况。长沙市政府副市长彭涛&#…

Java 拷贝

Java 中的拷贝分为两种&#xff0c;浅拷贝和深拷贝&#xff0c;关于为什么要有两种拷贝方式而不是一种&#xff0c;就要涉及到 Java 的两种类型数据了。Java 的深浅拷贝都是针对于引用类型而言的&#xff0c;基本类型是没有深浅拷贝之分的&#xff0c;类似于 C 语言&#xff0c…

C# AnimeGAN 漫画风格迁移 动漫风格迁移 图像卡通化 图像动漫化

效果 项目 模型 animeganv3_H40_model.onnx animeganv3_H50_model.onnx animeganv3_H64_model.onnx AnimeGANv3_JP_face_v1.0.onnx AnimeGANv3_PortraitSketch_25.onnx Hayao-60.onnx Hayao_64.onnx Paprika_54.onnx Shinkai_53.onnx 下载 可执行文件exe下载 源码下载

element el-table树形表格结构,勾选联动 父级勾选,子级全部选中,勾选子级,父级显示勾选状态

需求实现如下 重点使用到 select 以及 select-all 两个方法 返回数据格式 代码实现 <el-table ref"tableRef" :cell-style"{ color: #FFF, background: #333 }":header-cell-style"{ color: #FFF, background: #333 }" row-key"id"…

操作系统 面试题(二)

PART1 1.乐观锁和悲观锁的区别是什么&#xff1f; 2.乐观锁和悲观锁的实现方式分别有哪些&#xff1f; 3.平均周转时间如何计算&#xff1f; 4.银行家算法是什么&#xff1f; 5.IO多路复用是什么&#xff1f; 6.HTTP的头部包含哪些内容&#xff1f; 7.TCP如何保持连接&a…

HTTP 原理与CND原理

1 HTTP 原理 HTTP是一个无状态的协议。无状态是指客户机&#xff08;Web浏览器&#xff09;和服务器之间不需要建立持久的连接&#xff0c;这意味着当一个客户端向服务器端发出请求&#xff0c;然后服务器返回响应(response)&#xff0c;连接就被关闭了&#xff0c;在服务器端…

NSA 和 CISA 揭示十大网络安全错误配置

美国国家安全局 (NSA) 和网络安全与基础设施安全局 (CISA) 在5日公布了其红蓝团队在大型组织网络中发现的十大最常见的网络安全错误配置。 通报还详细介绍了威胁行为者使用哪些策略、技术和程序 (TTP) 来成功利用这些错误配置来实现各种目标&#xff0c;包括获取访问权限、横向…

内存空间扩充之进程覆盖技术,交换技术

1.覆盖技术 人们引入了覆盖技术&#xff0c;用来解决“程序大小超过物理内存总和”的问题。 一个固定区&#xff1a; 存放最活跃的程序段固定区中的程序段在运行过程中不会调入调出 若干覆盖区&#xff1a; 不可能同时被访问程序段可共享一个覆盖区覆盖区中的程序段在运行…