cplusplus:pointers_2_slides
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
cplusplus:pointers_2_slides [2019/03/28 17:00] – mithat | cplusplus:pointers_2_slides [2021/10/19 19:46] (current) – [Constant pointer to constant data] mithat | ||
---|---|---|---|
Line 2: | Line 2: | ||
~~NOTOC~~ | ~~NOTOC~~ | ||
- | ====== Pointers 2 ====== | + | ====== Pointers 2 slides |
Pointers and comparisons, | Pointers and comparisons, | ||
Deitel, Harvey M., and Paul J. Deitel. " | Deitel, Harvey M., and Paul J. Deitel. " | ||
Line 28: | Line 28: | ||
* Arguments can be anything that can be assigned to a pointer (i.e., addresses or pointers). | * Arguments can be anything that can be assigned to a pointer (i.e., addresses or pointers). | ||
+ | ===== Example ===== | ||
<file cpp function-with-pointer.cpp> | <file cpp function-with-pointer.cpp> | ||
/** Demonstrates how to pass pointers to functions. */ | /** Demonstrates how to pass pointers to functions. */ | ||
Line 62: | Line 63: | ||
* Pointers can be used to implement //pass by reference// in functions. | * Pointers can be used to implement //pass by reference// in functions. | ||
* The '' | * The '' | ||
- | | + | * Strictly speaking, the passing mechanism is //call by value//. But functionality is pass by reference. |
- | | + | * Syntax |
- | * The syntax | + | |
+ | ===== Example ===== | ||
<file cpp cube-by-reference.cpp> | <file cpp cube-by-reference.cpp> | ||
/** Cube a variable using pass by reference with a pointer. */ | /** Cube a variable using pass by reference with a pointer. */ | ||
Line 84: | Line 85: | ||
void cubeByReference(int *nPtr) | void cubeByReference(int *nPtr) | ||
{ | { | ||
+ | // *nptr'' | ||
*nPtr = (*nPtr) * (*nPtr) * (*nPtr); // parenthesis for readability | *nPtr = (*nPtr) * (*nPtr) * (*nPtr); // parenthesis for readability | ||
} | } | ||
</ | </ | ||
- | --------------------------------------------------------------------------------------------------------------- | + | ===== The const qualifier ===== |
- | ===== The const qualifier | + | * '' |
+ | * '' | ||
+ | * '' | ||
- | You are already familiar with C++' | + | ===== The const qualifier ===== |
+ | * '' | ||
+ | * What is constant? The pointer value or the value of the thing pointed to? | ||
+ | * Answer is //either or both//. | ||
- | * '' | + | ===== Constant pointers ===== |
- | * '' | + | |
- | * Attempting to change a '' | + | |
- | Applying the '' | + | * A **constant pointer** is a pointer whose value cannot change. |
+ | * Constant pointers //store a memory location that cannot be changed// | ||
+ | * Must be initialized when declared. | ||
+ | * '' | ||
- | The answer is //either or both//. | + | <code c++> |
- | + | int *const myPtr = & | |
- | ==== Constant pointers ==== | + | // myPtr will always |
- | + | </ | |
- | A **constant pointer** is a pointer whose value cannot change; that is, constant | + | |
- | To declare a constant pointer, use the '' | + | ===== Example ===== |
<file cpp const-ptr-demo.cpp> | <file cpp const-ptr-demo.cpp> | ||
Line 115: | Line 122: | ||
{ | { | ||
int x = 2, y = 5; | int x = 2, y = 5; | ||
- | int * const myPtr = & | + | int *const myPtr = & |
// The data pointed to by myPtr can be | // The data pointed to by myPtr can be | ||
// modified through myPtr, but myPtr must | // modified through myPtr, but myPtr must | ||
Line 121: | Line 128: | ||
*myPtr = 99; // change value stored in x to 99 | *myPtr = 99; // change value stored in x to 99 | ||
- | myPtr = & | + | myPtr = & |
cout << *myPtr << endl; | cout << *myPtr << endl; | ||
Line 129: | Line 136: | ||
</ | </ | ||
- | ==== Pointer to constant data ==== | + | ===== Pointer to constant data ===== |
- | You can also create a pointer | + | * A **pointer |
- | + | | |
- | To create a pointer to constant data, use the '' | + | |
<code cpp> | <code cpp> | ||
Line 139: | Line 146: | ||
const int *myPtr = & | const int *myPtr = & | ||
- | *myPtr = 99; // syntax error! | + | *myPtr = 99; // syntax error! |
myPtr = & | myPtr = & | ||
</ | </ | ||
+ | ===== Constant pointer to constant data ===== | ||
- | <WRAP center tip 90%> | + | * **Constant pointer to constant data** cannot |
- | One way to remember this is //"'' | + | |
- | + | ||
- | In the case of: | + | |
- | <code c++> | + | |
- | '' | + | |
- | + | ||
- | In the case of: | + | |
- | <code c++> | + | |
- | '' | + | |
- | </ | + | |
- | + | ||
- | ==== Constant pointer to constant data ==== | + | |
- | + | ||
- | Combining the above, you can create a pointer that can change | + | |
<code cpp> | <code cpp> | ||
Line 166: | Line 160: | ||
*myPtr = 99; // syntax error! | *myPtr = 99; // syntax error! | ||
myPtr = & | myPtr = & | ||
+ | </ | ||
+ | |||
+ | ===== How to remember ===== | ||
+ | |||
+ | * '' | ||
+ | |||
+ | <code c++> | ||
+ | /* const modifies myPtr, meaning the value of myPtr is constant. */ | ||
+ | int *const myPtr = &x; | ||
+ | </ | ||
+ | |||
+ | |||
+ | <code c++> | ||
+ | /* const modifies int, meaning the value of the int is constant. */ | ||
+ | const int *myPtr = &x; | ||
</ | </ | ||
cplusplus/pointers_2_slides.1553792410.txt.gz · Last modified: 2019/03/28 17:00 by mithat