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

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
主站蜘蛛池模板: 宜春市| 泰州市| 南宁市| 万年县| 扎赉特旗| 钦州市| 都江堰市| 留坝县| 临漳县| 浑源县| 沙河市| 日照市| 鄂伦春自治旗| 峨眉山市| 墨玉县| 周口市| 军事| 延川县| 会泽县| 渭源县| 乌兰县| 吉首市| 舟山市| 修武县| 柘城县| 东安县| 罗田县| 岳阳县| 防城港市| 东辽县| 惠水县| 大足县| 淮滨县| 万盛区| 云龙县| 庆云县| 淮安市| 雅江县| 棋牌| 二手房| 青龙|