当前位置:首页 > 其他书籍
absolute c++  second edition
absolute c++  second edition

absolute c++ second editionPDF电子书下载

其他书籍

  • 电子书积分:20 积分如何计算积分?
  • 作 者:
  • 出 版 社:
  • 出版年份:2222
  • ISBN:
  • 页数:0 页
图书介绍:
《absolute c++ second edition》目录
标签:

Chapter 1 C++ BASICS 1

1.1 INTRODUCTION TO C+ 2

Origins of the C++ Language 2

C++ and Object-Oriented Programming 3

The Character Of C+++ 3

C++ Terminology y 4

A Sample C++ Program y 4

1.2 VARIABLES, EXPRESSIONS, AND ASSIGNMENT STATEMENTS 6

Identifiers 6

Variables 8

Assignment Statements 10

Pitfall: Uninitialized Variables 12

Tip: Use Meaningful Names 13

More Assignment Statements 13

Assignment Compatibility 14

Literals 15

Escape Sequences 17

Naming Constants 17

Arithmetic Operators and Expressions 19

Integer and Floating-Point Division 21

Pitfall: Division and whole Number 22

Type Casting 23

Increment and Decrement Operators 25

Pitfall: Order of Evaluation 27

1.3 CONSOLE NPT/OUPU 28

output Using cout 28

New Lines in Output 29

Tip: End Each Program with n or endl 30

Formaing for Numbers with a Decimal Point 31

Output with cerr 32

Input Using cin 32

Tip: Line Breaks in l/O 34

1.4 PROGRAM STYLE 35

Comments 35

1.5 LIBRARIES AND NAMESPACES 36

Libraries and include Directives 36

Namespaces 37

Pitfall: Problems with Libra Names 38

Chapter Summa 38

Answers to Self-Test Exercises 39

Programming Projects 41

Chapter 2 FLOW Of CONTROL 45

2.1 BOOLEAN EXPRESSION 46

Building Boolean Expressions 46

Pitfall: Strings of Inequalities 47

Evaluating Boolean Expressions 48

Precedence Rule 50

Pitfall: Integer Values Can Be Used as Boolean Values 54

2.2 BRANCHING MECHANISMS 57

if-else Statements 57

Compound Statements 57

Pitfall: Using in Place of - - 59

Omiing the else 61

Nested Statement 62

Multiway if-else Statement 62

The switch Statement 62

Pitfall: Forgeing a break in a switch Statement 66

Tip: Use switch Statements for Menu 66

Enumeration Types 66

The Conditional Operation 67

2.3 LOOPS 69

The while and do-while Statements 69

Increment and Deement Operators Revisited 72

The Comma Operator 75

The for Statement 76

Tip: Repeat-N-Times Loops 79

Pitfall: Extra Semicolon in a for Statement 79

Pitfall: infinite Loops 80

The break and continue Statement 83

Nested Loops 86

Chapter Summa 86

Answers to Self-Test Exercises 87

Programming Projects 92

Chapter 3 FUNCTION BASICS 95

3.1 PREDEFINED FUNCTIONS 96

Predefined Funions That Retu a Value 96

Predefined void Functions 101

A Random Number Generator 103

3.2 PROGRAMMER-DEFINED FUNCTIONS 108

Defining Functions That Return a Value 108

Alternate Form for Function Declarations 111

Pitfall: Arguments in the Wrong Order m 111

Pitfall: Use the Terms Parameterand Argument in 111

Functctions Calling Functions 112

Example: A Rounding Function 112

Functions That Return a Boolean Value 114

Defining void Functions 115

retuct Statements in void Funions 117

Preconditions and Postconditions 119

main is a Function 119

Recursive Functions 120

3.3 SCOPE RULES 121

Local Variables 122

Procedural Abstraion 122

Global Constants and Global Variables 125

Blocks 128

Nested Scopes 129

Tip: Use Funion Calls in Branching and Loop Statements 129

Variables Declared in a for Loop 130

Chapter Summary 131

