초록색 : 작업 완료
붉은색 : 작업 미완
Preface
Chapter1 Getting Started
더보기
- 1.1 Writing a Simple C++ Program
- 1.1.1 Compiling and Executing Our Program
- 1.2 A First Look at Input/Output
- 1.3 A Word about Comments
- 1.4 Flow of Control
- 1.4.1 The while Statement
- 1.4.2 The for Statement
- 1.4.3 Reading an Unknown Number of Inputs
- 1.4.4 The if Statement
- 1.5 Introducing Classes
- 1.5.1 The Sales_item Class
- 1.5.2 A First Look at Member Functions
- 1.6 The Bookstore Program
- Chapter Summary
- Defined Terms
Part1 The Basics
Chapter2 Variables and Basic Types
더보기
- 2.1 Primitive Built-in Types
- 2.1.1 Arithmetic Types
- 2.1.2 Type Conversions
- 2.1.3 Literals
- 2.2 Variables
- 2.2.1 Variable Definitions
- 2.2.2 Variable Declarations and Definitions
- 2.2.3 Identifiers
- 2.2.4 Scope of a Name
- 2.3 Compound Types
- 2.3.1 References
- 2.3.2 Pointers
- 2.3.3 Understanding Compound Type Declarations
- 2.4 const Qualifier
- 2.4.1 References to const
- 2.4.2 Pointers and const
- 2.4.3 Top-Level const
- 2.4.4 constexpr and Constant Expressions
- 2.5 Dealing with Types
- 2.5.1 Type Aliases
- 2.5.2 The auto Type Specifier
- 2.5.3 The decltype Type Specifier
- 2.6 Defining Our Own Data Structures
- 2.6.1 Defining the Sales_data Type
- 2.6.2 Using the Sales_data Class
- 2.6.3 Writing Our Own Header Files
- Chapter Summary
- Defined Terms
Chapter3 Strings, Vectors, and Arrays
더보기
- 3.1 Namespace using Declarations
- 3.2 Library string Type
- 3.2.1 Defining and initializing strings
- 3.2.2 Operations on strings
- 3.2.3 Dealing with the Characters in a string
- 3.3 Library vector Type
- 3.3.1 Defining and Initializing vectors
- 3.3.2 Adding Elements to a vector
- 3.3.3 Other vector Operations
- 3.4 Introducing Iterators
- 3.4.1 Using Iterators
- 3.4.2 Iterator Arithmetic
- 3.5 Arrays
- 3.5.1 Defining and Initializing Buil-in Arrays
- 3.5.2 Accessing the Elements of an Array
- 3.5.3 Pointers and Arrays
- 3.5.4 C-Style Character Strings
- 3.5.5 Interfacing to Older Code
- 3.6 Multidimensional Arrays
- Chapter Summary
- Defined Terms
Chapter4 Expressions
더보기
- 4.1 Fundamentals
- 4.1.1 Basic Concepts
- 4.1.2 Precedence and Associativity
- 4.1.3 Order of Evaluation
- 4.2 Arithmetic Operators
- 4.3 Logical and Relational Operators
- 4.4 Assignment Operators
- 4.5 Increment and Decrement Operators
- 4.6 The Member Access Operators
- 4.7 The Conditional Operator
- 4.8 The Bitwise Operators
- 4.9 The sizeof Operator
- 4.10 Comma Operator
- 4.11 Type Conversions
- 4.11.1 The Arithmetic Conversions
- 4.11.2 Other Implicit Conversions
- 4.11.3 Explicit Conversions
- 4.12 Operator Precedence Table
- Chapter Summary
- Defined Terms
Chapter5 Statements
더보기
- 5.1 Simple Statements
- 5.2 Statement Scope
- 5.3 Conditional Statements
- 5.3.1 The if Statement
- 5.3.2 The switch Statement
- 5.4 Iterative Statements
- 5.4.1 The while Statement
- 5.4.2 Traditional for Statement
- 5.4.3 Range for Statement
- 5.4.4 The do while Statement
- 5.5 Jump Statements
- 5.5.1 The break Statement
- 5.5.2 The continue Statement
- 5.5.3 The goto Statement
- 5.6 try Blocks and Exception Handling
- 5.6.1 A throw Expression
- 5.6.2 The try Block
- 5.6.3 Standard Exceptions
- Chapter Summary
- Defined Terms
Chapter 6 Functions
더보기
- 6.1 Function Basics
- 6.1.1 Local Objects
- 6.1.2 Function Declarations
- 6.1.3 Separate Compilation
- 6.2 Argument Passing
- 6.2.1 Passing Arguments by Value
- 6.2.2 Passing Arguments by Reference
- 6.2.3 const Parameters and Arguments
- 6.2.4 Array Parameters
- 6.2.5 main: Handling Command-Line Options
- 6.2.6. Functions with Varying Parameters
- 6.3 Return Types and the return Statement
- 6.3.1 Functions with No Return Value
- 6.3.2 Functions That Return a Value
- 6.3.3 Returning a Pointer to an Array
- 6.4 Overloaded Functions
- 6.4.1 Overloading and Scope
- 6.5 Features for Specialized Uses
- 6.5.1 Default Arguments
- 6.5.2 Inline and constexpr Functions
- 6.5.3 Aids for Debugging
- 6.6 Function Matching
- 6.6.1 Argument Type Conversions
- 6.7 Pointers to Functions
- Chapter Summary
- Defined Terms
Chapter 7 Classes
더보기
- 7.1 Defining Abstract Data Types
- 7.1.1 Designing the Sales_data Class
- 7.1.2 Defining the Revised Sales_data Class
- 7.1.3 Defining Nonmember Class-Related Functions
- 7.1.4 Constructors
- 7.1.5 Copy, Assignment, and Destruction
- 7.2 Access Control and Encapsulation
- 7.2.1 Friends
- 7.3 Additional Class Features
- 7.3.1 Class Members Revisited
- 7.3.2 Functions That Return *this
- 7.3.3 Class Types
- 7.3.4 Friendship Revisited
- 7.4 Class Scope
- 7.4.1 Name Lookup and Class Scope
- 7.5 Constructors Revisited
- 7.5.1 Constructor Initializer List
- 7.5.2 Delegating Constructors
- 7.5.3 The Role of the Default Constructor
- 7.5.4 Implicit Class-Type Conversions
- 7.5.5 Aggregate Classes
- 7.5.6 Literal Classes
- 7.6 static Class Members
- Chapter Summary
- Defined Terms
Part2 The C++ Library
Chapter 8 The IO Library
더보기
- 8.1 The IO Classes
- 8.1.1 No Copy or Assign for IO Objects
- 8.1.2 Condition States
- 8.1.3 Managing the Output Buffer
- 8.2 File Input and Output
- 8.2.1 Using File Stream Objects
- 8.2.2 File Modes
- 8.3 string Streams
- 8.3.1 Using an istringstream
- 8.3.2 Using ostringstreams
- Chapter Summary
- Defined Terms
Chapter 9 Sequential Containers
더보기
- 9.1 Overview of the Sequential Containers
- 9.2 Container Library Overview
- 9.2.1 Iterators
- 9.2.2 Container Type Members
- 9.2.3 begin and end Members
- 9.2.4 Defining and Initializing a Container
- 9.2.5 Assignment and swap
- 9.2.6 Container Size Operations
- 9.2.7 Relational Operators
- 9.3 Sequential Container Operations
- 9.3.1 Adding Elements to a Sequential Container
- 9.3.2 Accessing Elements
- 9.3.3 Erasing Elements
- 9.3.4 Specialized forward_list Operations
- 9.3.5 Resizing a Container
- 9.3.6 Container Operations May Invalidate Iterators
- 9.4 How a vector Grows
- 9.5 Additional string Operations
- 9.5.1 Other Ways to Construct strings
- 9.5.2 Other Ways to Change a string
- 9.5.3 string Search Operations
- 9.5.4 The compare Functions
- 9.5.5 Numeric Conversions
- 9.6 Container Adaptors
- Chapter Summary
- Defined Terms
Chapter 10 Generic Algorithms
더보기
- 10.1 Overview
- 10.2 A First Look at the Algorithms
- 10.2.1 Read-Only Algorithms
- 10.2.2 Algorithms That Wrtie Container Elements
- 10.2.3 ALgorithms That Reorder Container Elements
- 10.3 Customizing Operations
- 10.3.1 Passing a Function to an Algorithm
- 10.3.2 Lambda Expressions
- 10.3.3 Lambda Captures and Returns
- 10.3.4 Binding Arguments
- 10.4 Revisiting Iterators
- 10.4.1 Insert Iterators
- 10.4.2 iostream Iterators
- 10.4.3 Reverse Iterators
- 10.5 Structure of Generic Algorithms
- 10.5.1 The Five Iterator Categories
- 10.5.2 ALgorithm Parameter Patterns
- 10.5.3 Algorithm Naming Conventions
- 10.6 Container-Specific Algorithms
- Chapter Summary
- Defined Terms
Chapter 11 Associative Conatiners
더보기
- 11.1 Using an Associative Container
- 11.2 Overview of the Associative Containers
- 11.2.1 Defining an Associative Container
- 11.2.2 Requirements on Key Type
- 11.2.3 The pair Type
- 11.3 Operations on Associative Containers
- 11.3.1 Associative Container Iterators
- 11.3.2 Adding Elements
- 11.3.3 Erasing Elements
- 11.3.4 Subscripting a map
- 11.3.5 Accessing Elements
- 11.3.6 A World Transformation Map
- 11.4 The Unordered Containers
- Chapter Summary
- Defined Terms
Chapter 12 Dynamic Memory
더보기
- 12.1 Dynamic Memory and Smart Pointers
- 12.1.1 The shared_ptr Class
- 12.1.2 Managing Memory Directly
- 12.1.3 Using shared_ptrs with new
- 12.1.4 Smart Pointers and Exceptions
- 12.1.5 unique_ptr
- 12.1.6 weak_ptr
- 12.2 Dynamic Arrays
- 12.2.1 new and Arrays
- 12.2.2 The allocator Class
- 12.3 Using the Library: A Text-Query Program
- 12.3.1 Design of the Query Program
- 12.3.2 Defining the Query Program Classes
- Chapter Summary
- Defined Terms
Part3 Tools for Class Authors
Chapter 13 Copy Control
더보기
- 13.1 Copy, Assign, and Destroy
- 13.1.1 The Copy Constructor
- 13.1.2 The Copy-Assignment Operator
- 13.1.3 The Destructor
- 13.1.4 The Rule of Three/Five
- 13.1.5 Using = default
- 13.1.6 Preventing Copies
- 13.2 Copy Control and Resource Management
- 13.2.1 Classes That Act Like Values
- 13.2.2 Defining CLasses That Act Like Pointers
- 13.3 Swap
- 13.4 A Copy-Control Example
- 13.5 Classes That Manage Dynamic Memory
- 13.6 Moving Objects
- 13.6.1 Rvalue References
- 13.6.2 Move COnstructor and Move Assignment
- 13.6.3 Rvalue References and Member Functions
- Chapter Summary
- Defined Terms
Chapter14 Overloaded Operations and Conversions
더보기
- 14.1 Basic Concepts
- 14.2 Input and Output Operators
- 14.2.1 Overloading the Output Operator <<
- 14.2.2 Overloading the Input Operator >>
- 14.3 Arithmetic and Relational Operators
- 14.3.1 Equality Operators
- 14.3.2 Relational Operators
- 14.4 Assignment Operators
- 14.5 Subscript Operators
- 14.6 Increment and Decrement Operators
- 14.7 Member Access Operators
- 14.8 Function-Call Operators
- 14.8.1 Lambdas Are Function Objects
- 14.8.2 Library-Defined Function Objects
- 14.8.3 Callable Objects and function
- 14.9 Overloading, Conversions, and Operators
- 14.9.1 Conversion Operators
- 14.9.2 Avoiding Ambiguous Conversions
- 14.9.3 Function Matching and Overloaded Operators
- Chapter Summary
- Defined Terms
Chapter 15 Object-Oriented Programming
더보기
- 15.1 OOP: An Overview
- 15.2 Defining Base and Derived Classes
- 15.2.1 Defining a Base Class
- 15.2.2 Defining a Derived Class
- 15.2.3 Conversions and Inheritance
- 15.3 Virtual Functions
- 15.4 Abstract Base Classes
- 15.5 Access Control and Inheritance
- 15.6 Class Scope under Inheritance
- 15.7 Constructors and Copy Control
- 15.8 Containers and Inheritance
- 15.8.1 Writing a Basket Class
- 15.9 Text Queries Revisited
- 15.9.1 An Object-Oriented Solution
- 15.9.2 The Query_base and Query Classes
- 15.9.3 The Derived Classes
- 15.9.4 The eval Functions
- Chapter Summary
- Defined Terms
Chapter 16 Templates and Generic Programming
더보기
- 16.1 Defining a Template
- 16.1.1 Function Templates
- 16.1.2 Class Templates
- 16.1.3 Template Parameters
- 16.1.4 Member Templates
- 16.1.5 Controlling Instantiations
- 16.1.6 Efficiency and Flexibility
- 16.2 Template Argument Deduction
- 16.2.1 Conversions and Template Type Parameters
- 16.2.2 Function-Template Explicit Arguments
- 16.2.3 Trailing Return Types and Type Transformation
- 16.2.4 Function Pointers and Argument Deduction
- 16.2.5 Template Argument Deduction and References
- 16.2.6 Understanding std::move
- 16.2.7 Forwarding
- 16.3 Overloading and Templates
- 16.4 Variadic Templates
- 16.4.1 Writing a Variadic Function Template
- 16.4.2 Pack Expansion
- 16.4.3 Forwarding parameter Packs
- 16.5 Template Specializations
- Chapter Summary
- Defined Terms
Part4 Advanced Topics
Chapter 17 Specialized Library Facilities
더보기
- 17.1 The tuple Type
- 17.1.1 Defining and Initializing tuples
- 17.1.2 Using a tuple to Return Multiple Values
- 17.2 The bitset Type
- 17.2.1 Defining and Initializing bitsets
- 17.2.2 Operations on bitsets
- 17.3 Regular Expressions
- 17.3.1 Using the Regular Expressions Library
- 17.3.2 The Match and Regex Iterator Types
- 17.3.3 Using SubExpressions
- 17.4 Random Numbers
- 17.4.1 Random-Number Engines and Distribution
- 17.4.2 Other Kinds of Distributions
- 17.5 The IO Library Revisited
- 17.5.1 Formatted Input and Output
- 17.5.2 Unformatted Input/Output Operations
- 17.5.3 Random Access to a Stream
- Chapter Summary
- Defined Terms
Chapter 18 Tools for Large Programs
더보기
- 18.1 Exception Handling
- 18.1.1 Throwing an Exception
- 18.1.2 Catching an Exception
- 18.1.3 Function try Blocks and Constructors
- 18.1.4 The noexcept Exception Specification
- 18.1.5 Exception Class Hierarchies
- 18.2 Namespaces
- 18.2.1 Namespace Definitions
- 18.2.2 Using Namespace Members
- 18.2.3 Classes, Namespaces, and Scope
- 18.2.4 Overloading and Namespaces
- 18.3 Multiple and Virtual Inheritance
- 18.3.1 Multiple Inheritance
- 18.3.2 Conversions and Multiple Base Classes
- 18.3.3 Class Scope under Multiple Inheritance
- 18.3.4 Virtual Inheritance
- 18.3.5 Constructors and Virtual Inheritance
- Chapter Summary
- Defined Terms
Chapter 19 Specialized Tools and Techniques
더보기
- 19.1 Controlling Memory Allocation
- 19.1.1 Overloading new and delete
- 19.1.2 Placement new Expressions
- 19.2 Run-Time Type Identification
- 19.2.1 The dynamic_cast Operator
- 19.2.2 The typeid Operator
- 19.2.3 Using RTTI
- 19.2.4 The type_info Class
- 19.3 Enumerations
- 19.4 Pointer to Class Member
- 19.4.1 Pointers to Data Members
- 19.4.2 Pointers to Member Functions
- 19.4.3 Using Member Functions as Callable Objects
- 19.5 Nested Classes
- 19.6 union: A Space-Saving Class
- 19.7 Local Classes
- 19.8 Inherently Nonportable Features
- 19.8.1 Bit-fields
- 19.8.2 volatile Qualifier
- 19.8.3 Linkage Directives: extern "C"
- Chapter Summary
- Defined Terms
Appendix A The Library
더보기
- A.1 Library Names and Headers
- A.2 A Brief Tour of the Algorithms
- A.2.1 Algorithms to Find an Object
- A.2.2 Other Read-Only Algorithms
- A.2.3 BInary Search Algorithms
- A.2.4 Algorithms That Write Container Elements
- A.2.5 Partitioning and SOrting Algorithms
- A.2.6 General Reordering Operations
- A.2.7 Permutation Algorithms
- A.2.8 Set Algorithms for Sorted Sequences
- A.2.9 Minimum and Maximum Values
- A.2.10 Numeric Algorithms
- A.3 Random Numbers
- A.3.1 Random Number Distributions
- A.3.2 Random Number Engines
New Features in C++11
더보기
- 2.1.1 long long Type
- 2.2.1 List Initialization
- 2.3.2 nullptr Literal
- 2.4.4 constexpr Variables
- 2.5.1 Type Alias Declarations
- 2.5.2 The auto Type Specifier
- 2.5.3 The decltype Type Specifier
- 2.6.1 In-CLass Initializers
- 3.2.2 Using auto or decltype for Type Abbreviation
- 3.2.3 Range for Statement
- 3.3 Defining a vector of vectors
- 3.3.1 List Initialization for vectors
- 3.4.1 Container cbegin and cend Functions
- 3.5.3 Library begin and end Functions
- 3.6 Using auto or decltype to Simplify Declarations
- 4.2 Rounding Rules for Division
- 4.4 Assignment from a Braced List of Values
- 4.9 sizeof Applied to a Class Member
- 5.4.3 Range for Statement
- 6.2.6 Library initializer_list Class
- 6.3.2 List Initializing a Return Value
- 6.3.3 Declaring a Trailing Return Type
- 6.3.3 Using decltype to Simplify Return Type Declarations
- 6.5.2 constexpr Functions
- 7.1.4 Using = default to Generate a Default Constructor
- 7.3.1 In-class Initailizers for Members of Class Type
- 7.5.2 Delegating Constructors
- 7.5.6 constexpr Constructors
- 8.2.1 Using strings for File Names
- 9.1 The array and forward_list Containers
- 9.2.3 Container cbegin and cend Functions
- 9.2.4 List Initialization for Containers
- 9.2.5 Container Nunmember swap Functions
- 9.3.1 Return Type for Container insert Members
- 9.3.1 Container emplace Members
- 9.4 shrink_to_fit
- 9.5.5 Numeric Conversion Functions for strings
- 10.3.2 Lambda Expressions
- 10.3.3 Trailing Return Type in Lambda Expressions
- 10.3.4 The Library bind Function
- 11.2.1 List Initialization of an Associative Container
- 11.2.3 List Initializing pair Return Type
- 11.3.2 List Initialization of a pair
- 11.4 The Unordered Containers
- 12.1 Smart Pointers
- 12.1.1 The shared_ptr Class
- 12.1.2 List Initialization of Dynamically Allocated Objects
- 12.1.2 auto and Dynamic Allocation
- 12.1.5 The unique_ptr CLass
- 12.1.6 The weak_ptr Class
- 12.2.1 Range for Doesn't Apply to Dynamically Allocated Arrays .
- 12.2.1 List Initialization of Dynamically Allocated Arrays
- 12.2.1 auto Can't Be Used to Allocate an Array
- 12.2.2 allocator:: construct Can Use any Constructor
- 13.1.5 Using = default for Copy-Control Members
- 13.1.6 Using = delete to Prevent Copying Class Objects
- 13.5 Moving Instead of Copying Class Objects
- 13.6.1 Rvalue References
- 13.6.1 The Library move Function
- 13.6.2 Move Constructor and Move Assignment
- 13.6.2 Move Constructors Usually Should Be noExcept
- 13.6.2 Move Iterators
- 13.6.3 References Qualified Member Functions
- 14.8.3 The function Class Template
- 14.9.1 explicit COnversion Operators
- 15.2.2 override Specifier for Virtual Functions
- 15.2.2 Preventing Inheritance by Defining a Class as final
- 15.3 override and final Specifiers for Virtual Functions
- 15.7.2 Deleted Copy Control and Inheritance
- 15.7.4 Inherrited Constructors
- 16.1.2 Declaring a Template Type Parameter as a Friend
- 16.1.2 Template Type Aliases
- 16.1.3 Default Template Arguments for Template Functions
- 16.1.5 Explicit Control of Instantiation
- 16.2.3 Template Functions and Trailing Return Types
- 16.2.5 Reference Collapsing Rules
- 16.2.6 static_cast from an Lvalue to an Rvalue
- 16.2.7 The Library forward Function
- 16.4 Variadic Templates
- 16.4 The sizeof... Operator
- 16.4.3 Variadic Templates and Forwarding
- 17.1 The Library Tuple Class Template
- 17.2.2 New bitset Operations
- 17.3 The Regular Expressions Library
- 17.4 The Random Number Library
- 17.5.1 Floating-Point Format Control
- 18.1.4 The noexcept Exception Specifier
- 18.1.4 The noexcept Operator
- 18.2.1 Inline Namespaces
- 18.3.1 Inherited Constructors and Multiple Inheritance
- 19.3 Scoped enums
- 19.3 Specifying the Type Used to Hold an enum
- 19.3 Forward Declarations for enums
- 19.4.3 The Library mem_fn Class Template
- 19.6 Union Members of Class Types