Software engineering explained

Software engineering is the application of a systematic, disciplined, quantifiable approach to the development, operation, and maintenance of software, and the study of these approaches. That is the application of engineering to software.[1]

The term software engineering first appeared in the 1968 NATO Software Engineering Conference and was meant to provoke thought regarding the current "software crisis" at the time.[2] Since then, it has continued as a profession and field of study dedicated to creating software that is of higher quality, cheaper, maintainable, and quicker to build. Since the field is still relatively young compared to its sister fields of engineering, there is still much work and debate around what software engineering actually is, and if it deserves the title engineering. It has grown organically out of the limitations of viewing software as just programming. Software development is a term sometimes preferred by practitioners in the industry who view software engineering as too heavy-handed and constrictive to the malleable process of creating software.

Yet, in spite of its youth as a profession, the field's future looks bright as Money Magazine and Salary.com rated software engineering as the best job in America in 2006. [3]

History

See main article: History of software engineering. While the term software engineering was coined at a conference in 1968, the problems that it tried to address started much earlier. The history of software engineering is inextricably intertwined with the dueling histories of computer hardware and computer software.

When the modern digital computer first appeared in 1941, the instructions to make it operate were wired into the machine. Practitioners quickly realized that this design was not flexible and came up with the "stored program architecture" or von Neumann architecture. Thus the first division between "hardware" and "software" began with abstraction being used to deal with the complexity of computing.

Programming languages started to appear in the 1950s and this was also another major step in abstraction. Major languages such as Fortran, Algol, and Cobol were released in the late 1950s to deal with scientific, algorithmic, and business problems respectively. E. W. Dijsktra wrote his seminal paper, "Go To Statement Considered Harmful", [4] in 1968 and David Parnas introduced the key concept of modularity and information hiding in 1972[5] to help programmers deal with the ever increasing complexity of software systems. A software system for managing the hardware called an operating system was also introduced, most notably by Unix in 1969. In 1967, the Simula language introduced the object-oriented programming paradigm.

These advances in software were met with more advances in computer hardware. In the mid 1970s, the microcomputer was introduced, making it economical for hobbyists to obtain a computer and write software for it. This in turn lead to the now famous Personal Computer or PC and Microsoft Windows. The Software Development Life Cycle or SDLC was also starting to appear as a consensus for centralized construction of software in the mid 1980s. The late 1970s and early 1980s saw the introduction of several new Simula-inspired object-oriented programming languages, including C++, Smalltalk, and Objective C.

Open-source software started to appear in the early 90s in the form of Linux and other software introducing the "bazaar" or decentralized style of constructing software [6] . Then the Internet and World Wide Web hit in the mid 90s changing the engineering of software once again. Distributed Systems gained sway as a way to design systems and the Java programming language was introduced as another step in abstraction having its own virtual machine. Programmers collaborated and wrote the Agile Manifesto that favored more light weight processes to create cheaper and more timely software.

The current definition of software engineering is still being debated by practitioners today as they struggle to come up with ways to produce software that is "cheaper, bigger, quicker".

Profession

See main article: Software engineer.

While some areas, such as Ontario, Canada [7], license software engineers; most places in the world have no laws regarding the profession of software engineers. Yet there are some guides from the IEEE Computer Society and the ACM, the two main professional organizations of software engineering. The IEEE's Guide to the Software Engineering Body of Knowledge - 2004 Version or SWEBOK defines the field and gives a coverage of the knowledge practicing software engineers should know. There is also an IEEE "Software Engineering Code of Ethics". [8] In addition, there is a Software and Systems Engineering Vocabulary (SEVOCAB) [9], published on-line by the IEEE Computer Society.

Employment

In 2004, the U. S. Bureau of Labor Statistics counted 760,840 software engineers holding jobs in the U.S.; in the same time period there were some 1.4 million practitioners employed in the U.S. in all other engineering disciplines combined.[10] Due to its relative newness as a field of study, formal education in software engineering is often taught as part of a computer science curriculum, and as a result most software engineers hold computer science degrees.[11]