Answers to Self-Test Exercises 131

Programming Projects 135

Chapter 4 PARAMETERS AND OVERLOADING 139

4.1 PARAMETERS 140

Call-by-Value Parameters 140

A Fit Look at Call-by-Reference Parameters 143

Call-by-Reference Mechanism in Detail 145

Constant Reference Parameters 147

Example: The swapValues Function 148

Tip: Think of Actions, Not Code 149

Mixed Parameter Lists 150

Tip: What Kind of Parameter to Use 151

Pitfall: Inadvertent Local Variables 152

Tip: Choosing Formal Parameter Names 155

Example: Buying Pizza 155

4.2 OVERLOADING AND DEFAULT ARGUMENTS 158

Introduction to overloading 159

Pitfall: Automatic Type Conversion and Overloading 161

Rules for Resolving overloading 163

Example: Revised Pizza-Buying Program 164

Default Arguments 167

4.3 TESTING AND DEBUGGING FUNCTIONS 169

The assert Mao 169

Stubs and Drivers 170

Chapter Summary 176

Answers to Self-Test Exercises 176

Programming Projects 176

Chapter5 ARRAYS 181

5.1 INTRODluCTION TO ARRAYS 182

Declaring and Referencing Arrays 182

Tip: Use for Loops with Aays 185

Pitfall: Aay Indexes Always Sta with Zero 185

Tip: Use a Defined Constant for the Size of an Aay 185

Aays in Memo 186

Pitfall: Aay Index Out of Range 187

Initializing Aays 189

5.2 ARRAYS IN FUNCTIONS 191

Indexed Variables as Funion Arguments 191

Entire Aays as Funion Arguments 193

TheconstParameter Modifier 196

Pitfall: Inconsistent Use of const Paramete 198

Functions That Retum an Array 198

Example: Production Graph 199

5.3 PROGRAONG WITH ARRAYS 204

Paially Filled Arrays 204

Tip: Do Not Skimp on Formal Paramete 205

Example: Searching an Array 207

Example: Soing an Array 210

5.4 MULTIDlAENSIONAL ARRAYS 214

Multidimensional Array Basics 214

Multidimensional Array Parameters 216

Example: Two-Dimensional Grading Program 217

Chapter Summa 222

Answers to Self-Test Exercises 223

Programming Projects 227

Chapter 6 STRUCTURES AND CLASSES 235

6.1 STRUCTURES 236

Structure Types 238

Pitfall: Forgeing a Semicolon in a Structure Definition 242

Structures as Function Arguments 242

Tip: Use Hierarchical Structures 243

Initializing Structures 246

6.2 CLASSES 249

Defining Classes and Member Functions 249

Encapsulation 254

Public and Private Members 255

Accessor and Mutator Functions 259

Tip: Separate Interface and implementation 261

Tip: A Test for Encapsulation 262

Structures versus Classes 263

Tip: Thinking Objects 265

Chapter Summary 265

Answers to Self-Test Exercises 266

Programming Projects 268

Chapter 7 CONSTRUCTORS AND OTHER TOOLS 271

7.1 CONSTRUCTORS 272

ConstructoTDefinitions 272

Pitfall: Constructors with No Arguments 277

Explicit Constructor Calls 279

Tip: Always Include a Default Constructor 279

Example: BonkAccount Class 282

Class Type Member Variables 288

7.2 MORE TOOLS 291

The const Parameter Modifier 292

Pitfall: Inconsistent Use of const 294

Inline Functions 298

Static Members 299

Nested and Local Class Definitions 304

7.3 VECTORS—A PREVIEWS OF THE STANDARD TEMPLATE LIBRARY 304

Vector Basics 305

Pitfall: Using Square Brackets beyond the Vector Size 308

Tip: Vector Assignment Is Well Behaved 309

Efficiency Issues 309

Chapter Summa 311

Answers to Self-Test Exercises 311

Programming Projects 314

Chapter 8 OPERATOR OVERLOADING, FRIENDS, AND REFERENCES 317

