All of the program requirements must be completely defined before design begins.
All of the program design must be complete before any coding begins.
All of the coding must be complete before any testing can begin.
Different development activities often take place concurrently, overlapping in the software life cycle.
Fill in the blanks. "Software specifications tell exactly ____________________________________a program will do, but not _________________________________."
Name two ways in which you can make your programs meet Goal 2: "Quality software can be read and understood."
Explain why software might need to be modified
in the design phase
in the coding phase
in the testing phase
in the maintenance phase
Goal 4 says, "Quality software is completed on time and within budget."
Explain some of the consequences of not meeting this goal for a student preparing a class programming assignment.
Explain some of the consequences of not meeting this goal for a team developing a highly competitive new software product.
Explain some of the consequences of not meeting this goal for a programmer who is developing the user interface (the screen input/output) for a spacecraft launch system.
What is the first step in developing any software program?
You are working on a class programming assignment, and the details of one of the requirements are ambiguous. What are some ways of dealing with this problem?
There is usually one way of solving a problem that is clearly better than any other. (True or False?)
Write a top-down design for making a birthday cake.
Explain what is mean by "information hiding." Why is the following section of code an example of information hiding?
What separates the logical properties of a program's data or functions from its implementation?
Give an example of data abstraction.
The documentation of a program should begin as soon as the testing is complete so that the documentation perfectly matches the final correct version of the program. (True or False?)
What is meant by "external documentation"? Give two examples.
Suggest where some comments could be added to the following code segment to make it more understandable:
for (int i = 0, i < maxIndex , i++ )
processEntry (list, i, false, 100, successFlag);
Use the idea of self-documenting code to make the following code segment more understandable:
{
double x, y, z ;
:
:
z = x * 3.1417 * (y * y)
{
True or False? (Correct any false statements.) Good programming practices dictate that
a procedure should be written before its specifications.
when doing top-down design, you should try to avoid changing the main program as you work on lower levels.
when doing top-down design, you should always first decide on the data structures that will be used.
What part of a program's code is analogous to the main module of the top-down design?