软考高级:内聚的分类(偶然内聚、逻辑内聚等)概念和例题

2024-03-06 09:28

本文主要是介绍软考高级:内聚的分类(偶然内聚、逻辑内聚等)概念和例题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

作者:明明如月学长, CSDN 博客专家,大厂高级 Java 工程师,《性能优化方法论》作者、《解锁大厂思维:剖析《阿里巴巴Java开发手册》》、《再学经典:《Effective Java》独家解析》专栏作者。

热门文章推荐

  • (1)《为什么很多人工作 3 年 却只有 1 年经验?》
  • (2)《一文掌握大模型提示词技巧:从战略到战术巧》
  • (3)《AI 时代,程序员的出路在何方?》
  • (4)《如何写出高质量的文章:从战略到战术》
  • (5)《我的技术学习方法论》
  • (6)《我的性能方法论》
  • (7)《AI 时代的学习方式: 和文档对话》

一、AI 讲解

1. 偶然内聚(Coincidental Cohesion)

偶然内聚是内聚度最低的一种类型。模块内的各个元素之间没有任何联系,它们只是偶然地被放在同一个模块中。例如,在一个模块中包含了以下三个语句:

move O to R
read file F
move S to T

这三个语句没有任何逻辑上的联系,它们只是被放在同一个模块中,以便于一起编译和执行。

2. 逻辑内聚(Logical Cohesion)

逻辑内聚是指模块内执行若干个逻辑上相似的功能,通过参数确定该模块完成哪一个功能。例如,在一个模块中包含了以下三个函数:

void add(int a, int b) {return a + b;
}void subtract(int a, int b) {return a - b;
}void multiply(int a, int b) {return a * b;
}

这三个函数都实现了基本的算术运算,它们之间有一定的逻辑联系。模块可以通过参数来选择执行哪个函数。

3. 时间内聚(Temporal Cohesion)

时间内聚是指把需要同时执行的动作组合在一起形成的模块。例如,在一个模块中包含了以下两个函数:

void init() {// 初始化系统
}void start() {// 启动系统
}

这两个函数必须同时执行才能完成系统的初始化和启动工作。因此,将它们放在同一个模块中可以提高代码的可读性和可维护性。

4. 过程内聚(Procedural Cohesion)

过程内聚是指一个模块完成多个任务,这些任务必须按指定的过程执行。例如,在一个模块中包含了以下三个函数:

void open_file(char *filename) {// 打开文件
}void read_file(char *buffer, int size) {// 读取文件
}void close_file() {// 关闭文件
}

这三个函数实现了打开、读取和关闭文件的操作。它们必须按顺序执行才能完成文件的读写操作。

5. 通信内聚(Communicational Cohesion)

通信内聚是指模块内的所有处理元素都在同一数据结构上操作,或者各处理使用相同的输入数据或产生相同的输出数据。例如,在一个模块中包含了以下三个函数:

void add_student(Student *student) {// 添加学生信息
}void delete_student(int id) {// 删除学生信息
}void modify_student(Student *student) {// 修改学生信息
}

这三个函数都操作了同一个数据结构 Student。因此,将它们放在同一个模块中可以提高代码的可读性和可维护性。

6. 顺序内聚(Sequential Cohesion)

顺序内聚是指一个模块中的各个处理元素都密切相关于同一各功能且必须顺序执行,前一个功能元素的输出就是下一个功能的输入。例如,在一个模块中包含了以下三个函数:

void parse_input(char *input) {// 解析输入
}void process_input(char *input) {// 处理输入
}void generate_output(char *output) {// 生成输出
}

这三个函数实现了输入解析、处理和输出生成的功能。它们必须按顺序执行才能完成整个功能。

7. 功能内聚(Functional Cohesion)

功能内聚是内聚度最高的一种类型。指模块内的所有元素共同作用完成一个功能,缺一不可。例如,在一个模块中包含了以下三个函数:

void init_database() {// 初始化数据库
}void query_database(char *query) {// 查询数据库
}void close_database() {// 关闭数据库
}

这三个函数共同实现了数据库的初始化、查询和关闭功能。它们缺一不可,否则无法完成数据库的操作。

二、AI 出题

  1. 下列哪种内聚类型表示模块中的操作必须按照特定顺序执行?
    A. 逻辑内聚
    B. 时间内聚
    C. 过程内聚
    D. 通信内聚

  2. 功能内聚指的是什么?
    A. 模块内的操作可以独立执行
    B. 模块内的所有元素共同完成一个单一的任务
    C. 模块包含了逻辑上相似的操作
    D. 模块的操作处理同一数据

  3. 偶然内聚的模块中的元素之间的关系是怎样的?
    A. 严格按顺序执行的
    B. 逻辑上相似的
    C. 没有任何明显的关系
    D. 基于时间执行的

  4. 通信内聚是指模块中的操作怎样组织?
    A. 按照执行时间组织
    B. 操作同一份数据或资源
    C. 基于操作的逻辑相似性
    D. 完全是偶然组织的

  5. 顺序内聚与过程内聚有什么不同?
    A. 顺序内聚强调操作的逻辑相似性
    B. 过程内聚的操作之间没有顺序关系
    C. 顺序内聚的输出作为另一操作的输入
    D. 过程内聚涉及到数据处理的多个步骤

  6. 时间内聚通常在什么情况下出现?
    A. 当模块执行与时间无关的任务时
    B. 当模块的操作在程序的同一生命周期阶段执行
    C. 当模块包含不相关的操作时
    D. 当模块的所有操作都完成一个单一任务时