8.1 BASIC OPERATOR OVERLOADING 318

Overloading Basics 319

Tip: A Constructor Can Return an Object 324

Returning by const Value 325

Tip: Retuing Member Variables of a Class Type 328

Overloading Una Operators 329

Overloading as Members Functions 330

Tip: A Class Has Access to All its objects 332

Overloading Function Application ( ) 333

Pitfall: Overloading , ll, and the Comma Operator 334

8.2 FRIEND FUNCTIONS AND AUTOMATk TYPE CONVERSION 334

Constructors for Automatic Type Conversion 334

Pitfall: Member Operators and Automatic Type Conversion 335

Friend Functions 336

Pitfall: Compilers without Friends 340

Friend Classes 340

8.3 REFERENCES AND MORE OVERLOADED OPERATORS 342

References 342

Pitfall: Returning a Reference to Ceain Member Variables 343

Overloading and 344

Tip: What Mode of Retued Value to Use 351

The Assignment Operator 353

Overloading the Increment and Deement Operato 354

Overloading the Array operator 357

Overloading Based on L-Value veus R-value 359

Chapter Summa 359

Answers to self-Test Exercises 360

Programming Projects 362

Chapter 9 STRINGS 367

9.1 AN ARRAY TYPE FOR STRINGS 368

C-String Values and C-String Variables 369

Pitfall:Using and- with C-Strings 373

Other Functions in <cstring> 375

C-String Input and Output 379

9.2 CHARACTER MANIPULATION TOOLS 382

Character l/O 382

The Member Functions get and put 382

Example: Checking Input Using a Newfine Function 385

Pitfall: Unexpected n in Input 386

The putback, peek, and ignore Member Functions 388

Character-Manipulating Functions 390

Pitfall: toupper and tolower Retu int Values 392

9.3 THE STANDARD CLASS string 394

Introduction to the Standard Class string 394

l/O with the Class string 396

Tip: More Versions of getline 401

Pitfall: Mixing cin variable; and getline 401

String Processing with the Class string 402

Example: Palindrome Testing 406

Converting between string Objes and C-Strings 411

Chapter Summa 411

Answers to Self-Test Exercises 412

Programming Projes 415

Chapter 10 POINTERS AND DYNAMIC ARRAYS 421

10.1 POINTERS 422

Pointer Variables 423

Basic Memo Management 431

Pitfall: Dangling Pointers 434

Dynamic Variables and Automatic Variables 434

Tip: Define Pointer Types 435

Pitfall: Pointers as Call-by-Value Parameters 437

Uses for Pointers 439

10.2 DYNAMIC ARRAYS 439

Array Variables and Pointer Variables 439

Creating and Using Dynamic Aays 441

Example: A Function That Retus an Aay 445

Pointer Arithmetic 447

Multidimensional Dynamic Aays 448

10.3 CLASSES POINTERS AND DYNAC ARRAYS 451

The -> Operator 451

The this Pointer 452

Overloading the Assignment Operator 453

Example: A Class for Paially Filled Aays 456

Destructors 463

Copy Constructors 465

Chapter Summary 469

Answers to Self-Test Exercises 470

Programming Projects 472

Chapter 11 SEPARATE COMPILATION AND NAMESPACES 475

11.1SEPARATE COMPILATION 476

Encapsulation Reviewed 477

Header Files and Implementation Files 478

Example: DigitalTime Class 486

Tip: Reusable Components 487

Using #ifndef 487

Tip: Defining Other Libraries 490

11.2 NAMESPACES 491

Namespaces and using Directives 491

Creating a Namespace 493

Using Declarations 496

Qualifying Names 498

Tip: Choosing a Name for a Namespace 500

Example: A Class Definition in a Namespace 501

Unnamed Namespaces 502

Pitfall: Confusing the Global Namespace and the Unnamed Namespace 509

Tip: Unnamed Namespaces Replace the static Qualifer 509

Tip: Hiding Helping Functions 509

Nested Namespaces 510

Tip: What Namespace Specification Should You Use? 510

