官术网_书友最值得收藏!

Importance of software architecture

So far, we have discussed the fundamental principles of software architecture, and also seen some of its characteristics. These sections, of course, assumed that software architecture is important, and is a critical step of the software development process.

It is time to play devil's advocate, and look back at software architecture and ask some existential questions about it as follows:

  • Why software architecture?
  • Why is software architecture important?
  • Why not build a system without a formal software architecture?

Let us take a look at the critical insights that software architecture provides, which would otherwise be missing from an informal software development process. We are only focusing on the technical or developmental aspects of the system in the following table:

There are a number of other aspects which are related to the business context of a system, into which architecture provides valuable insights. However, since this is a book mostly on the technical aspects of software architecture, we have limited our discussion to the ones given in the preceding table.

Now, let us take on the second question:

Why not build a system without a formal software architecture?

If you've been following the arguments so far thoroughly, it is not very difficult to see the answer for it. It can, however, be summarized in the following few statements:

  • Every system has an architecture, whether it is documented or not
  • Documenting an architecture makes it formal, allowing it to be shared among stakeholders, making change management and iterative development possible
  • All the other benefits and characteristics of software architecture are ready to be taken advantage of when you have a formal architecture defined and documented
  • You may be still able to work and build a functional system without a formal architecture, but it would not produce a system which is extensible and modifiable, and would most likely produce a system with a set of quality attributes quite far away from the original requirements
主站蜘蛛池模板: 永福县| 甘谷县| 桓仁| 乾安县| 长白| 天峨县| 平度市| 巴青县| 民权县| 兰坪| 武冈市| 公主岭市| 丹巴县| 昌乐县| 通辽市| 南乐县| 始兴县| 永平县| 甘孜| 临沂市| 铜川市| 馆陶县| 方城县| 应城市| 新河县| 南皮县| 长阳| 措美县| 岫岩| 格尔木市| 离岛区| 大关县| 武定县| 凯里市| 嘉鱼县| 论坛| 武川县| 乌海市| 南木林县| 社会| 和田县|