Most software engineers work as employees or contractors. Software engineers work with businesses, government agencies (civilian or military), and non-profit organizations. Some software engineers work for themselves as freelancers. Some organizations have specialists to perform each of the tasks in the software development process. Other organizations require software engineers to do many or all of them. In large projects, people may specialize in only one role. In small projects, people may fill several or all roles at the same time. Specializations include: in industry (analysts, architects, developers, testers, technical support, managers) and in academia (educators, researchers).

There is considerable debate over the future employment prospects for Software Engineers and other IT Professionals. For example, an online futures market called the "ITJOBS Future of IT Jobs in America"[12] attempts to answer whether there will be more IT jobs, including software engineers, in 2012 than there were in 2002.

Certification

Professional certification of software engineers is a contentious issue. Some see it as a tool to improve professional practice;"The only purpose of licensing software engineers is to protect the public" [13]

The ACM had a professional certification program in the early 1980s, which was discontinued due to lack of interest. The ACM examined the possibility of professional certification of software engineers in the late 1990s, but eventually decided that such certification was inappropriate for the professional industrial practice of software engineering.[14], the IEEE had certified over 575 software professionals.[15] In Canada the Canadian Information Processing Society has developed a legally recognized professional certification called Information Systems Professional (ISP).[16]

Most certification programs in the IT industry are oriented toward specific technologies, and are managed by the vendors of these technologies.[17] These certification programs are tailored to the institutions that would employ people who use these technologies.

Impact of globalization

Many students in the developed world have avoided degrees related to software engineering because of the fear of offshore outsourcing (importing software products or services from other countries) and of being displaced by foreign visa workers.[18] Although government statistics do not currently show a threat to software engineering itself; a related career, computer programming does appear to have been affected.[19] [20] Often one is expected to start out as a computer programmer before being promoted to software engineer. Thus, the career path to software engineering may be rough, especially during recessions.

Some career counselors suggest a student also focus on "people skills" and business skills rather than purely technical skills because such "soft skills" are allegedly more difficult to offshore.[21] It is the quasi-management aspects of software engineering that appear to be what has kept it from being impacted by globalization.[22]

Education

A knowledge of programming is the main pre-requisite to becoming a software engineer, but it is not sufficient. Many software engineers have degrees in Computer Science due to the lack of software engineering programs in higher education. However, this has started to change with the introduction of new software engineering degrees, especially in post-graduate education. A standard international curriculum for undergraduate software engineering degrees was defined by the CCSE.

In 1998, the US Naval Postgraduate School (NPS) established the first doctorate program in Software Engineering in the world. Steve McConnell opines that because most universities teach computer science rather than software engineering, there is a shortage of true software engineers.[23] In 2004 the IEEE Computer Society produced the SWEBOK, which has become an ISO standard describing the body of knowledge covered by a software engineer .

Sub-disciplines

Software engineering can be divided into ten subdisciplines. They are:[1]

Related disciplines

Software engineering is related to the disciplines of computer science, project management, and systems engineering.[24] [25]

Computer science

Software engineering is considered a subfield of computer science by many academics. Many of the foundations of software engineering come from computer science.

Project management

The building of a software system is usually considered a project and the management of it borrows many principles from the field of Project management.

Systems engineering

Systems engineers have been dealing with the complexity of large systems for many decades and their knowledge is applied to many software engineering problems.

See also

Further reading

. Roger S. Pressman. Software Engineering: A Practitioner's Approach. 6th ed.. 2005. McGraw-Hill. Boston, Mass. 0072853182.

. Ian Sommerville (academic). Software Engineering. 1982. 8th ed.. 2007. Pearson Education. Harlow, England. 0-321-31379-8.

. Pankaj Jalote. An Integrated Approach to Software Engineering. 1991. 3th ed.. 2005. Springer. 0-387-20881-X.

External links

