CS 201 short notes.
The #include directive instructs the preprocessor to read and include a file into a source code file. The file name is typically enclosed with < and > if the file is a system provided file, or in quotes if the file is user provided.
A class that can only be used as a base class for some other class. A class is abstract if it has at least one pure virtual function.
An array or object of a class with no constructors, no private or protected members, no base classes, and no virtual functions. Also see initializer and initialization.
Defining an alias for a structure or built-in type allows use of the alias as if it were a new type. In C, the keyword is typedef. It's a bad idea to alias (have two objects pointing to the same data) unless one of those objects is a temporary variable.
The process of giving memory space to an object. Also see dynamic storage, static storage, and deallocation
When calling a function, refers to the actual values passed to the function. Also see parameter.
An ordered and indexable sequence of values. C++ supports arrays of a single dimension (a vector) or of multiple dimensions.
The process of giving a value to a pre-existing object. Also see copy constructor and initialization.
A class that serves as a base for a derived class to inherit members from. Also see inheritance.
A bit is the smallest unit of memory that can be manipulated. It has a binary or boolean value of 0 or 1. Within memory bits are combined to form bytes and words. Depending on its type, a variable in a program is stored in some number of bytes.
C++ keyword used to declare a Boolean data type.
C++ keyword used to specify a statement that is used to break out of a for or while loop or out of a switch statement.
A byte is a grouping of eight bits which a computer typically groups as one logical unit. It is usually the smallest addressable unit of memory.
Call by reference:
Passing a pointer to an argument to a function. The function can then change the argument value. Also see call by value.
Call by value:
Passing a copy of an argument to a function. The function cannot then change the argument value. C and C++ use call by value argument passing. But also see pointer and reference, also see call by reference.
A C++ keyword used to denote an individual element of a switch statement.
A C++ keyword used to declare an object of character type. Often considered the same as a byte, though it is possible to have multi-byte characters.
In C++ stream I/O, the standard input stream.
A C++ keyword used to declare the fundamental building block of C++ programs. A class has a tag, members, access control mechanisms, and so on.
The way in which data class members are arranged in a class object
A constituent member of a class, such as a data declaration, a function, or a nested class.
A template used for generating class types.
C++ has C-style comments delimited with /* and */, and new C++-style line-oriented comments starting with //.
A software tool that converts a language such as C++ into a different form, typically assembly language.
A C++ keyword used to declare an object as constant or used to declare a constant parameter.
A function called when a class object comes into scope. The constructor is used to initialize the object. See allocation, copy constructor, and destructor.
C++ keyword used with for and while statements to continue the iteration at the top of the loop.
A special type of constructor that is called when an object is copied.
In C++ stream I/O, the standard output stream.
The term data structure refers to the way data is organized for use within a program. Correct organization of data can lead to simpler and more efficient algorithms. Common data structures are linked-lists, stacks, queues and trees.
A tool for stepping through the execution of a program, examining variables, setting breakpoints, and so on.
A C++ entity that introduces one or more names into a program. declaration specifies to the compiler the types of all the elements of an identifier; "this function or this piece of data exists somewhere else, and here is what it should look like." See also definition for definition.
An optional argument to a function. A value specified in the function declaration is used if the argument is not given.
Instantiates an identifier, allocating its memory. A declaration can also be a definition. You can declare data or a function in many difference places, but can define it only once.
C++ keyword and operator used to delete dynamic storage.
A class that inherits members from a base class.
A function called when a class object goes out of scope. It cleans up the object, freeing resources like dynamic storage.
A C/C++ reserved word that allows construction of an iterative loop. The statements in the body always execute at least once. Also see while.
A fundamental data type in C and C++. Double variables are used to store floating-point values. They offer greater precision and can store larger numbers than floats.
Dynamic memory allocation:
The process of dynamically creating objects in the heap or free store during program runtime. Statically created objects, created by the compiler, are put on the program stack.
C++ keyword, part of the if statement, that allows conditional execution of code.
The standard C++ library provides a set of manipulator functions that can modify the state of iostream objects. endl writes a new line to output.
A C++ keyword used in the declaration of constructors to indicate that conversion of an initializer should not take place.
A combination of constants, variables, and operators used to produce a value of some type.
A statement that is an expression, such as a function call or assignment.
A C++ keyword used to declare a floating point type.
A C++ keyword used to specify an iteration or looping statement.
A type of declaration used within a class to grant other classes or functions access to that class.
A C++ entity that is a sequence of statements. It has its own scope, accepts a set of argument values, and returns a value on completion.
The capability of having several routines in a program with the same name. The different functions are distinguished by their parameter types, return value types, or both; the compiler automatically selects the correct version, based on parameter types and return types.
A way of automatically managing dynamic storage such that explicit cleanup of storage is not required. C++ does not have garbage collection.
A variable that is accessible throughout the whole program, whose lifetime is that of the program.
C++ keyword, used to transfer control within a C++ function.
A file containing class declarations, preprocessor directives, and so on, and included in a translation unit. It is expanded by the preprocessor.
A pool of memory used for dynamic memory allocation. Blocks of memory from this area are allocated for program use during execution using the new operator in C++ and the malloc function in C.
C++ keyword used in conditional statements, that allows conditional execution of code.
The process whereby a derived class inherits members from a base class. A derived class will also add its own members to those of the base class.
C++ keyword used to declare an inline function.
A function that can be expanded by a compiler at the point of call, thereby saving the overhead time required to call the function. Best for recursive and loop calls. Provides type safety and side-effects protection not afforded by #define.
The C/C++ keyword int is used to declare an integer variable.
C++ separates its interface from its implementation. The interface in C++ is the class definition of an object, and its methods. The interface doesn't specify how the methods work; this is done in the class implementation. Only the interface need be compiled at compile time. The implementation can be linked (or even written) at any time. You can compile a system to make sure it all fits together without writing its implementation.
A reserved identifier in C++, used to denote data types, statements of the language, and so on. Keywords are reserved words that serve a special purpose within a programming language. They may declare the type or properties of an object, or allow creation of program structure such as branches or loops. They may not by used as identifiers or object (variable) names.
A name that is the target of a goto statement.
A program that combines object files and library code to produce an executable program.
A preprocessor feature that supports parameter substitution and expansion of commonly-used code sequences. Also see inline function.
Every C or C++ program must have one and only one main function. Program execution begins with the first statement in main
malloc is used to dynamically allocate memory in the C programming language. malloc returns a pointer of type void to a memory buffer of a requested size, or null if it fails. It may also be used in C++, although new is preferred.
Special iostream functions permitting specific i/o operations while in the middle of stream insertion or extraction. These functions switch appropriate iostream format flags.
In C/C++, it is possible to allocate space for objects (variables) dynamically during program execution. After finishing use of a dynamically allocated object, it is necessary to explicitly release the memory consumed by the object, particularly before pointers to the object go out of scope. Failure to do so results in a memory leak. Long running programs or those that allocate memory extensively can consume or occupy enough of a computers memory to seriously hinder performance when memory leaks are present.
A way of encoding an external name representing a function so as to be able to distinguish the types of its parameters.
C++ keyword and operator used to allocate dynamic storage.
A pointer value that evaluates to zero.
In C++, often refers to an instance of a class. Also more loosely refers to any named declaration of a variable or other entity that involves storage.
Acronym for object-oriented programming.
A builtin operation of the C++ language, like ddition, or an overloaded operator corresponding to a member function of a class.
To treat a C++ operator like as a function and overload it for particular parameter types. The assignment of more than one function to a particular operator, with the implication that the operation performed will vary depending on the data type (operands) involved.
To specify more than one function of the same name, but with varying numbers and types of parameters.
Refers to the variables passed into a function.
An address of an object.
Pointer to data member:
A pointer that points at a data member of a class.
Pointer to function:
An address of a function or a member function.
A stage of compilation processing that occurs before the compiler proper is invoked. Preprocessing handles macro expansion among other things. In C++ use of const and inline functions makes preprocessing less important.
A device or routine that performs preliminary operations on input before passing it on for further processing. See also preprocessing.
A C++ keyword used to specify that a class member can only be accessed from member functions and friends of the class. See access control, protected, and public.
A C++ keyword used to specify that a class member can only be accessed by member functions and friends of its own class and by member functions and friends of classes derived from this class. See also private and public.
A prototype is a function declaration. Function declarations are generally placed in header files.
A C++ keyword used to specify that class members are accessible from any (non-member) function.
A queue is a data structure that supports FIFO, first in first out processing. Objects will be processed in the order they enter a queue. Conceptualize a queue as a water pipe. The first water to flow in will be the first water to flow out of the other end.
Another name for an object. Access to an object via a reference is like manipulating the object itself. References are typically implemented as pointers in the underlying generated code.
C++ keyword used as a hint to the compiler that a particular local variable should be placed in a machine register.
Keywords that serve a special purpose within a programming language. They may declare the type or properties of an object, or allow creation of program structure such as branches or loops. They may not by used as identifiers or object (variable) names.
C++ keyword used for returning values from a function.
The value returned from a function.
The region of a program where a name has visibility. Generally, the domain of objects and calls within which an object can exist. A struct name or enum in an inner scope can obscure a global of the same name in an outer scope. In C++, enum constants embedded in a struct def have the same scope as that struct's fields.
A C++ fundamental type used to declare small integers.
C++ keyword used to indicate a signed data type.
A set of consecutive characters treated by a computer as a single item. In C, strings are represented in null , '\0', terminated character arrays. In C++, it is common to use the string class, which is part of the standard C++ library to hold and manipulate strings.
C++ keyword denoting a statement type, used to dispatch to one of several sequences of statements based on the value of an expression.
A parameterized type. A template can accept type parameters that are used to customize the resulting type.
An actual value or type given to a template to form a template class.
A combination of a template with a template argument list via the process of template instantiation.
C++ keyword used in a member function to point at the object currently being operated on.
A structure somewhat like a class or struct, except that individual union members share the same memory.
A member function whose interpretation when called depends on the type of the object for which it is called; a function for an object of a derived class will override a function of its base class.
C++ keyword used to declare an iteration statement. It means 'do until the condition is true'.