Chapter Summa 514

Answers to Self-Test Exercises 514

Programming Projects 516

Chapter 12 STREAMS AND FILE l/O 519

12.1 l/O STREAMS 521

File l/O 521

Pitfall: Restrictions on Stream Variables 526

Appending to a File 526

Tip: Another Syntax for Opening a File 528

Tip: Check That a File Was Opened Successfully 529

Character l/O 532

Checking for the End of a File 533

12.2 TOOLS FOR STREAM l/O 537

File Names as Input 537

Formaing output with Stream Functions 538

Manipulators 542

Saving Flag Seings 543

More Output Stream Member Functions 544

Example: Cleaning Up a File Format 546

Example: Editing a Text File 548

12.3 STREAM HIERARCHIES: A PREVIEW OF INHERITANCE 551

Inheritance among Stream Classes 551

Example: Another newline Function 553

12.4 RANDOM ACCESS TO FILES 557

Chapter Summa 559

Answe to Self-Test Exercises 559

Programming Projects 562

Chapter 13 RECURSION 571

13.1 RECURSIVE void FUNCTIONS 573

Example: Vertical Numbers 573

Tracing a Recursive Call 576

A Closer look at Recuion 579

Pitfall: Infinite Recursion 580

Stacks for Recuion 582

Pitfall: Stack overflow 584

Recursion versus iteration 584

13.2 RECURSIVE FUNCTIONS THAT RETURN A VALUE 585

General Form for a Recursive Function That Retus a Value 585

Example: Another Powers Function 586

13.3 THINKING RECURSIVELY 591

Recursive Design Techniques 591

Bina Search 592

Chapter Summa 601

Answe to Self-Test Exercises 601

Programming Projects 606

Chapter 14 INHERITANCE 609

14.1 INHERITANCE BASICSDerived Classes 610

Constructo in Derived Classes 620

Pitfall: Use of Private Member Variables from the Base Class 622

Pitfall: Private Member Functions Are Effectively Not Inherited 624

The protected Qualifier 624

Redefinition of Member Functions 627

Redefining veus Overloading 629

Access to a Redefined Base Function 630

Functions That Are Not Inherited 631

14.2 PROGRAMANING WITH INHERITANCE 633

Assignment Operato and Copy Constructors in Derived Classes 633

Destructors in Derived Classes 634

Example: Paially Filled Array with Backup 634

Pitfall: Same Object on Both Sides of the Assignment Operator 643

Example: Alteate Implementation of PFArrayDBak 644

Tip: A Class Has Access to Private Membe of All Objects of the Class 647

Tip: “Is a” versus “Has a” 647

Protected and Private Inheritance 648

Multiple Inheritance 649

Chapter Summa 650

Answe to Self-Test Exercises 650

Programming Projects 652

Chapter15 POLYMORPHISM AND VIRTUAL FUNCTIONS 655

15.1 VIRTUAL FUNCTION BASICS 656

LAte Binding 656

Virtual Functions in C+++ 657

Tip: The Virtual Property Is Inherited 664

Tip: When to Use a Virtual Function 664

Pitfall: Omiing the Definition of a Virtual Member Function 665

Abstract Classes and Pure Viual functions 665

Example: An Abstract Class 667

15.2 POINTERS AND VIRTU FUNCTIONS 669

Virtual Functions and Extended Type Compatibility 669

Pitfall: The Slicing Problem 674

Tip: Make Destructo Viual 675

Downcasting and Upcasting 676

How C++ Implements Viual Functions 678

Chapter Summa 679

Answe to Self-Test Exeises 679

Programming Projects 680

Chapter 16 TEMPLATES 683

16.1 FUNCTION TEMPLATES 684

Syntax for Function Templates 686

Pitfall: Compiler Complitions 689

Tip: How to Define Templates 690

Example: A Generic Soing Funion 692

Pitfall: Using a Template with an Inappropriate Type 696

16.2 CLASS TEMPLATES 698

Syntax for Class Templates 698

