![]() |
|
|||||||||||||||||
Software engineering(Redirected from Software engineer)
Software engineering (SE) is the profession, practiced by software engineers, concerned with creating and maintaining software applications by applying technologies and practices from computer science, project management, and other fields. Software is the instructions that direct computers to perform useful work, and can be found in every aspect of modern life from life-critical applications like medical-monitoring devices and nuclear power plants to entertainment devices like video-games. Complex software guides space missions while simple software controls microwave ovens. Many software products contain millions of lines of code that are expected to perform properly in the face of changing conditions. All software needs high reliability (with failure being either incovenient or deadly) and needs to be produced economically. These needs are addressed by software engineering. Software engineering techniques improve the functionality and efficiency of applications and the ease and efficiency of software developers. The SE community includes 630,000 practitioners and educators in the U.S. and an estimated 1,400,000 practitioners in the E.U., Asia, and elsewhere; it is about 60% the size of traditional engineering. SE pioneers include Barry Boehm, Fred Brooks, C. A. R. Hoare, and David Parnas. See also List of software engineering topics.
TerminologyOriginsThe term software engineering was used occasionally in the late 1950s and early 1960s. Software engineering was popularized by the 1968 NATO Software Engineering Conference held in Garmisch, Germany and has been in widespread use since. MeaningsAs of 2004, in common parlance the term software engineering is used with at least three distinct meanings:
Software engineers are modeling parts of the real world into the software. Like in the real world changes, also the software changes. Therefore, we can conclude that software engineering is concerned also with the evolution of these models and how they meet changing requirements. LevelsThere are currently no widely accepted criteria for distinguishing someone who is a software engineer from someone who is not a software engineer. In addition, the industry is in the midst of a complex debate on the licensing of practicing software engineers. For the localities that do not license software engineers, some hiring classifications are made based on education and experience. Classification levels may include: entry-level, mid-level, and senior. Typical entry-level software engineers have a bachelor's degree and zero to five years of experience. Typical mid-level software engineers have a bachelor's or master's degree and have five to ten years of experience. Typical senior-level software engineers have an advanced degree and have ten or more years of experience. Note that these are only guidelines that are trends seen in hiring practices and that many exceptions exist. Software engineerSoftware engineering is the practice of creating software, productively and with quality. Members of this profession are called software engineers, programmers, developers, or practitioners. People who write code and do not follow the doctrines of software engineering are more accurately called programmers, developers, or software artists. Software engineering todayImpact of software engineeringSoftware engineering affects economies and societies in many ways.
Successful projects where software engineering methods have been applied include Linux, the space shuttle software, and automatic teller machines. When it is cheaper to run a business or agency with software applications than without, businesses and agencies often invest in computers, software, and personnel. See also software engineering economics. Room for improvementIn spite of the enormous economic growth and productivity gains enabled by software, persistent complaints about the quality remain. See also Debates within software engineering and Criticism of software engineering EducationPeople from many different educational backgrounds make important contributions to SE. The fraction of practitioners who earn computer science or software engineering degrees has been slowly rising. Today, about 1/2 of all software engineers earn computer science or software engineering degrees. For comparison, about 3/4 of all traditional engineers earn engineering degrees.
GraduateGraduate computer science degrees have been available from hundreds of universities for several decades. Graduate software engineering degrees have been available from dozens of universities for a decade or so. UndergraduateUndergraduate computer science degrees are available from most universities. In 1996, Rochester Institute of Technology established the first BSSE degree program in the United States. The program received ABET accreditation in 2003. Since then, software engineering undergraduate degrees have been established at many universities. A standard international curriculum for undergraduate software engineering degrees was recently defined by the CCSE. SecondaryProgramming and coding are being taught to students at an increasingly earlier stage in secondary schools. However, software engineering is not always included in the curriculum. Many have the impression that students are adequately capable of managing projects. Development techniques beyond learning a programming syntax is required . Processes and methodologiesA decades-long goal has been to find processes or methodologies that improve productivity and quality. Some want to systematize or formalize the seemingly-unruly task of writing applications. Others want to apply project management techniques to writing applications. Without project management, software projects can easily be delivered late or over budget. With large numbers of software projects not meeting their expectations in terms of functionality, cost, or delivery schedule, effective project management is proving difficult. See also software development processes and methodologies. Process stepsSoftware engineering requires performing many tasks, notably the following, some of which may not seem to directly produce software.
Waterfall processesThe best-known and oldest process is the waterfall model, where (roughly) developers follow these steps in order. They analyze the problem, design a solution approach, architect a software framework to that solution, develop code, test, deploy, and maintain. There is usually little chance to change the requirements, once the project has begun. The problem is that adequate experience to analyze and specify large systems is almost never available and errors discovered late in the process are expensive to fix. In old style (CMM) processes, architecture and design preceded coding, usually by separate people in a separate process step. Iterative processesIterative development prescribes the construction of an initially small but ever larger portions of a software project to help all those involved to uncover important issues early before problems or faulty assumptions can lead to disaster. Agile processesAgile processes are built on the foundation of iterative development. To that foundation they add a ligher, more people-centric viewpoint than traditional approaches. Agile processes use feedback, rather than planning, as their primary control mechanism. The feedback is driven by regular tests and releases of the evolving software. Extreme Programming is the best-known agile process. In Extreme Programming, the phases are mixed up. Advocates say this is much more effective. Testing is done first, to provide concrete goals for development. Coding comes next. Design and architecture emerge out of refactoring, and come after coding. Design is done by the same people who do the coding. (Only the last feature - blurring together design and code - is common to all the other agile processes.) Formal methodsFormal methods are mathematical approachs to solving software problems. Examples of formal methods are petri nets or automata theory. For instance one can build up and validate application behaviour by designing a system of finite state machines. EmploymentSee also software engineering demographics. Roles in industrySome organizations have specialists to perform each of these tasks. Other organizations required software engineers to do many or all of them. In large projects, people may specialize in only 1 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 Future of IT Jobs in America attempts to answer the question as to whether there will be more IT jobs, including software engineers, in 2012 than there were in 2002. EmployersMost 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 free agents. CertificationCertification is a contentious issue. Some see it as a tool to improve professional practice. Others point out that very few traditional engineers bother with any form of certification. The most successful certification programs are oriented toward specific technologies, and are managed by the vendors. These certification programs are tailored to the institutions that would hire people who pass.
General certification of software practitioners has struggled. The ACM had a professional certification program in the early 1980s, which was discontinued due to lack of interest. Today, the IEEE is certifying software professionals, but only about 500 people have passed the exam by March 2005. 200 people passing the exam every year is not very many.
Technologies and practicesWhat is the best way to make more and better software? SEs advocate many different technologies and practices, with much disagreement. This debate has gone on for 60 years and may continue forever. Software engineers use a wide variety of technologies and practices. Practitioners use a wide variety of technologies, from compilers to word processors to code repositories. SpecificationsThe goal of specifications is to state what the application should do, simply and precisely. Over time, the meaning has changed. In the 1950s, Fortan was advertized as a language that eliminated the need for programming. Engineers could literally write down the equations that they needed. Fortran was originally viewed as a specification language. The problem is that every time languages work at a higher level, specifications are expected to work at the next level, too. Recent approaches try to merge the specification and code into one activity, as this seems to be the only honest way to ensure the specification and code match. While Agile methods propagate specification of all requirements in code, software engineering purists argue for executable specification, which can be achieved by methods like VFSM, trying to avoid the coding activity at all. Comparing related fieldsMany fields are closely related to software engineering. Here are some key similarities and distinctions. Comparing SE with other fields helps explain what SE is and helps define what SE might or should become. There is considerable debate over which fields SE most resembles (or should most resemble). These complex and inexact comparisons explain why some see software engineering as its own field. What is the nature of SE?Software engineering resembles many different fields in many different ways. The following paragraphs make some simple comparisons.
Branch of which field?Is SE (or should SE be) a branch of programming, a branch of computer science, a branch of traditional engineering, or a field that stands on its own? There is considerable debate over this. This has important implications for professionalism, licensing, and ethics. Licensing is a polarizing issue: some fiercely advocate it while others staunchly oppose it.
See also Comparing software engineering and related fields. HistorySoftware engineering has a long evolving history. Both the tools that are used and the applications that are written have evolved over time. It seems likely that software engineering will continue evolving for many decades to come. See also History of software engineering. 60 year time line
Future directions for software engineeringAspect-oriented programming and agile methods are important emerging SE technologies and practices.
The Future of Software Engineering conference (FOSE) held at the ICSE 2000 documented the state of the art of SE in 2000 and listed many problems to be solved over the next decade. The Feyerabend project attempts to discover the future of software engineering by seeking and publishing innovative ideas. Conferences, organizations and publicationsConferencesSeveral academic conferences devoted to software engineering are held every year. There are also many other academic conferences every year devoted to special topics within SE, such as programming languages, requirements, testing, and so on.
Organizations
PublicationsExternal LinksQuotes
The contents of this article are licensed from Wikipedia.org under the GNU Free Documentation License.
How to see transparent copy 01-04-2007 01:21:04 |
|