答案解析:

  1. C. 过程内聚
  2. B. 模块内的所有元素共同完成一个单一的任务
  3. C. 没有任何明显的关系
  4. B. 操作同一份数据或资源
  5. C. 顺序内聚的输出作为另一操作的输入
  6. B. 当模块的操作在程序的同一生命周期阶段执行

这篇关于软考高级:内聚的分类(偶然内聚、逻辑内聚等)概念和例题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

Python中你不知道的gzip高级用法分享

《Python中你不知道的gzip高级用法分享》在当今大数据时代,数据存储和传输成本已成为每个开发者必须考虑的问题,Python内置的gzip模块提供了一种简单高效的解决方案,下面小编就来和大家详细讲... 目录前言:为什么数据压缩如此重要1. gzip 模块基础介绍2. 基本压缩与解压缩操作2.1 压缩文

Java中的for循环高级用法

《Java中的for循环高级用法》本文系统解析Java中传统、增强型for循环、StreamAPI及并行流的实现原理与性能差异,并通过大量代码示例展示实际开发中的最佳实践,感兴趣的朋友一起看看吧... 目录前言一、基础篇:传统for循环1.1 标准语法结构1.2 典型应用场景二、进阶篇:增强型for循环2.

MySQL中的索引结构和分类实战案例详解

《MySQL中的索引结构和分类实战案例详解》本文详解MySQL索引结构与分类,涵盖B树、B+树、哈希及全文索引,分析其原理与优劣势,并结合实战案例探讨创建、管理及优化技巧,助力提升查询性能,感兴趣的朋... 目录一、索引概述1.1 索引的定义与作用1.2 索引的基本原理二、索引结构详解2.1 B树索引2.2

使用Python进行GRPC和Dubbo协议的高级测试

《使用Python进行GRPC和Dubbo协议的高级测试》GRPC(GoogleRemoteProcedureCall)是一种高性能、开源的远程过程调用(RPC)框架,Dubbo是一种高性能的分布式服... 目录01 GRPC测试安装gRPC编写.proto文件实现服务02 Dubbo测试1. 安装Dubb

Apache 高级配置实战之从连接保持到日志分析的完整指南

《Apache高级配置实战之从连接保持到日志分析的完整指南》本文带你从连接保持优化开始,一路走到访问控制和日志管理,最后用AWStats来分析网站数据,对Apache配置日志分析相关知识感兴趣的朋友... 目录Apache 高级配置实战:从连接保持到日志分析的完整指南前言 一、Apache 连接保持 - 性

MySQL 事务的概念及ACID属性和使用详解

《MySQL事务的概念及ACID属性和使用详解》MySQL通过多线程实现存储工作,因此在并发访问场景中,事务确保了数据操作的一致性和可靠性,下面通过本文给大家介绍MySQL事务的概念及ACID属性和... 目录一、什么是事务二、事务的属性及使用2.1 事务的 ACID 属性2.2 为什么存在事务2.3 事务

mysql中的group by高级用法详解

《mysql中的groupby高级用法详解》MySQL中的GROUPBY是数据聚合分析的核心功能,主要用于将结果集按指定列分组,并结合聚合函数进行统计计算,本文给大家介绍mysql中的groupby... 目录一、基本语法与核心功能二、基础用法示例1. 单列分组统计2. 多列组合分组3. 与WHERE结合使

PyTorch高级特性与性能优化方式

《PyTorch高级特性与性能优化方式》:本文主要介绍PyTorch高级特性与性能优化方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、自动化机制1.自动微分机制2.动态计算图二、性能优化1.内存管理2.GPU加速3.多GPU训练三、分布式训练1.分布式数据

Spring Boot集成SLF4j从基础到高级实践(最新推荐)

《SpringBoot集成SLF4j从基础到高级实践(最新推荐)》SLF4j(SimpleLoggingFacadeforJava)是一个日志门面(Facade),不是具体的日志实现,这篇文章主要介... 目录一、日志框架概述与SLF4j简介1.1 为什么需要日志框架1.2 主流日志框架对比1.3 SLF4

Spring Boot集成Logback终极指南之从基础到高级配置实战指南

《SpringBoot集成Logback终极指南之从基础到高级配置实战指南》Logback是一个可靠、通用且快速的Java日志框架,作为Log4j的继承者,由Log4j创始人设计,:本文主要介绍... 目录一、Logback简介与Spring Boot集成基础1.1 Logback是什么?1.2 Sprin