Programming Principles and Practice Using C 1st Edition Bjarne Stroustrup
Programming Principles and Practice Using C 1st Edition Bjarne Stroustrup
com
https://ebookname.com/product/programming-principles-and-
practice-using-c-1st-edition-bjarne-stroustrup/
OR CLICK BUTTON
DOWNLOAD EBOOK
https://ebookname.com/product/object-oriented-programming-using-
c-fourth-edition-joyce-farrell/
https://ebookname.com/product/programming-fundamentals-a-modular-
structured-approach-using-c-kenneth-leroy-busbee/
https://ebookname.com/product/goddess-traditions-in-tantric-
hinduism-history-practice-and-doctrine-1st-edition-bjarne-
wernicke-olesen-editor/
https://ebookname.com/product/an-introduction-to-political-
philosophy-1st-edition-alexander-rainy-maclean-murray/
Democratic Theorizing from the Margins 1st Edition
Marla Brettschneider
https://ebookname.com/product/democratic-theorizing-from-the-
margins-1st-edition-marla-brettschneider/
https://ebookname.com/product/working-with-dreams-initiation-
into-the-soul-s-speaking-about-itself-1st-edition-wolfgang-
giegerich/
https://ebookname.com/product/syntax-a-functional-typological-
introduction-volume-ii-talmy-givon/
https://ebookname.com/product/making-the-british-
empire-1660-1800-1st-edition-jason-peacey/
https://ebookname.com/product/the-introduction-to-the-magee-
system-of-technical-analysis-2nd-edition-w-h-c-bassetti/
Encyclopedia of law enforcement 1st Edition Larry E.
Sullivan
https://ebookname.com/product/encyclopedia-of-law-
enforcement-1st-edition-larry-e-sullivan/
Programming
Programming
Principles and Practice
Using C++
Bjarne Stroustrup
./.,· Addison-Wesley
Upper Saddle River, NJ • Boston • Indianapolis • San Francisco
New York • Toronto • Montreal • London • Munich • Paris • Madrid
Capetown • Sydney • Tokyo • Singapore • Mexico City
Many of the designations used by manufacturers and sellers to distinguish their products arc claimed as
trademarks. Where those designations appear in this book. and tl1c publisher was aware of a trademark
claim, the designations have been primed witl1 initial capital letters or in all capitals.
The author and publisher have taken care in the preparation of this book, but make no expressed or im·
plied warran t y of any kind and assume no responsibility for errors or omissioru. No liability is assumed
for incidental or consequential damages in connection witl1 or arising out of the usc of the information or
programs contained herein.
The publisher offers excellent discounts on tllis book when ordered in quantity for bulk purcl!ases or spe
cial sales, wllich may include electronic versions and/or custom covers and content particular to your busi
ness. training goals. marketing focus. and branding interests. For more information. please contact:
International Sales
[email protected]
Stroustrup, Bjame.
Programming principles and practice using C++ I Bjamc Stroustrup.
P· em.
Includes bibliographical references and index.
ISBN 978-0-321-54372·1 (pbk. : alk. paper) I. C++ (Computer program language) I. Title.
QA76.73.C153S82 2008
005.13'3-dc22
2008032595
AU rights reserved. Printed in the United States of America. ll1is publication is protected by copyright, and
permission must be obtained from tl1c publisher prior to any prohibited reproduction, storage in a retrieval
system, or transmission in any form or by any means. electronic, mechanical, photocopying, recording, or
likewise. For information regarding pemlissions, write to:
ISBN-13: 978·0·321·54372·1
ISBN-10: 0-321-54372·6
Text printed in the United States on recycled paper at Courier in Kendallville, Indiana.
Ftrst printing, December 2008
Contents
Preface xxiii
Chapter 0 Notes to the Reader
0.1 The structure of this book 2
0.1. 1 General approach 3
0.1.2 Drills, exercises, etc. 4
0.1.3 What comes after this book? 5
0.2 A philosophy of teaching and learning 6
0.2.1 The order of topics 9
0.2.2 Programming and programming language 10
0.2.3 Portability 11
0.3 Programming and computer science 12
0.4 Creativity and problem solving 12
0.5 Request for feedback 12
0.6 References 13
0.7 Biographies 14
Bjame Stroustrup 14
Lawrence "Pete" Petersen 15
"
vi CONTENTS
2. 1 Programs 44
2.2 T he classic first program 45
2.3 Compilation 47
2.4 Linking 51
2.5 Programming environments 52
Chapter 4 Computation 89
4.1 Computation 90
4.2 Objectives and tools 92
CONTENTS vii
4.3 Expressions 94
4.3.1 Constant expressions 95
4.3.2 Operators 96
4.3.3 Conversions 98
4.4 Statements 99
4.4.1 Selection 101
4.4.2 Iteration 108
4.5 Functions 1 12
4.5.1 Why bother with functions? 114
4.5.2 Function declarations 115
4.6 Vector 1 16
4.6.1 Growing a vector 118
4.6.2 A numeric example 119
4 .6.3 A text example 121
4.7 Language features 123
Chapter 5 Errors 1 31
5. 1 Introduction 132
5.2 Sources of errors 134
5.3 Compile-time errors 134
5.3.1 Syntax errors 135
5.3.2 Type errors 136
.5.3.3 Non-errors 137
5.4 Link-time errors 137
5.5 Run-time errors 138
5.5.1 T he caller deals with errors 140
5.5.2 l11e callee deals with errors 141
5.5.3 Error reporting 143
5.6 Exceptions 144
5.6.1 Bad arguments 145
5.6.2 Range errors 146
5.6.3 Bad input 148
5.6.4 Narrowing errors 151
5.7 Logic errors 152
5.8 Estimation 155
5.9 Debugging 156
5.9.1 Practical debug advice 1S7
5. 10 Pre- and post-conditions 161
5.10.1 Post·conditions 163
5. 1 1 Testing 164
viii CONTENTS
Glossary 1171
Bibliography 1177
Index 1181
Preface
-Admiral Farragut
xxiii
xxiv PREFACE
Why would you want to program? Our civilization runs on software. With·
out understanding software you are reduced to believing in "magic" and will be
locked out of many of the most interesting, profitable, and socially useful techni
cal fields of work. When I talk about programming, I think of the whole spec
trum of computer programs from personal computer applications with G Uls
(graphical user interfaces), through engineering calculations and embedded sys
tems control applications (such as digital cameras, cars, and cell phones), to text
manipulation applications as found in many humanities and business applica
tions. Like mathematics, programming- when done well- is a valuable intellec
tual exercise that sharpens our ability to think. However, thanks to feedback
from the computer, programming is more concrete than most forms of math, and
therefore accessible to more people. It is a way to reach out and change the world
- ideally for the better. Finally, programming can be great fun.
W hy C++? You can't learn to program without a progranmung language,
and C++ directly supports the key concepts and techniques used in real-world
software. C++ is one of the most widely used programming languages, found in
an unsurpassed range of application areas. You fmd C++ applications every·
where from the bottom of the oceans to the surface of Mars. C++ is precisely
and comprehensively defmed by a nonproprietary international standard. Qyal·
ity and/or free implementations are available on every kind of computer. Most of
the programming concepts that you will learn using C++ can be used directly in
other languages, such as C, C#, Fortran, andjava. Fmally, I simply like C++ as
a language for writing elegant and efficient code.
This is not the easiest book on beginning programming; it is not meant to
be. I just aim for it to be the easiest book from which you can learn the basics of
real-world programming. That's quite an ambitious goal because much modern
software relies on techniques considered advanced just a few years ago.
My fundamental assumption is that you want to write programs for the use
of others, and to do so responsibly, providing a decent level of system quality:
that is, I assume that you want to achieve a level of professionalism. Consc·
quently, I chose the topics for this book to cover what is needed to get started
with real-world programming. not just what is easy to teach and learn. If you
need a technique to get basic work done right, I describe it. demonstrate concepts
and language facilities needed to support the technique, provide exercises for it,
and expect you to work on those exercises. If you just want to understand toy
programs, you can get along with far less than I present. On the other hand, I
won't waste your time with material of marginal practical importance. If an idea
is explained here, it's because you'll almost certainly need it.
If your desire is to use the work of others without understanding how things
arc done and witl10ut adding significantly to the code yourself, tills book is not
for you. If so, please consider whether you would be better served by another
book and another language. If that is approximately your view of programming,
please also consider from where you got that view and whether it in fact is adc·
quate for your needs. People often underestimate the complexity of program-
P R E F AC E XXV
ming as well as its value. I would hate for you to acquire a dislike for program
ming because of a mismatch between what you need and the pa11 of the software
reality I describe. There are many parts of the "information technology" world
that do not require knowledge of programming. This book is aimed to serve
those who do want to write or understand nontrivial programs.
Because of its structure and practical aims, this book can also be used as a
second book on programming for someone who already knows a bit of C++ or
for someone who programs in another language and wants to learn C++. If you
fit into one of those categories, I refrain from guessing how long it will take you
to read this book, but I do encourage you to do many of the exercises. This will
help you to counteract the common problem of writing programs in older. famil
iar styles rather than adoptirlg newer techniques where these are more appropri
ate. If you have learned C++ in one of the more traditional ways, you'll find
something surprising and useful before you reach Chapter 7. Unless your name
is Stroustrup, what I discuss here is not "your father's C++."
Programming is learned by writirlg programs. In this, programming is similar
to other endeavors with a practical component. You cannot learn to swim, to play
a musical instrument, or to drive a car just from reading a book - you must prac
tice. Nor can you learn to program without reading and writirlg lots of code. This
book focuses on code examples closely tied to explanatory text and diagrams. You
need those to understand the ideals, concepts, and principles of programming and
to master the language constructs used to express them. That's essential, but by it
self, it will not give you the practical skills of programming. For that, you need to
do the exercises and get used to the tools for writirlg, compiling, and running pro
grams. You need to make your own mistakes and learn to correct them. There is
no substitute for writing code. Besides, that's where the fun is!
On the other hand, there is more to programming - much more - than fol·
lowing a few rules and reading the manual. This book is emphatically not fo
cused on "the syntax of C++." Understanding the fundamental ideals, principles,
and techniques is the essence of a good progranuner. Only well-designed code
has a chance of becoming part of a correct, reliable, and maintainable system.
Also, "the fundamentals" are what last: they will still be essential after today's
languages and tools have evolved or been replaced.
What about computer science, software engineering, information technol·
ogy, etc.? Is that all programming? Of course not! Programming is one of the
fundamental topics that underlie everything in computer-related fields, and it has
a natural place in a balanced course of computer science. I provide brief intro
ductions to key concepts and techniques of algorithms, data structures, user in
terfaces, data processing, and software engineering. However, this book is not a
substitute for a thorough and balanced study of those topics.
Code can be beautiful as well as useful. This book is written to help you see
that, to understand what it means for code to be beautiful, and to help you to
master the principles and acquire the practical skills to create such code. Good
luck with programming!
xxvi PRE FACE
A note to students
Of the 1000+ first-year students we have taught so far using drafts of this book at
Texas A&M University, about 60% had programmed before and about 40% had
never seen a line of code in their lives. Most succeeded, so you can do it, too.
You don't have to read this book as part of a course. I assume that the book
will be widely used for self-study. However, whether you work your way through
as part of a course or independently, try to work with others. Programming has
an - unfair - reputation as a lonely activity. Most people work better and learn
faster when they are part of a group with a common aim. Learning together and
discussing problems with friends is not cheating! It is the most efficient - as well
as most pleasant - way of making progress. If nothing else, working with friends
forces you to articulate your ideas, which is just about the most efficient way of
testing your understanding and making sure you remember. You don't actually
have to personally discover the answer to every obscure language and program
ming environment problem. However, please don't cheat yourself by not doing
the drills and a fair number of exercises (even if no teacher forces you to do
them). Remember: programming is (among other things) a practical skill that
you need to practice to master. If you don't write code (do several exercises for
each chapter), reading this book will be a pointless theoretical exercise.
Most students - especially thoughtful good students - face times when they
wonder whether their hard work is worthwhile. When (not iJ) this happens to you,
take a break, reread t11e preface, and look at Chapter 1 ("Computers, People, and
Programming") and Chapter 22 ("Ideals and History"). There, I try to articulate
what I find exciting about programming and why I consider it a crucial tool for
making a positive contribution to the world. If you wonder about my teaching phi
losophy and general approach, have a look at Chapter 0 ("Notes to the Reader").
You might find the weight of this book worrying, but it should reassure you
that part of the reason for the heft is that I prefer to repeat an explanation or add an
example rat11er than have you search for t11e one and only explanation. The other
major part of the reason is that the second half of the book is reference material and
"additional material" presented for you to explore only if you are interested in
more information about a specific area of programming, such as embedded sys·
tems programming, text analysis, or numerical computation.
And please don't be too impatient. Learning any major new and valuable
skill takes time and is worth it.
A note to teachers
No. This is not a traditional Computer Science 101 course. It is a book about
how to construct working software. As such, it leaves out much of what a com·
puter science student is traditionally exposed to (Turing completeness, state rna·
P R E FACE xxvii
Support
The book's support website, www.stroustrup.com/Programmi ng, contains a va
riety of materials supporting the teaching and learning of programming using
tlus book. The material is likely to be improved with time, but for starters, you
can find:
Acknowledgments
I'd especially like to thank my late colleague and co-teacher Lawrence "Pete" Pe
tersen for encouraging me to tackle the task of teaching beginners long before I'd
otherwise have felt comfortable doing that, and for supplying the practical teach
ing experience to make the course succeed. W ithout him, the first version of the
course would have been a failure. We worked together on the first versions of the
course for which tills book was designed and together taught it repeatedly, learn
ing from our experiences, improving the course and the book. My use of "we" in
this book initially meant "Pete and me."
xxviii P R E FA C E
Thanks to the students, teaching assistants, and peer teachers of ENGR 112
at Texas A&M University who directly and indirectly helped us construct this
book, and to Walter Daugherity, who has also taught the course. Also thanks to
Damian Dechev, Tracy Hammond, Arne Tolstrup Madsen, Gabriel Dos Reis,
Nicholas Stroustrup,J. C. van Wmkcl, Greg Versoonder, Ronnie Ward, and Leor
Zolman for constructive comments on drafts of this book. T hanks to Mogens
Hansen for explaining about engine control software. Thanks to AI Aho , Stephen
Edwards, Brian Kernighan, and Daisy Nguyen for helping me hide away from
distractions to get writing done during the summers.
Thanks to the reviewers that Addison-Wesley found for me. T heir comments,
mostly based on teaching either C++ or Computer Science 101 at the college
level, have been invaluable: Richard Enbody, David Gustafson, Ron McCarty,
and K. Narayanaswamy. Also thanks to my editor, Peter Gordon, for many useful
comments and (not least) for his patience. I'm very grateful to the production
team assembled by Addison-Wesley; they added much to the quality of the book:
Julie Grady (proofreader), Chris Keane (compositor), Rob Mauhar (illustrator),
Julie Nahil (production editor), and Barbara Wood (copy editor).
In addition to my own unsystematic code checking, Bashar Anabtawi, Yinan
Fan, and Yuriy Solodkyy checked all code fragments using Microsoft C++ 7.1
(2003) and 8.0 (2005) and Gee 3.4.4.
I would also like to thank Brian Kernighan and Doug Mcilroy for setting a
very high standard for writing about programming, and Dennis Ritchie and Kristen
Nygaard for providing valuable lessons in practical language design.
t_
,..
0
will fmd most parts immediately useful. If you are reading this
book without the benefit of a good teacher, please don't try to
structure of this book" and the first part of the "A philosophy of
reread this chapter once you feel comfortable writing and execut
0.1 The structure of this book 0.3 Programming and computer science
0.1.1 General approach 0.4 Creativity and problem solving
0.1.2 Drills, exercises, etc.
0.1.3 What comes after this bookJ 0.5 Request for feedback
0.2 A philosophy of teaching and 0.6 References
learning 0.7 Biographies
0.2.1 The order of topics
0.2.2 Programming and programming
language
0.2.3 Portability
Unfortunately. the world of programming doesn't really fall into four cleanly sep
arated parts. l11ereforc, the "parts'' of this book provide only a coarse classifica
tion of topics. We consider it a useful classification (obviously, or we wouldn't
have used it). but reality has a way of escaping neat classifications. For example,
we need to usc input operations far sooner than we can give a thorough explana
tion of C++ standard 110 streams (input/output streams). W here the set of topics
needed to present an idea conflicts with the overall classification, we explain the
minimum needed for a good presentation, rather than just referring to the com
plete explanation elsewhere. Rigid classifications work much better for manuals
than for tutorials.
The order of topics is determined by programming techniques. rather than
programming language features; see §0.2. For a presentation organized around
language features, see Appendix A.
To ease review and to help you if you miss a key point during a first reading fj
where you have yet to discover which kind of information is crucial, we place
three kinds of "alert markers'' in the margin:
worked on a few exercises, you'll often find that you have to go back to reread a
few sections and that several days have gone by. We have clustered the chapters
into "parts" focused on a major topic. such as input/output. These parts make
good units of review.
Common praise for a textbook is "It answered all my questions just as I
thought of them!" That's an ideal for minor teclmical questions, and early read
ers have observed the phenomenon with this book. However, that cannot be the
whole ideal. We raise questions that a novice would probably not think of. We
aim to ask and answer questions that you need to consider to write quality soft
ware for the use of others. Learning to ask the right (often hard) questions is an
essential part of learning to think as a programmer. Asking only the easy and ob
vious questions would make you feel good, but it wouldn't help make you a pro
grammer.
We try to respect your intelligence and to be considerate about your tin1e. In
our presentation, we aim for professionalism rather than cuteness, and we'd
rather understate a point than hype it. We try not to exaggerate the importance
of a progranlming technique or a language feature, but please don't underesti
mate a simple statement like "This is often useful." If we quietly emphasize tl1at
something is important, we mean that you'll sooner or later waste days if you
don't master it. Our use of humor is more linllted than we would have preferred.
but experience shows that people's ideas of what is fmmy differ dramatically and
that a failed attempt at humor can be confusing.
We do not pretend tl1at our ideas or the tools offered are perfect. No tool, li
brary, language, or technique is "the solution" to all of the many challenges fac
ing a programmer. At best, it can help you to develop and express your solution.
We try hard to avoid "white lies" ; that is, we refrain from oversin1plified explana
tions that are clear and easy to understand, but not true in the context of real lan
guages and real problems. On the other hand. this book is not a reference; for
more precise and complete descriptions of C++. see Bjame Stroustrup, 77U' C++
Programmu1g La11guage, Special Edition (Addison-Wesley, 2000) , and the ISO C++
standard.
Exercises: Some exercises are trivial and others are very hard, but most
arc intended to leave some scope for initiative and imagination. If you
are serious, you'll do quite a few exercises. At least do enough to know
which are difficult for you. Then do a few more of those. l11at's how
you'll learn the most. The exercises are meant to be manageable without
exceptional cleverness, rather than to be tricky puzzles. However, we
hope that we have provided exercises that are hard enough to challenge
anybody and enough exercises to exhaust even the best student's avail
able time. We do not expect you to do them all, but feel free to try.
In addition, we recommend that you (every student) take part in a small project
(and more if time allows for it) . A project is intended to produce a complete useful
program. Ideally, a project is done by a small group of people (e.g., three people)
working together for about a month while working through the chapters in Part
III. Most people find the projects the most fun and what ties everything together.
Some people like to put the book aside and try some examples before read
ing to the end of a chapter; others prefer to read ahead to the end before trying to
get code to run. To support readers with the former preference, we provide sim
ple suggestions for practical work labeled "Try this:" at natural breaks in the
text. A Try this is generally in the nature of a drill focused narrowly on the topic
that precedes it. If you pass a Try this without trying - maybe because you are
not near a computer or you fmd the text riveting - do return to it when you do
the chapter drill; a Try this either complements the chapter drill or is a part of it.
At the end of each chapter you'll find a set of review questions . They are in
tended to point you to the key ideas explained in the chapter. One way to look at
the review questions is as a complement to the exercises : the exercises focus on the
in , whereas the review questions try to help you ar
practical aspects of progranlffig
ticulate the ideas and concepts. In that, they resemble good interview questions.
The "Terms" section at the end of each chapter presents the basic vocabulary
of programming and of C++. If you want to understand what people say about
programming topics and to articulate your own ideas, you should know what
each means.
Learning involves repetition. Our ideal is to make every important point at
least twice and to reinforce it with exercises .
course not! When done well, programming is a subtle, deep, and highly skilled U
art building on a variety of technical skills. You should no more expect to be an
expert at programming in four months than you should expect to be an expert in
biology, in math, in a natural language (such as Chinese, English, or Danish), or
at playing the violin in four months - or in half a year, or a year. What you
6 CHAPTER 0 • N OT E S TO T H E R E A D E R
should hope for, and what you can expect if you approach this book seriously, is
to have a really good start that allows you to write relatively simple useful pro
grams, to be able to read more complex programs, and to have a good concep
tual and practical background for further work.
The best follow-up to this initial course is to work on a real project develop
ing code to be used by someone else. Mter that, or (even better) in parallel with a
real project, read either a professional-level general textbook (such as Stroustrup,
The C++ Programming Language) , a more specialized book relating to the needs of
your project (such as Q5 for GUI, or ACE for distributed programming) , or a
textbook focusing on a particular aspect of C++ (such as Koenig and Moo, Accel
erated C++; Sutter's Exceptional C++; or Gamma et al., Design Patterns) . For com
plete references, see §0.6 or the Bibliography section at the back of the book.
Eventually, you should learn another programming language. We don't con
sider it possible to be a professional in the realm of software - even if you are not
primarily a programmer - without knowing more than one language.
which means,
Beginning of March, beginning of April,
Bring forth the cows from their stables,
For the grass is growing,
And the snow is going.