Example: An Aay Template Class 703

The vector and basic-string Templates 709

16.3 TEMPALTES AND INHERITANCE 709

Example: Template Class for a Partially Filled Array with Backup 710

Chapter Summary 716

Answers to Self-Test Exercises 716

Programming Projects 720

Chapter 17 LINKED DATA STRUCTURES 721

17.1 NODES AND LINKED LISTS 723

Nodes 723

Linked Lists 728

Inserting a Node at the Head of a List 730

Pitfall: Losing Nodes 733

Inseing and Removing Nodes Inside a List 734

Pitfall: Using the Assignment Operator with Dynamic Data Structures 738

Searching a Linked List 738

Example: A Generic Soing Template Version of Linked List Tools 743

17.2 LINKED LIST APPLICATIONS 747

Example: A Stack Template Class 748

Example: A Queue Template Class 755

Tip: A Comment on Namespaces 758

Friend Classes and Similar Alternatives 759

17.3 ITERATORS 762

Pointers as Iterators 762

Iterator Classes 763

Example: An Iterator Class 764

17.4 TREES 771

Tree Propeies 772

Example: A Tree Template Class 775

Chapter Summa 780

Answers to Self-Test Exercises 780

Programming Projects 788

Chapter18 EXCEPTION HANDLING 793

18.1 EXCEPTION HANDLING BASICS 795

A Toy Example of Exception Handling 795

Defining Your Own Exception Classes 804

Multiple Throws and Catches 806

Pitfall: Catch the More Specific Exception First 808

Tip: Exception Classes Can Be Trivial 809

Throwing an Exception in a Function 810

Exception Specification 810

Pitfall: Exception Specification in Derived Classes 814

18.2 PROGRAMMING TECHNIQUES FOR EXCEPTION HANDLING 815

When to Throw an Exception 815

Pitfall: Uncaught Exceptions 817

Pitfall: Nested try-catch Blocks 817

Pitfall: overuse of Exceptions 818

Exception Class Hierarchies 818

Testing for Available Memo 818

Rethrowing an Exception 819

Chapter Summa 819

Answers to Self-Test Exercises 820

Programming Projects 821

Chapter19 STANDARD TEMPLATE LIBRARY 823

19.1 ITERATORS 825

Iterator Basi 825

Kinds of Iterators 831

Constant and Mutable Iterators 834

Revee Iterators 836

Pitfall: Compiler Problems 838

Other Kinds of Iterato 838

19.2 CONTAINERS 839

Sequential Containers 839

Pitfall: Iterato and Removing Elements 844

Tip: Type Definitions in Containers 844

The Container Adapters stack and queue 845

The Associative Containe set and nap 846

Efficiency 851

19.3 GENERc: ALGORITHMS 853

Running Times and Big-ONotation 854

Container Access Running Times 858

Nonmodifying Sequence Algorithms 859

Modifying Sequence Algorithms 863

Set Algorithms 865

Soing Algorithms 865

Chapter Summa 867

Answers to Self-Test Exercises 868

Programming Projects 870

Chapter 20 PATENS AND UML 875

20.1 PATTERNS 876

Adapter Patte 877

The Model-View-Controller Paern 877

Example: A Soing Pattern 879

Efficiency of the Soing Pattern 885

Tip: Pragmatics and Paes 886

Pattern Formalism 886

20.2 UML 887

Histo of UML 887

UML Class Diagrams 888

Class Interactions 889

Chapter Summa 889

Answe to Self-Test Exercises 889

Programming Projects 891

Appendix 1 C+++ Keywords 893

Appendix 2 Precedence of operators 895

Appendix 3 The ASCII Character Set 899

Appendix 4 Some Libra Functions 901

Arithmetic Funions 901

Input and Output Member functions 902

Charaer Functions 903

C-String Functions 904

string Class Functions 906

Random Number Generator 907

Trigonometric functions 908

Appendix5 Old and New Header Files 909

Further Reading 911

lndex 913

相关图书
作者其它书籍
    返回顶部