问题1(16分)
针对该系统功能,赵工建议解释器架构风格,李工建议管道过滤架构风格,王工则建议饮食调用,该系统从灵活性和可扩展性考虑,应采用哪种?
解析:
管道-过滤器:过滤器就是构件,管道就是连接件,每一个构件都是有输入和输出,经过构件内部处理,前一个构件的输出时候一个构件的输入,前后数据流相关联。
解释器:可以构建解释器引擎,定义一套规则给使用者使用。
隐式调用:通过触发或广播一个事件或多个事件,当某事件被触发,系统直接隐式调用其他模块的过程。
答案:
灵活性方面,解释器可以灵活组装各个规则,来实现同的功能,灵活性最好。管道-过滤器可以通过管道来灵活组装每个流程的过滤器,灵活性次之,隐式调用是通过一个事件触发另一个事件,或者通过广播一个或多个事件,在灵活方面则差一点。
学习算法可扩展性,解释器可以直接配置新的规则,扩展性是最好的。管道-过滤器可以组装管道和过滤器,或者新增过滤器来实现,扩展性次之。隐式调用则扩展性差点,每次需要新增新的事件来触发。
考虑到该平台灵活定义机器学习流程需求和开发新算法组件加入平台,提高扩展性和灵活性建议选择解释器。
问题2(9分)
在系统初步运行后,发现系统数据访问性能较差。经过分析,刘工认为原来数据库规范化设计后,关系〕于细分,造成了大量的多表关联查洵,影响了性能。例如当用户吉洵商品信息时,需要同时显示该药品的信息、供应商的信息、当前库存等信息。为此,刘工认为可以采用反规范化设计来改造药品关系的结构,以提高查讠旬性能。修改后的药品关系结构为:药品(药品ID,药品名称,药品型号药品价格,供应商ID,供应商名称,当前库存数。
请用200字以内的文字说明常见的反规范化设计方法,并说班用户查洵商品信息应该采用哪种反规范化设计方法。
解析:
- 增加冗余列:多个相同列字段在不同表新增。
- 增加派生列:需要聚合的数据新增一个字段存储。
- 合并表:多个表需要查询的字段合并成一个表。
- 拆分表:拆分又分为水平拆分和垂直拆分。水平拆分则是把表拆分成多个,所有表字段都一致。垂直拆分则是把表常用字段和不常用字段,拆分成两个表,富文本字段也可以拆分成单独的表。
该项目应采用增加冗余列方法。
问题3(9分)
王工认为,反规范化设计可提高吉洵的性能,但必然会带来数据的不一致性问题。清用200字以内的文字说明在反规范化设计中,解决数据不一致性问题的三种常见方法,并说月该系统应该采用哪种方法。
解析:
数据不一致解决方案 :
- 同步实时更新,每次更新冗余字段,冗余表都放在一个事务里,事务的原子性保证要么同时成功,要么同时失败。
- 异步更新,读取bin log日志,更新其他冗余数据。
- 异步更新,通过消息队列消费,如Kafka,Rocket等,通知其他冗余数据更新。
该项目对实时性要求不高,可以考虑异步更新,通过读取mysql 的binlog来解决。
问题4(7分)
该系统采厍了Redis来现某些特定功能呶当前热药品排名等),同时将药品关系数据放到内存以提高商品查讠旬的性能,但必然会造成Redis和MySQL的数据实时同步问题。
()Redis的数据类型包括String、Hash、List、set和zset等,清说班实现当前热药品排名的功能应该使用哪种数据类型。
()清用200字以内的文字解说班解决Redis和MySQL数啹实时同步问题的常见方案。
解析:
Zset来实现当前热药品排名。
被动一致性:Redis和MySQL数据同步可以采用延迟双删来解决,先删除Redis缓存数据,再更新MySQL数据,sleep一段时间(为了保证数据库已持久化),再次删除Redis缓存数据。
主动一致性:开启额外服务去读取BinLog日志,来更新到Redis缓存。
问题5(9分)
采用面向对象方法开发软件,通常需要建立对象模型、动态模型和功能模型,请分别介绍这三种模型,针对上述模型,说明那些模型可以软件的需求分析?
解析:
对象模型 描述了系统的静态结构,对象图建模,描述了现实对象到系统数据结构的转换。
动态模型 描述了时间和操作顺序有关的特征。主要状态图表示。
功能摸索 描述了数据的输入值和输出值,主要DFD来实现。
对象模型是动态模型和功能模型的基础数据,对象模型确定发生的对象,动态模型确定什么时候发生,功能模型则是发生了什么。
问题6(8分)
请用400字以内的文字简要描述基于家庭网关的传统智能家居管理系统和基于云平台的智能家居管理系统在网关管理、数据处理和系统性能等方面的特点,以说明项目组选择李工设计思路的原因。
解析:
网关管理方面基于云平台的可以统一在云平台管理,更方便远程管理。
数据处理方面基于云平台的数据都存储在云上,一起处理方便,冗余备份。
性能方面基于云平台的性能和安全性更好。
问题7(5分)
该系统实现用户终端与服务端的双向可靠性通信,请用300字以内的文字从数据传说可靠性对比TCP和UDP通信协议的不同,并且说明该系统用哪种协议?
解析:
TCP是在IP协议提供的不可靠基础上,采用了重发技术,为应用程序提供了一个可靠的、面向连接的、双全工传输服务。TCP协议适用输出数据量少,且对可靠性要求高的场景。
UDP是不可靠传输协议,无连接传输协议,可以保证应用程序的通信,但是错误检测功能弱很多。
问题8: