Computer System Engineering 6.033 Spring 2009

Author:

Access: Public Instant Grading

Start FlashCards Download PDF Learn

Get Jobilize Job Search Mobile App in your pocket Now!

Get it on Google Play Download on the App Store Now
The objective of this session is to introduce the subject of software engineering. When you have read this session you will understand what software engineering is and why it is important, know the answers to key questions which provide an introduction to software engineering, understand ethical and professional issues which are important for software engineers.

Introduction

Virtually all countries now depend on complex computer-based systems. More and more products incorporate computers and controlling software in some form. The software in these systems represents a large and increasing proportion of the total system costs. Therefore, producing software in a cost-effective way is essential for the functioning of national and international economies.

Software engineering is an engineering discipline whose goal is the cost-effective development of software systems. Software is abstract and intangible. It is not constrained by materials, governed by physical laws or by manufacturing processes. In some ways, this simplifies software engineering as there are no physical limitations on the potential of software. In other ways, however, this lack of natural constraints means that software can easily become extremely complex and hence very difficult to understand.

Software engineering is still a relatively young discipline. The notion of ‘software engineering’ was first proposed in 1968 at a conference held to discuss what was then called the ‘software crisis’. This software crisis resulted directly from the introduction of powerful, third generation computer hardware. Their power made hitherto unrealisable computer applications a feasible proposition. The resulting software was orders of magnitude larger and more complex than previous software systems.

Early experience in building these systems showed that an informal approach to software development was not good enough. Major projects were sometimes years late. They cost much more than originally predicted, were unreliable, difficult to maintain and performed poorly. Software development was in crisis. Hardware costs were tumbling whilst software costs were rising rapidly. New techniques and methods were needed to control the complexity inherent in large software systems.

These techniques have become part of software engineering and are now widely although not universally used. However, there are still problems in producing complex software which meets user expectations, is delivered on time and to budget. Many software projects still have problems and this has led to some commentators (Pressman, 1997) suggesting that software engineering is in a state of chronic affliction.

As our ability to produce software has increased so too has the complexity of the software systems required. New technologies resulting from the convergence of computers and communication systems place new demands on software engineers. For this reason and because many companies do not apply software engineering techniques effectively, we still have problems. Things are not as bad as the doomsayers suggest but there is clearly room for improvement.

This course covers topics on the engineering of computer software and hardware systems: techniques for controlling complexity; strong modularity using client-server design, virtual memory, and threads; networks; atomicity and coordination of parallel activities; recovery and reliability; privacy, security, and encryption; and impact of computer systems on society. Case studies of working systems and readings from the current literature provide comparisons and contrasts. Two design projects are required, and students engage in extensive written communication exercises.

Exam PDF eBook: 
Computer System Engineering 6.033 Spring 2009
Download Computer Engineering Exam PDF eBook
18 Pages
2014
English US
Educational Materials



Sample Questions from the Computer System Engineering 6.033 Spring 2009 Exam

Question: 2. [8 points]: Which of the following statements is true of the X Window System as described in Reading #6 (Scheifler and Gettys. "The X window System”, ACM Trans. on Graphics, Vol 5, 2, April 1986)?

Choices:

True

False

Question: 3. [8 points]: Which of the following statements about the Lockset algorithm as used in the Race-Track paper (Reading #7 "RaceTrack: Efficient Detection of Data Race Conditions via Adaptive Tracking” by Yu, Rodeheffer, and Chen, Proc. of the 20th ACM Symposium on Operating Systems Principles, 2005) is true?

Choices:

True

False

Question: 1. [6 points]: Which of the following statements is true for UNIX as described in reading #5 (Ritchie and Thompson. "The UNIX time-sharing system”, Bell System Technical Journal, 57, 6, part 2, 1978)?

Choices:

True

False

Question: 2. [8 points]: Which of the following statements is true of the X Window System as described in Reading #6 (Scheifler and Gettys. "The X window System”, ACM Trans. on Graphics, Vol 5, 2, April 1986)?

Choices:

True

False

Question: 2. [8 points]: Which of the following statements is true of the X Window System as described in Reading #6 (Scheifler and Gettys. "The X window System”, ACM Trans. on Graphics, Vol 5, 2, April 1986)?

Choices:

True

False

Question: 1. [6 points]: Which of the following statements is true for UNIX as described in reading #5 (Ritchie and Thompson. "The UNIX time-sharing system”, Bell System Technical Journal, 57, 6, part 2, 1978)?

Choices:

True

False

Question: 2. [8 points]: Which of the following statements is true of the X Window System as described in Reading #6 (Scheifler and Gettys. "The X window System”, ACM Trans. on Graphics, Vol 5, 2, April 1986)?

Choices:

True

False

Question: 1. [6 points]: Which of the following statements is true for UNIX as described in reading #5 (Ritchie and Thompson. "The UNIX time-sharing system”, Bell System Technical Journal, 57, 6, part 2, 1978)?

Choices:

True

False

Question: 1. [6 points]: Which of the following statements is true for UNIX as described in reading #5 (Ritchie and Thompson. "The UNIX time-sharing system”, Bell System Technical Journal, 57, 6, part 2, 1978)?

Choices:

True

False

Question: 1. [6 points]: Which of the following statements is true for UNIX as described in reading #5 (Ritchie and Thompson. "The UNIX time-sharing system”, Bell System Technical Journal, 57, 6, part 2, 1978)?

Choices:

True

False

Question: 1. [6 points]: Which of the following statements is true for UNIX as described in reading #5 (Ritchie and Thompson. "The UNIX time-sharing system”, Bell System Technical Journal, 57, 6, part 2, 1978)?

Choices:

True

False

Start FlashCards Download PDF Learn
Source:  Morris, Robert, and Samuel Madden. 6.033 Computer System Engineering, Spring 2009. (MIT OpenCourseWare: Massachusetts Institute of Technology), http://ocw.mit.edu/courses/electrical-engineering-and-computer-science/6-033-computer-system-engineering-spring-2009 (Accessed 2 May, 2014). License: Creative Commons BY-NC-SA
Saylor Foundation
Start Quiz
David Bourgeois
Start Quiz
Copy and paste the following HTML code into your website or blog.
<iframe src="https://www.jobilize.com/embed/computer-system-engineering-exam-by-prof-robert-morris-mit" width="600" height="600" frameborder="0" marginwidth="0" marginheight="0" scrolling="yes" style="border:1px solid #CCC; border-width:1px 1px 0; margin-bottom:5px" allowfullscreen webkitallowfullscreen mozallowfullscreen> </iframe>