Notes and References

  1. Book: Pierre Bourque and Robert Dupuis. Guide to the Software Engineering Body of Knowledge - 2004 Version. IEEE Computer Society. 2004. 1-1. 0-7695-2330-7.
  2. Naur. Peter. Brian Randell. Software engineering: Report of a conference sponsored by the NATO Science Committee. Scientific Affairs Division, NATO. 7–11 October 1968. Garmisch, Germany. PDF. 2008-12-26.
  3. Web site: Kalwarski. Tara. Daphne Mosher, Janet Paskin and Donna Rosato. 2006. Best Jobs in America. MONEY Magazine. CNN. 2006-04-20.
  4. Dijkstra. E. W.. Edsger_Dijkstra. Go To Statement Considered Harmful. Communications of the ACM. 11. 3. 147-148. March. 1968. 2008-12-26.
  5. Parnas. David. David Parnas. Communications of the ACM. 15. 12. 1053-1058. On the Criteria To Be Used in Decomposing Systems into Modules. December. 1972. 2008-12-26.
  6. [Eric S. Raymond|Raymond, Eric S.]
  7. N.S.W.. Williams. Professional Engineers Ontario's approach to licensing software engineering practitioners. Software Engineering Education and Training, 2001 Proceedings. 14th Conference on. 77 - 78. IEEE. 19-21 Feb 2001. Charlotte, NC.
  8. http://www.computer.org/portal/cms_docs_computer/computer/content/code-of-ethics.pdf Software Engineering Code of Ethics
  9. http://computer.org/sevocab
  10. Bureau of Labor Statistics, U.S. Department of Labor, [ftp://ftp.bls.gov/pub/news.release/ocwage.txt ''USDL 05-2145: Occupational Employment and Wages, November 2004''], Table 1.
  11. Web site: Software Engineering. 2008-02-01.
  12. http://www.ideosphere.com/fx-bin/Claim?claim=ITJOBS Future of IT Jobs in America
  13. http://www.computer.org/portal/cms_docs_software/software/homepage/2008/s6car.pdf Kruchten, Philippe, "Licensing Software Engineers?", IEEE SOFTWARE nov/dec 2008
  14. Web site: A Summary of the ACM Position on Software Engineering as a Licensed Engineering Profession. ACM. July 17, 2000. Association for Computing Machinery (ACM). 2009-03-03. At its meeting in May 2000, the Council further concluded that the framework of alicensed professional engineer, originally developed for civil engineers, does notmatch the professional industrial practice of software engineering. Such licensingpractices would give false assurances of competence even if the body of knowledgewere mature; and would preclude many of the most qualified software engineersfrom becoming licensed..
  15. Web site: IEEE Computer Society. 2006 IEEE computer society report to the IFIP General Assembly. PDF. 2007-04-10.
  16. Web site: Canadian Information Processing Society. I.S.P. Designation. 2007-03-15.
  17. Web site: The Top 10 Problems with IT Certification in 2008. Wyrostek. Warren. March 14, 2008. InformIT. 2009-03-03.
  18. http://www.computerworld.com/printthis/2006/0,4814,111202,00.html As outsourcing gathers steam, computer science interest wanes
  19. http://www.bls.gov/oco/ocos110.htm#outlook Computer Programmers
  20. http://www.infoworld.com/article/07/03/13/HNslowsoftdev_1.html Software developer growth slows in North America | InfoWorld | News | 2007-03-13 | By Robert Mullins, IDG News Service
  21. http://www.computerworld.com/action/article.do?command=viewArticleTOC&specialReportId=9000100&articleId=112360 Hot Skills, Cold Skills
  22. http://itmanagement.earthweb.com/career/article.php/3523066 Dual Roles: The Changing Face of IT
  23. McConnell, Steve (July 10, 2003. Professional Software Development: Shorter Schedules, Higher Quality Products, More Successful Projects, Enhanced Careers. ISBN 978-0321193674.
  24. [Ian Sommerville (academic)|Ian Sommerville]
  25. Table 2 in Chapter 1,Web site: Guide to the Software Engineering Body of Knowledge. February 6, 2004. 2008-02-21.