软件交付问题之架构让代码组织更有序,如何解决

简介: 软件交付问题之架构让代码组织更有序,如何解决

问题一:为什么数值、状态等多变的字段建议不要跨单据冗余?


为什么数值、状态等多变的字段建议不要跨单据冗余?


参考回答:

数值、状态等多变的字段建议不要跨单据冗余,因为冗余可能导致数据一致性问题。如果在两个单据上都冗余了相同的字段,如金额或状态,那么在任何更新这些字段的逻辑中,都需要同时更新这两个单据。这不仅增加了不必要的复杂性,而且可能导致数据不一致,特别是在没有使用事务来确保两个单据上的数据同时更新的情况下。因此,为了避免这些问题,建议不要在多个单据间冗余多变的字段。


关于本问题的更多回答可点击原文查看:

https://developer.aliyun.com/ask/621587



问题二:为什么要对客表达和系统实现进行解耦?


为什么要对客表达和系统实现进行解耦?


参考回答:

因为用户侧的表达通常基于系统里的模型数据,但用户看到的一些点并不需要100%落实到系统实现中去。通过抽象和转换,我们可以将用户看到的数据与系统内部的数据模型进行映射,而不是直接暴露系统内部的复杂性给用户。这样做可以使系统实现更加灵活和可扩展,同时提供更好的用户体验。


关于本问题的更多回答可点击原文查看:

https://developer.aliyun.com/ask/621588



问题三:架构如何让代码组织更有序?


架构如何让代码组织更有序?


参考回答:

因为它提供了对代码结构进行规划的原则和指导。在设计阶段,我们可以考虑相关业务逻辑的代码应该放在哪里,提炼出一些原则来指导代码的组织。这样可以避免代码乱放、公共代码和差异化代码的混乱问题。通过合理的架构规划,我们可以使代码结构更加有序、清晰和易于维护。


关于本问题的更多回答可点击原文查看:

https://developer.aliyun.com/ask/621589



问题四:为什么需要把在线业务逻辑和批处理任务切分开?


为什么需要把在线业务逻辑和批处理任务切分开?


参考回答:

因为批处理任务可能会导致机器负载增加,从而影响在线接口的响应速度。此外,批处理任务通常是异步的,并且可以重复运行,而在线业务逻辑需要实时响应并避免中断或在指定时间内无法反馈的情况。将两者分开可以确保在线业务逻辑的稳定性和响应速度,并提高系统的整体性能。


关于本问题的更多回答可点击原文查看:

https://developer.aliyun.com/ask/621590



问题五:为什么不建议把太多的业务逻辑放在前端?


为什么不建议把太多的业务逻辑放在前端?


参考回答:

因为对客的页面渲染和用户操作的交互逻辑更适合放在前端处理,而流程的控制应该全部放在后端进行。如果前端包含过多的业务逻辑,那么运行情况将难以监控,并且一旦出现问题需要查看客户端的运行情况,这将增加排查问题的难度。此外,将业务逻辑放在后端可以更容易地通过后端链路看清楚整体的业务流程。


关于本问题的更多回答可点击原文查看:

https://developer.aliyun.com/ask/621591

相关文章
|
3月前
|
数据采集 机器学习/深度学习 大数据
行为检测代码(一):超详细介绍C3D架构训练+测试步骤
这篇文章详细介绍了C3D架构在行为检测领域的应用,包括训练和测试步骤,使用UCF101数据集进行演示。
117 1
行为检测代码(一):超详细介绍C3D架构训练+测试步骤
|
2月前
|
运维 负载均衡 Shell
控制员工上网软件:高可用架构的构建方法
本文介绍了构建控制员工上网软件的高可用架构的方法,包括负载均衡、数据备份与恢复、故障检测与自动切换等关键机制,以确保企业网络管理系统的稳定运行。通过具体代码示例,展示了如何实现这些机制。
138 63
|
2月前
|
监控 前端开发 数据可视化
3D架构图软件 iCraft Editor 正式发布 @icraft/player-react 前端组件, 轻松嵌入3D架构图到您的项目,实现数字孪生
@icraft/player-react 是 iCraft Editor 推出的 React 组件库,旨在简化3D数字孪生场景的前端集成。它支持零配置快速接入、自定义插件、丰富的事件和方法、动画控制及实时数据接入,帮助开发者轻松实现3D场景与React项目的无缝融合。
238 8
3D架构图软件 iCraft Editor 正式发布 @icraft/player-react 前端组件, 轻松嵌入3D架构图到您的项目,实现数字孪生
|
2月前
|
敏捷开发 缓存 中间件
.NET技术的高效开发模式,涵盖面向对象编程、良好架构设计及高效代码编写与管理三大关键要素
本文深入探讨了.NET技术的高效开发模式,涵盖面向对象编程、良好架构设计及高效代码编写与管理三大关键要素,并通过企业级应用和Web应用开发的实践案例,展示了如何在实际项目中应用这些模式,旨在为开发者提供有益的参考和指导。
50 3
|
2月前
|
Kubernetes 前端开发 分布式数据库
工作中常见的软件系统部署架构
在实际应用中,会根据项目的具体需求、规模、性能要求等因素选择合适的部署架构,或者综合使用多种架构模式来构建稳定、高效、可扩展的系统。
320 2
|
3月前
|
机器学习/深度学习 网络架构 计算机视觉
目标检测笔记(一):不同模型的网络架构介绍和代码
这篇文章介绍了ShuffleNetV2网络架构及其代码实现,包括模型结构、代码细节和不同版本的模型。ShuffleNetV2是一个高效的卷积神经网络,适用于深度学习中的目标检测任务。
135 1
目标检测笔记(一):不同模型的网络架构介绍和代码
|
2月前
|
存储 安全 Java
系统安全架构的深度解析与实践:Java代码实现
【11月更文挑战第1天】系统安全架构是保护信息系统免受各种威胁和攻击的关键。作为系统架构师,设计一套完善的系统安全架构不仅需要对各种安全威胁有深入理解,还需要熟练掌握各种安全技术和工具。
206 10
|
2月前
|
运维 Serverless 数据处理
Serverless架构通过提供更快的研发交付速度、降低成本、简化运维、优化资源利用、提供自动扩展能力、支持实时数据处理和快速原型开发等优势,为图像处理等计算密集型应用提供了一个高效、灵活且成本效益高的解决方案。
Serverless架构通过提供更快的研发交付速度、降低成本、简化运维、优化资源利用、提供自动扩展能力、支持实时数据处理和快速原型开发等优势,为图像处理等计算密集型应用提供了一个高效、灵活且成本效益高的解决方案。
115 1
|
3月前
|
运维 Serverless 数据处理
Serverless架构通过提供更快的研发交付速度、降低成本、简化运维、优化资源利用、提供自动扩展能力、支持实时数据处理和快速原型开发等优势,为图像处理等计算密集型应用提供了一个高效、灵活且成本效益高的解决方案。
Serverless架构通过提供更快的研发交付速度、降低成本、简化运维、优化资源利用、提供自动扩展能力、支持实时数据处理和快速原型开发等优势,为图像处理等计算密集型应用提供了一个高效、灵活且成本效益高的解决方案。
83 3
|
3月前
|
机器学习/深度学习 大数据 PyTorch
行为检测(一):openpose、LSTM、TSN、C3D等架构实现或者开源代码总结
这篇文章总结了包括openpose、LSTM、TSN和C3D在内的几种行为检测架构的实现方法和开源代码资源。
127 0

热门文章

最新文章