Computer System Engineering 6.033 Spring 2006

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.

There are 12 questions and 12 pages in this quiz booklet. Answer each question according to the instructions given.

You have 50 minutes to answer the questions.

Most questions are multiple-choice questions. Next to each choice, circle the word True or False,

as appropriate. A correct choice will earn positive points, a wrong choice may earn negative

points, and not picking a choice will score 0.

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



Sample Questions from the Computer System Engineering 6.033 Spring 2006 Exam

Question: 1. [6 points]: Which of the following statements are true of the X Windows System (as described in the X Windows paper, reading # 5)?

Choices:

True

False

Question: 3. [8 points]: Ben Bitdiddle is using a MapReduce cluster (as described in reading #8) to process some data. He finds that some of his programs are running slowly and needs your help to understand which performance enhancements to try. For each of the following MapReduce configurations and suggested enhancements, circle True if the statement about the enhancement is true, and False otherwise.

Choices:

True

False

Question: 1. [6 points]: Which of the following statements are true of the X Windows System (as described in the X Windows paper, reading # 5)?

Choices:

True

False

Question: 3. [8 points]: Ben Bitdiddle is using a MapReduce cluster (as described in reading #8) to process some data. He finds that some of his programs are running slowly and needs your help to understand which performance enhancements to try. For each of the following MapReduce configurations and suggested enhancements, circle True if the statement about the enhancement is true, and False otherwise.

Choices:

True

False

Question: 2. [8 points]: The UNIX designers chose to have the process created by a fork() share (inherit) the open file descriptors of its parent. Which of the following would become more complicated had they decided on an alternate fork() semantics, in which the child process is created with no open file descriptors?

Choices:

True

False

Question: 3. [8 points]: Ben Bitdiddle is using a MapReduce cluster (as described in reading #8) to process some data. He finds that some of his programs are running slowly and needs your help to understand which performance enhancements to try. For each of the following MapReduce configurations and suggested enhancements, circle True if the statement about the enhancement is true, and False otherwise. the entire 1000-node cluster can complete these MapReduce operations in 100 seconds then doubling the CPU performance (task processing rate) of each machine in the cluster may improve performance somewhat but not significantly.

Choices:

True

False

Question: 2. [8 points]: The UNIX designers chose to have the process created by a fork() share (inherit) the open file descriptors of its parent. Which of the following would become more complicated had they decided on an alternate fork() semantics, in which the child process is created with no open file descriptors?

Choices:

True

False

Question: 1. [6 points]: Which of the following statements are true of the X Windows System (as described in the X Windows paper, reading # 5)?

Choices:

True

False

Question: 3. [8 points]: Ben Bitdiddle is using a MapReduce cluster (as described in reading #8) to process some data. He finds that some of his programs are running slowly and needs your help to understand which performance enhancements to try. For each of the following MapReduce configurations and suggested enhancements, circle True if the statement about the enhancement is true, and False otherwise.

Choices:

True

False

Question: 2. [8 points]: The UNIX designers chose to have the process created by a fork() share (inherit) the open file descriptors of its parent. Which of the following would become more complicated had they decided on an alternate fork() semantics, in which the child process is created with no open file descriptors?

Choices:

True

False

Question: 2. [8 points]: The UNIX designers chose to have the process created by a fork() share (inherit) the open file descriptors of its parent. Which of the following would become more complicated had they decided on an alternate fork() semantics, in which the child process is created with no open file descriptors?

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
Anindyo Mukhopadhyay
Start Quiz
Vanessa Soledad
Start Exam
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-samuel-madden-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>