由结构体设计想到的

2024-04-08 09:18
文章标签 设计 结构 想到

本文主要是介绍由结构体设计想到的,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

昨天,在和春哥讨论一个结构体的设计时,

最初设计结构体的结构:
typedef struct Infor
{
    Infor *pInfor;
    Time  *pTime;
    Id      *pId;
};

struct InforHeader{
Infor *pInfor;
     Time  *pTime;
     Id      *pId;
unsigned char u8InforNum;
    char          s8InforIndex;
};

struct Header{
    struct InforHeader *pInforHeader;
    unsigned short  u16Num;
    short                s16Index;
    unsigned char  u8OpMode;
};
这是一个写入与读出时需要使用的结构体,关于写入没有太多需要注意的,只要把值相应的填到Infor的结构体成员中就可以。
只是在读出时,需要将数据显示出来,这个时候就有很大不一样。主要说,读出时结构体的设计思路。
这里最初的设计思路是,用Header中的u8OpMode来输入查询的模式,由于这里有三种查询方式,按ID来查询,按Time查询,按ID和Time查询。这里就将用来查询的内容放在了Header->InforHeader->pTime 和Header->InforHeader->pId中,同时pInfor用来返回查询结果,u8InforNum。如果只是这样,这个结构设计可以满足要求。只是后来,的要求是pTime要是pInfor的具体时间,由于输入的时候pTime只能具体到天,而数据库中的pTime是精确到秒,所以当时在考虑时,是输入的参量就不再去查询,所以如果是输入时间查询,是不再查查出具体的时间,这里的返回值只有pInfor,这样最终的查询值就只有pInfor。
如此是可以的。
但是,由于后来发现,在显示那一部分需要数据库中精确的时间,而不是输入查询时,输入的时间。这样一来,这个pTime就有可能即做输入,又做输出,这样在之后显示时如果索引这个时间值,就有可能很麻烦,如果要再去查询,这个时候,就有可能造成索引很麻烦。

修改后:
typedef struct Infor
{
     Infor          aInfor;
Time         aTime;
Id              aId;
}  AlarmInfor;

struct InforHeader{
    struct Infor *pInfor;
unsigned char u8InforNum;
    char          s8InforIndex;
};

struct Header{
    struct InforHeader sInforHeader;
Time                  *pTimeHeader;
Id                       *pId;

    unsigned short u16Num;
    short          s16Index;
    unsigned char  u8OpMode;
};
写入数据库是一样的,不再说。
在查询时,这里的查询内容由Header->pTimeHeader和Header->pId提供,查询的结果由Header->sInforHeader.pInfor提供,这样,在查询的内容和返回的结果,是在不同的变量中保存。在查询时输入和输出不至于混在一起,这样在显示时就方便很多。

综合前后结构体的修改,发现并不是一开始设计结构体就出错了,如果根据最初的理解,查询在按ID和Time查询的返回只有Infor,第一种的设计也是可以的。
但是在后来的显示中,需要将数据库中的时间同样读出来,所以第一种结构设计就不合适了,第二种数据结构更合适。

这里之所以会出现这样的偏差,
应该是对于一开始的模块的功能需求不明确,造成了结构体设计出来,不符合需要。
这里想起来《大象》中所说的,“不满足需求的程序设计,基本就是无用的设计”。程序不是我们设计的有多么好,多么精巧,而是首先明白我们的程序是用来做什么的,需要实现什么。在此基础上,去设计,去编程。不然,即使一个十分好的程序,但是没有实现功能,对于程序设计的目的是无用的。

但是这个过程对于程序设计者,是很有帮助的。程序设计者会更多的去思考,去总结。以更好的,符合设计要求。

这篇关于由结构体设计想到的的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/885177

相关文章

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

Java集合中的链表与结构详解

《Java集合中的链表与结构详解》链表是一种物理存储结构上非连续的存储结构,数据元素的逻辑顺序的通过链表中的引用链接次序实现,文章对比ArrayList与LinkedList的结构差异,详细讲解了链表... 目录一、链表概念与结构二、当向单链表的实现2.1 准备工作2.2 初始化链表2.3 打印数据、链表长

创建springBoot模块没有目录结构的解决方案

《创建springBoot模块没有目录结构的解决方案》2023版IntelliJIDEA创建模块时可能出现目录结构识别错误,导致文件显示异常,解决方法为选择模块后点击确认,重新校准项目结构设置,确保源... 目录创建spChina编程ringBoot模块没有目录结构解决方案总结创建springBoot模块没有目录

SpringBoot利用树形结构优化查询速度

《SpringBoot利用树形结构优化查询速度》这篇文章主要为大家详细介绍了SpringBoot利用树形结构优化查询速度,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一个真实的性能灾难传统方案为什么这么慢N+1查询灾难性能测试数据对比核心解决方案:一次查询 + O(n)算法解决

Oracle查询表结构建表语句索引等方式

《Oracle查询表结构建表语句索引等方式》使用USER_TAB_COLUMNS查询表结构可避免系统隐藏字段(如LISTUSER的CLOB与VARCHAR2同名字段),这些字段可能为dbms_lob.... 目录oracle查询表结构建表语句索引1.用“USER_TAB_COLUMNS”查询表结构2.用“a

Mysql中设计数据表的过程解析

《Mysql中设计数据表的过程解析》数据库约束通过NOTNULL、UNIQUE、DEFAULT、主键和外键等规则保障数据完整性,自动校验数据,减少人工错误,提升数据一致性和业务逻辑严谨性,本文介绍My... 目录1.引言2.NOT NULL——制定某列不可以存储NULL值2.UNIQUE——保证某一列的每一

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

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

如何使用Maven创建web目录结构

《如何使用Maven创建web目录结构》:本文主要介绍如何使用Maven创建web目录结构的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录创建web工程第一步第二步第三步第四步第五步第六步第七步总结创建web工程第一步js通过Maven骨架创pytho

Python循环结构全面解析

《Python循环结构全面解析》循环中的代码会执行特定的次数,或者是执行到特定条件成立时结束循环,或者是针对某一集合中的所有项目都执行一次,这篇文章给大家介绍Python循环结构解析,感兴趣的朋友跟随... 目录for-in循环while循环循环控制语句break语句continue语句else子句嵌套的循

MyBatis设计SQL返回布尔值(Boolean)的常见方法

《MyBatis设计SQL返回布尔值(Boolean)的常见方法》这篇文章主要为大家详细介绍了MyBatis设计SQL返回布尔值(Boolean)的几种常见方法,文中的示例代码讲解详细,感兴趣的小伙伴... 目录方案一:使用COUNT查询存在性(推荐)方案二:条件表达式直接返回布尔方案三:存在性检查(EXI