Download presentation
Presentation is loading. Please wait.
Published byMorris Hood Modified over 8 years ago
1
2008 Pearson Education, Inc. All rights reserved. 1 8 8 Pointers and Pointer-Based Strings
2
2008 Pearson Education, Inc. All rights reserved. 2 OBJECTIVES In this chapter you will learn: What pointers are. The similarities and differences between pointers and references, and when to use each. To use pointers to pass arguments to functions by reference. To use pointer-based C-style strings. The close relationships among pointers, arrays and C-style strings. To use pointers to functions. To declare and use arrays of C-style strings. What handles and tracking references are. To use handles to pass managed objects to functions by reference.
3
2008 Pearson Education, Inc. All rights reserved. 3 9.1 Introduction 9.2 Pointer Variable Declarations and Initialization 9.3 Pointer Operators 9.4 Passing Arguments to Functions by Reference with Pointers 9.5 Using const with Pointers 9.6 Selection Sort Using Pass-by-Reference 9.7 sizeof Operator 9.8 Pointer Expressions and Pointer Arithmetic 9.9 Relationship Between Pointers and Arrays 9.10 Arrays of Pointers 9.11 Case Study: Card Shuffling and Dealing Simulation 9.12 Function Pointers 9.13 Introduction to Pointer-Based String Processing 9.13.1 Fundamentals of Characters and Pointer-Based Strings 9.13.2 String Manipulation Functions of the String-Handling Library 9.14 Introduction to C++/CLI Handles 9.15 Passing Arguments to Functions by Reference with Handles 9.16 Tracking References and References to Handles 9.17Interior Pointers 9.18 Wrap-Up
4
2008 Pearson Education, Inc. All rights reserved. 4 9.1 Introduction Pointers – Powerful, but difficult to master – Can be used to perform pass-by-reference – Can be used to create and manipulate dynamic data structures – Close relationship with arrays and strings char * pointer-based strings
5
2008 Pearson Education, Inc. All rights reserved. 5 9.2Pointer Variable Declarations and Initialization Pointer variables – Contain memory addresses as values Normally, variable contains specific value (direct reference) Pointers contain address of variable that has specific value (indirect reference) Indirection – Referencing value through pointer
6
2008 Pearson Education, Inc. All rights reserved. 6 9.2Pointer Variable Declarations and Initialization (Cont.) Pointer declarations – * indicates variable is a pointer Example int *myPtr; Declares pointer to int, of type int * Multiple pointers require multiple asterisks int *myPtr1, *myPtr2; Pointer initialization – Initialized to 0, NULL, or an address 0 or NULL points to nothing (null pointer)
7
2008 Pearson Education, Inc. All rights reserved. 7 Common Programming Error 9.1 Assuming that the * used to declare a pointer distributes to all variable names in a declaration’s comma-separated list of variables can lead to errors. Each pointer must be declared with the * prefixed to the name (either with or without a space in between—the compiler ignores the space). Declaring only one variable per declaration helps avoid these types of errors and improves program readability.
8
2008 Pearson Education, Inc. All rights reserved. 8 Good Programming Practice 9.1 Although it is not a requirement, including the letters Ptr in pointer variable names makes it clear that these variables are pointers and that they must be handled accordingly.
9
2008 Pearson Education, Inc. All rights reserved. 9 Fig. 9.1 | Directly and indirectly referencing a variable.
10
2008 Pearson Education, Inc. All rights reserved. 10 Error-Prevention Tip 9.1 Initialize pointers to prevent pointing to unknown or uninitialized areas of memory.
11
2008 Pearson Education, Inc. All rights reserved. 11 9.3Pointer Operators Address operator ( & ) – Returns memory address of its operand – Example int y = 5; int *yPtr; yPtr = &y; assigns the address of variable y to pointer variable yPtr – Variable yPtr “points to” y yPtr indirectly references variable y ’s value
12
2008 Pearson Education, Inc. All rights reserved. 12 Fig. 9.2 | Graphical representation of a pointer pointing to a variable in memory.
13
2008 Pearson Education, Inc. All rights reserved. 13 9.3Pointer Operators (Cont.) * operator – Also called indirection operator or dereferencing operator – Returns synonym for the object its operand points to – *yPtr returns y (because yPtr points to y ) – Dereferenced pointer is an lvalue *yptr = 9; * and & are inverses of each other – Will “cancel one another out” when applied consecutively in either order
14
2008 Pearson Education, Inc. All rights reserved. 14 Fig. 9.3 | Representation of y and yPtr in memory.
15
2008 Pearson Education, Inc. All rights reserved. 15 Common Programming Error 9.2 Dereferencing a pointer that has not been properly initialized or that has not been assigned to point to a specific location in memory could cause a fatal execution-time error, or it could accidentally modify important data and allow the program to run to completion, possibly with incorrect results.
16
2008 Pearson Education, Inc. All rights reserved. 16 Common Programming Error 9.3 An attempt to dereference a variable that is not a pointer is a compilation error.
17
2008 Pearson Education, Inc. All rights reserved. 17 Common Programming Error 9.4 Dereferencing a null pointer is often a fatal execution-time error.
18
2008 Pearson Education, Inc. All rights reserved. 18 Portability Tip 9.1 The format in which a pointer is output is compiler dependent—some use hexadecimal integers, some use decimal integers and some use other formats.
19
2008 Pearson Education, Inc. All rights reserved. 19 Outline PointerOperators.cpp (1 of 2) Variable aPtr is a point to an int Initialize aPtr with the address of variable a
20
2008 Pearson Education, Inc. All rights reserved. 20 Outline PointerOperators.cpp (2 of 2) * and & are inverses of each other Address of a and the value of aPtr are identical * and & are inverses; same result when both are applied to aPtr Value of a and the dereferenced aPtr are identical
21
2008 Pearson Education, Inc. All rights reserved. 21 Fig. 9.5 | Operator precedence and associativity.
22
2008 Pearson Education, Inc. All rights reserved. 22 9.4 Passing Arguments to Functions by Reference with Pointers Three ways to pass arguments to a function – Pass-by-value – Pass-by-reference with reference arguments – Pass-by-reference with pointer arguments A function can return only one value Arguments passed to a function using reference arguments – Function can modify original values of arguments More than one value “returned”
23
2008 Pearson Education, Inc. All rights reserved. 23 9.4 Passing Arguments to Functions by Reference with Pointers (Cont.) Pass-by-reference with pointer arguments – Simulates pass-by-reference Use pointers and indirection operator – Pass address of argument using & operator – Arrays not passed with & because array name is already a pointer – * operator used as alias/nickname for variable inside of function
24
2008 Pearson Education, Inc. All rights reserved. 24 Outline PassByValue.cpp (1 of 1) Pass number by value; result returned by cubeByValue cubeByValue receives parameter passed-by-value Cubes local variable n and return the result
25
2008 Pearson Education, Inc. All rights reserved. 25 Common Programming Error 9.5 Not dereferencing a pointer when it is necessary to do so to obtain the value to which the pointer points is an error.
26
2008 Pearson Education, Inc. All rights reserved. 26 Outline PassByReference. cpp (1 of 1) Prototype indicates parameter is a pointer to an int Apply address operator & to pass address of number to cubeByReference cubeByReference modifies variable number cubeByReference receives address of an int variable, i.e., a pointer to an int Modify and access int variable using indirection operator *
27
2008 Pearson Education, Inc. All rights reserved. 27 Software Engineering Observation 9.1 Use pass-by-value to pass arguments to a function unless the caller explicitly requires that the called function directly modify the value of the argument variable in the caller. This is another example of the principle of least privilege.
28
2008 Pearson Education, Inc. All rights reserved. 28 Fig. 9.8 | Pass-by-value analysis of the program of Fig. 9.6.
29
2008 Pearson Education, Inc. All rights reserved. 29 Fig. 9.9 | Pass-by-reference analysis (with a pointer argument) of the program of Fig. 9.7.
30
2008 Pearson Education, Inc. All rights reserved. 30 9.5 Using const with Pointers const qualifier – Indicates that value of variable should not be modified – const used when function does not need to change the variable’s value Principle of least privilege – Award function enough access to accomplish task, but no more – Example A function that prints the elements of an array, takes array and int indicating length – Array contents are not changed – should be const – Array length is not changed – should be const
31
2008 Pearson Education, Inc. All rights reserved. 31 Software Engineering Observation 9.2 If a value does not (or should not) change in the body of a function to which it is passed, the parameter should be declared const to ensure that it is not accidentally modified.
32
2008 Pearson Education, Inc. All rights reserved. 32 Error-Prevention Tip 9.2 Before using a function, check its function prototype to determine the parameters that it can modify.
33
2008 Pearson Education, Inc. All rights reserved. 33 9.5 Using const with Pointers (Cont.) Four ways to pass pointer to function – Nonconstant pointer to nonconstant data Highest amount of access Data can be modified through the dereferenced pointer Pointer can be modified to point to other data – Pointer arithmetic Operator ++ moves array pointer to the next element Its declaration does not include const qualifier
34
2008 Pearson Education, Inc. All rights reserved. 34 Outline NonConstantPointers.cpp (1 of 2) Parameter is a nonconstant pointer to nonconstant data convertToUppercase modifies variable phrase
35
2008 Pearson Education, Inc. All rights reserved. 35 Outline NonConstantPoint ers.cpp (2 of 2) Parameter sPtr is a nonconstant pointer to nonconstant data Function islower returns true if the character is lowercase Function toupper returns corresponding uppercase character if original character is lowercase; otherwise toupper returns the original character Modify the memory address stored in sPtr to point to the next element of the array
36
2008 Pearson Education, Inc. All rights reserved. 36 9.5 Using const with Pointers (Cont.) Four ways to pass pointer to function (Cont.) – Nonconstant pointer to constant data Pointer can be modified to point to any appropriate data item Data cannot be modified through this pointer Provides the performance of pass-by-reference and the protection of pass-by-value
37
2008 Pearson Education, Inc. All rights reserved. 37 Outline PointerToConstant. cpp (1 of 1) Parameter is a nonconstant pointer to constant data Pass pointer phrase to function printCharacters sPtr is a nonconstant pointer to constant data; it cannot modify the character to which it points Increment sPtr to point to the next character
38
2008 Pearson Education, Inc. All rights reserved. 38 Outline NonConstantPoint er.cpp (1 of 2) Parameter is a nonconstant pointer to constant data Pass the address of int variable y to attempt an illegal modification
39
2008 Pearson Education, Inc. All rights reserved. 39 Outline NonConstantPointer.cpp (2 of 2) Attempt to modify a const object pointed to by xPtr
40
2008 Pearson Education, Inc. All rights reserved. 40 Performance Tip 9.1 If they do not need to be modified by the called function, pass large objects using pointers to constant data or references to constant data, to obtain the performance benefits of pass-by- reference.
41
2008 Pearson Education, Inc. All rights reserved. 41 Software Engineering Observation 9.3 Pass large objects using pointers to constant data, or references to constant data, to obtain the security of pass-by-value.
42
2008 Pearson Education, Inc. All rights reserved. 42 9.5 Using const with Pointers (Cont.) Four ways to pass pointer to function (Cont.) – Constant pointer to nonconstant data Always points to the same memory location – Can only access other elements using subscript notation Data can be modified through the pointer Default for an array name – Can be used by a function to receive an array argument Must be initialized when declared
43
2008 Pearson Education, Inc. All rights reserved. 43 Outline ConstantPointer. cpp (1 of 1) ptr is a constant pointer to an integer Can modify x (pointed to by ptr ) since x is not constant Cannot modify ptr to point to a new address since ptr is constant
44
2008 Pearson Education, Inc. All rights reserved. 44 Common Programming Error 9.6 Not initializing a pointer that is declared const is a compilation error.
45
2008 Pearson Education, Inc. All rights reserved. 45 9.5 Using const with Pointers (Cont.) Four ways to pass pointer to function (Cont.) – Constant pointer to constant data Least amount of access Always points to the same memory location Data cannot be modified using this pointer
46
2008 Pearson Education, Inc. All rights reserved. 46 Outline ConstantPointer. cpp ptr is a constant pointer to a constant integer Cannot modify x (pointed to by ptr ) since *ptr is constant Cannot modify ptr to point to a new address since ptr is constant
47
2008 Pearson Education, Inc. All rights reserved. 47 9.6 Selection Sort Using Pass-by- Reference Implement selectionSort using pointers – Selection sort algorithm Swap smallest element with the first element Swap second-smallest element with the second element Etc. – Want function swap to access array elements Individual array elements: scalars – Passed by value by default Pass by reference via pointers using address operator &
48
2008 Pearson Education, Inc. All rights reserved. 48 Outline SelectionSort.cpp (1 of 3)
49
2008 Pearson Education, Inc. All rights reserved. 49 Outline SelectionSort.cpp (2 of 3) Declare array as int *array (rather than int array[] ) to indicate function selectionSort receives single-subscripted array Receives the size of the array as an argument; declared const to ensure that size is not modified
50
2008 Pearson Education, Inc. All rights reserved. 50 Outline SelectionSort.cpp (3 of 3) Arguments are assed by reference, allowing the function to swap values at the original memory locations
51
2008 Pearson Education, Inc. All rights reserved. 51 Software Engineering Observation 9.4 When passing an array to a function, also pass the size of the array (rather than building into the function knowledge of the array size)—this makes the function more reusable.
52
2008 Pearson Education, Inc. All rights reserved. 52 9.7 sizeof Operators sizeof operator – Returns size of operand in bytes – For arrays, sizeof returns ( size of 1 element ) * ( number of elements ) – If sizeof( int ) returns 4 then int myArray[ 10 ]; cout << sizeof( myArray ); will print 40 – Can be used with Variable names Type names Constant values
53
2008 Pearson Education, Inc. All rights reserved. 53 Common Programming Error 9.7 Using the sizeof operator in a function to find the size in bytes of an array parameter results in the size in bytes of a pointer, not the size in bytes of the array.
54
2008 Pearson Education, Inc. All rights reserved. 54 Outline Sizeof.cpp (1 of 1) Operator sizeof applied to an array returns total number of bytes in the array Function getSize returns the number of bytes used to store array address Operator sizeof returns number of bytes of pointer
55
2008 Pearson Education, Inc. All rights reserved. 55 9.7 sizeof Operators (Cont.) sizeof operator (Cont.) – Is performed at compiler-time – For double realArray[ 22 ]; Use sizeof realArray / sizeof( double ) to calculate the number of elements in realArray – Parentheses are only required if the operand is a type name
56
2008 Pearson Education, Inc. All rights reserved. 56 Outline Sizeof.cpp (1 of 2)
57
2008 Pearson Education, Inc. All rights reserved. 57 Outline Sizeof.cpp (2 of 2) Operator sizeof can be used on a variable name Operator sizeof can be used on a type name Operator sizeof returns the total number of bytes in the array
58
2008 Pearson Education, Inc. All rights reserved. 58 Portability Tip 9.2 The number of bytes used to store a particular data type may vary among systems. When writing programs that depend on data type sizes, and that will run on several computer systems, use sizeof to determine the number of bytes used to store the data types.
59
2008 Pearson Education, Inc. All rights reserved. 59 Common Programming Error 9.8 Omitting the parentheses in a sizeof operation when the operand is a type name is a compilation error.
60
2008 Pearson Education, Inc. All rights reserved. 60 Performance Tip 9.2 Because sizeof is a compile-time unary operator, not an execution-time operator, using sizeof does not negatively impact execution performance.
61
2008 Pearson Education, Inc. All rights reserved. 61 Error-Prevention Tip 9.3 To avoid errors associated with omitting the parentheses around the operand of operator sizeof, many programmers include parentheses around every sizeof operand.
62
2008 Pearson Education, Inc. All rights reserved. 62 9.8 Pointer Expressions and Pointer Arithmetic Pointer arithmetic – Increment/decrement pointer ( ++ or -- ) – Add/subtract an integer to/from a pointer ( + or +=, - or -= ) – Pointers may be subtracted from each other – Pointer arithmetic is meaningless unless performed on a pointer to an array
63
2008 Pearson Education, Inc. All rights reserved. 63 9.8 Pointer Expressions and Pointer Arithmetic (Cont.) 5 element int array on a machine using 4 byte int s vPtr points to first element v[ 0 ], at location 3000 vPtr = &v[ 0 ]; vPtr += 2; sets vPtr to 3008 ( 3000 + 2 * 4 ) vPtr points to v[ 2 ] Subtracting pointers – Returns number of elements between two addresses vPtr2 = v[ 2 ]; vPtr = v[ 0 ]; vPtr2 - vPtr is 2
64
2008 Pearson Education, Inc. All rights reserved. 64 Portability Tip 9.3 Most computers today have two-byte or four- byte integers. Some of the newer machines use eight-byte integers. Because the results of pointer arithmetic depend on the size of the objects a pointer points to, pointer arithmetic is machine dependent.
65
2008 Pearson Education, Inc. All rights reserved. 65 Fig. 9.18 | Array v and a pointer variable vPtr that points to v.
66
2008 Pearson Education, Inc. All rights reserved. 66 Fig. 9.19 | Pointer vPtr after pointer arithmetic.
67
2008 Pearson Education, Inc. All rights reserved. 67 Common Programming Error 9.9 Using pointer arithmetic on a pointer that does not refer to an array of values is a logic error.
68
2008 Pearson Education, Inc. All rights reserved. 68 Common Programming Error 9.10 Subtracting or comparing two pointers that do not refer to elements of the same array is a logic error.
69
2008 Pearson Education, Inc. All rights reserved. 69 Common Programming Error 9.11 Using pointer arithmetic to increment or decrement a pointer such that the pointer refers to an element outside the bounds of the array is normally a logic error.
70
2008 Pearson Education, Inc. All rights reserved. 70 9.8 Pointer Expressions and Pointer Arithmetic (Cont.) Pointer assignment – Pointer can be assigned to another pointer if both are of same type If not same type, cast operator must be used Exception – Pointer to void (type void * ) Generic pointer, represents any type No casting needed to convert pointer to void * Casting is needed to convert void * to any other type void pointers cannot be dereferenced
71
2008 Pearson Education, Inc. All rights reserved. 71 Software Engineering Observation 9.5 Nonconstant pointer arguments can be passed to constant pointer parameters. This is helpful when the body of a program uses a nonconstant pointer to access data, but does not want that data to be modified by a function called in the body of the program.
72
2008 Pearson Education, Inc. All rights reserved. 72 Common Programming Error 9.12 Assigning a pointer of one type to a pointer of another (other than void *) without casting the first pointer to the type of the second pointer is a compilation error.
73
2008 Pearson Education, Inc. All rights reserved. 73 Common Programming Error 9.13 All operations on a void * pointer are compilation errors, except comparing void * pointers with other pointers, casting void * pointers to valid pointer types and assigning addresses to void * pointers.
74
2008 Pearson Education, Inc. All rights reserved. 74 9.8 Pointer Expressions and Pointer Arithmetic (Cont.) Pointer comparison – Use equality and relational operators – Compare addresses stored in pointers Comparisons are meaningless unless pointers point to members of the same array – Example Could show that one pointer points to higher-index element of array than another pointer – Commonly used to determine whether pointer is 0 (null pointer)
75
2008 Pearson Education, Inc. All rights reserved. 75 9.9 Relationship Between Pointers and Arrays Arrays and pointers are closely related – Array name is like constant pointer – Pointers can do array subscripting operations
76
2008 Pearson Education, Inc. All rights reserved. 76 9.9 Relationship Between Pointers and Arrays (Cont.) Accessing array elements with pointers – Assume declarations: int b[ 5 ]; int *bPtr; bPtr = b; – Element b[ n ] can be accessed by *( bPtr + n ) Called pointer/offset notation – Addresses &b[ 3 ] is same as bPtr + 3 – Array name can be treated as pointer b[ 3 ] is same as *( b + 3 ) – Pointers can be subscripted (pointer/subscript notation) bPtr[ 3 ] is same as b[ 3 ]
77
2008 Pearson Education, Inc. All rights reserved. 77 Common Programming Error 9.14 Although array names are pointers to the beginning of the array and pointers can be modified in arithmetic expressions, array names cannot be modified in arithmetic expressions, because array names are constant pointers.
78
2008 Pearson Education, Inc. All rights reserved. 78 Good Programming Practice 9.2 For clarity, use array notation instead of pointer notation when manipulating arrays.
79
2008 Pearson Education, Inc. All rights reserved. 79 Outline PointerArrays.cpp (1 of 3) Using array subscript notation Using array name and pointer/offset notation
80
2008 Pearson Education, Inc. All rights reserved. 80 Outline PointerArrays.cpp (2 of 3) Using pointer subscript notation Using pointer name and pointer/offset notation
81
2008 Pearson Education, Inc. All rights reserved. 81 Outline PointerArrays.cpp (3 of 3)
82
2008 Pearson Education, Inc. All rights reserved. 82 Outline StringPointers.cpp (1 of 2)
83
2008 Pearson Education, Inc. All rights reserved. 83 Outline StringPointers.cpp (2 of 2) Use array subscript notation to copy string in s2 to character array s1 Use pointer notation to copy string in s2 to character array in s1 Increment both pointers to point to next elements in corresponding arrays
84
2008 Pearson Education, Inc. All rights reserved. 84 9.10 Arrays of Pointers Arrays can contain pointers – Commonly used to store array of strings (string array) Array does not store strings, only pointers to strings Example const char *suit[ 4 ] = {"Hearts", "Diamonds", "Clubs", "Spades"}; Each element of suit points to a char * (string) suit array has fixed size ( 4 ), but strings can be of any size Commonly used with command-line arguments to function main
85
2008 Pearson Education, Inc. All rights reserved. 85 Fig. 9.22 | Graphical representation of the suit array.
86
2008 Pearson Education, Inc. All rights reserved. 86 9.11 Case Study: Card Shuffling and Dealing Simulation Card shuffling program – Use an array of pointers to strings, to store suit names – Use a double scripted array (suit-by-value) – Place 1-52 into the array to specify the order in which the cards are dealt Indefinite postponement (starvation) – An algorithm executing for an indefinitely long period Due to randomness
87
2008 Pearson Education, Inc. All rights reserved. 87 Fig. 9.23 | Two-dimensional array representation of a deck of cards.
88
2008 Pearson Education, Inc. All rights reserved. 88 Performance Tip 9.3 Sometimes algorithms that emerge in a “natural” way can contain subtle performance problems such as indefinite postponement. Seek algorithms that avoid indefinite postponement.
89
2008 Pearson Education, Inc. All rights reserved. 89 9.11 Case Study: Card Shuffling and Dealing Simulation (Cont.) Pseudocode for shuffling and dealing simulation For each of the 52 cards Place card number in randomly selected unoccupied slot of deck For each of the 52 cards Find card number in deck array and print face and suit of card Choose slot of deck randomly While chosen slot of deck has been previously chosen Choose slot of deck randomly Place card number in chosen slot of deck For each slot of the deck array If slot contains card number Print the face and suit of the card Second refinementThird refinementFirst refinement Initialize the suit array Initialize the face array Initialize the deck array Shuffle the deck Deal 52 cards
90
2008 Pearson Education, Inc. All rights reserved. 90 Outline Fig. 9.24 | Pseudocode algorithm for card shuffling and dealing program. (1 of 1)
91
2008 Pearson Education, Inc. All rights reserved. 91 Outline DeckOfCards.h (1 of 1)
92
2008 Pearson Education, Inc. All rights reserved. 92 Outline DeckOfCards.cpp (1 of 4)
93
2008 Pearson Education, Inc. All rights reserved. 93 Outline DeckOfCards.cpp (2 of 4) Current position is at randomly selected row and column
94
2008 Pearson Education, Inc. All rights reserved. 94 Outline DeckOfCards.cpp (3 of 4) suit array contains pointers to char arrays face array contains pointers to char arrays
95
2008 Pearson Education, Inc. All rights reserved. 95 Outline DeckOfCards.cpp (4 of 4) Cause face to be output right justified in field of 5 characters Cause suit to be output left justified in field of 8 characters
96
2008 Pearson Education, Inc. All rights reserved. 96 Outline DeckOfCardsTest. cpp (1 of 2)
97
2008 Pearson Education, Inc. All rights reserved. 97 Outline DeckOfCardsTest. cpp (2 of 2)
98
2008 Pearson Education, Inc. All rights reserved. 98 9.12 Function Pointers Pointers to functions – Contain addresses of functions Similar to how array name is address of first element Function name is starting address of code that defines function Function pointers can be – Passed to functions – Returned from functions – Stored in arrays – Assigned to other function pointers
99
2008 Pearson Education, Inc. All rights reserved. 99 9.12 Function Pointers (Cont.) Calling functions using pointers – Assume function header parameter: bool ( *compare ) ( int, int ) – Execute function from pointer with either ( *compare ) ( int1, int2 ) – Dereference pointer to function OR compare( int1, int2 ) – Could be confusing User may think compare is name of actual function in program
100
2008 Pearson Education, Inc. All rights reserved. 100 Outline FunctionPointers.cpp (1 of 4) Parameter is pointer to function that receives two integer parameters and returns bool result
101
2008 Pearson Education, Inc. All rights reserved. 101 Outline FunctionPointers.cpp (2 of 4) Pass pointers to functions ascending and descending as parameters to function selectionSort
102
2008 Pearson Education, Inc. All rights reserved. 102 Outline FunctionPointers.cpp (3 of 4) compare is a pointer to a function that receives two integer parameters and returns a bool result Parentheses necessary to indicate pointer to function Dereference pointer compare to execute the function
103
2008 Pearson Education, Inc. All rights reserved. 103 Outline FunctionPointers.cpp (4 of 4)
104
2008 Pearson Education, Inc. All rights reserved. 104 9.12 Function Pointers (Cont.) Arrays of pointers to functions – Menu-driven systems Pointers to each function stored in array of pointers to functions – All functions must have same return type and same parameter types Menu choice determines subscript into array of function pointers
105
2008 Pearson Education, Inc. All rights reserved. 105 Outline ArrayOfFunctionP ointers.cpp (1 of 3) Array initialized with names of three functions
106
2008 Pearson Education, Inc. All rights reserved. 106 Outline ArrayOfFunctionP ointers.cpp (2 of 3) Call chosen function by dereferencing corresponding element in array
107
2008 Pearson Education, Inc. All rights reserved. 107 Outline ArrayOfFunctionP ointers.cpp (3 of 3)
108
2008 Pearson Education, Inc. All rights reserved. 108 9.13 Introduction to Pointer-Based String Processing Standard Library functions for string processing – Appropriate for developing text-processing software
109
2008 Pearson Education, Inc. All rights reserved. 109 9.13.1 Fundamentals of Characters and Pointer-Based Strings Character constant – Integer value represented as character in single quotes Example – 'z' is integer value of z 122 in ASCII – '\n' is integer value of newline 10 in ASCII
110
2008 Pearson Education, Inc. All rights reserved. 110 9.13.1 Fundamentals of Characters and Pointer-Based Strings (Cont.) String – Series of characters treated as single unit – Can include letters, digits, special characters +, -, *,... – String literal (string constants) Enclosed in double quotes, for example: "I like Visual C++“ Have static storage class – Array of characters, ends with null character '\0' – String is constant pointer Pointer to string’s first character – Like arrays
111
2008 Pearson Education, Inc. All rights reserved. 111 9.13.1 Fundamentals of Characters and Pointer-Based Strings (Cont.) String assignment – Character array char color[] = "blue"; – Creates 5 element char array color Last element is '\0' – Variable of type char * char *colorPtr = "blue"; – Creates pointer colorPtr to letter b in string "blue" "blue" somewhere in memory – Alternative for character array char color[] = { ' b ', ' l ', ' u ', ' e ', ' \0 ' };
112
2008 Pearson Education, Inc. All rights reserved. 112 Common Programming Error 9.15 Not allocating sufficient space in a character array to store the null character that terminates a string is an error.
113
2008 Pearson Education, Inc. All rights reserved. 113 Common Programming Error 9.16 Creating or using a C-style string that does not contain a terminating null character can lead to logic errors.
114
2008 Pearson Education, Inc. All rights reserved. 114 Error-Prevention Tip 9.4 When storing a string of characters in a character array, be sure that the array is large enough to hold the largest string that will be stored. Visual C++ allows strings of any length to be stored. If a string is longer than the character array in which it is to be stored, characters beyond the end of the array will overwrite data in memory following the array, leading to logic errors.
115
2008 Pearson Education, Inc. All rights reserved. 115 9.13.1 Fundamentals of Characters and Pointer-Based Strings (Cont.) Reading strings – Assign input to character array word[ 20 ] cin >> word; – Reads characters until whitespace or EOF – String could exceed array size cin >> setw( 20 ) >> word; – Reads only up to 19 characters (space reserved for '\0' )
116
2008 Pearson Education, Inc. All rights reserved. 116 9.13.1 Fundamentals of Characters and Pointer-Based Strings (Cont.) cin.getline – Read line of text cin.getline( array, size, delimiter ); – Copies input into specified array until either One less than size is reached delimiter character is input Example char sentence[ 80 ]; cin.getline( sentence, 80, '\n' );
117
2008 Pearson Education, Inc. All rights reserved. 117 Common Programming Error 9.17 Processing a single character as a char * string can lead to a fatal runtime error. A char * string is a pointer—probably a respectably large integer. However, a character is a small integer (ASCII values range 0–255). On many systems, dereferencing a char value causes an error, because low memory addresses are reserved for special purposes such as operating system interrupt handlers—so “memory access violations” occur.
118
2008 Pearson Education, Inc. All rights reserved. 118 Common Programming Error 9.18 Passing a string as an argument to a function when a character is expected is a compilation error.
119
2008 Pearson Education, Inc. All rights reserved. 119 9.13.2 String-Manipulation Functions of the String-Handling Library String handling library provides functions to – Manipulate string data – Compare strings – Search strings for characters and other strings – Tokenize strings (separate strings into logical pieces) Data type size_t – Defined to be an unsigned integral type Such as unsigned int or unsigned long – In header file
120
2008 Pearson Education, Inc. All rights reserved. 120 Fig. 9.30 | String-manipulation functions of the string-handling library. (Part 1 of 2)
121
2008 Pearson Education, Inc. All rights reserved. 121 Fig. 9.30 | String-manipulation functions of the string-handling library. (Part 2 of 2)
122
2008 Pearson Education, Inc. All rights reserved. 122 Common Programming Error 9.19 Forgetting to include the header file when using functions from the string-handling library causes compilation errors.
123
2008 Pearson Education, Inc. All rights reserved. 123 9.13.2 String Manipulation Functions of the String-Handling Library (Cont.) Copying strings – char *strcpy( char *s1, const char *s2 ) Copies second argument into first argument – First argument must be large enough to store string and terminating null character – char *strncpy( char *s1, const char *s2, size_t n ) Specifies number of characters to be copied from second argument into first argument – Does not necessarily copy terminating null character
124
2008 Pearson Education, Inc. All rights reserved. 124 Common Programming Error 9.20 When using strncpy, the terminating null character of the second argument (a char * string) will not be copied if the number of characters specified by strncpy’s third argument is not greater than the second argument’s length. In that case, a fatal error may occur if the programmer does not manually terminate the resulting char * string with a null character.
125
2008 Pearson Education, Inc. All rights reserved. 125 Outline StringFunctions. cpp (1 of 2) contains prototypes for strcpy and strncpy Copy entire string in array x into array y
126
2008 Pearson Education, Inc. All rights reserved. 126 Outline StringFunctions. cpp (2 of 2) Copy first 14 characters of array x into array y. Note that this does not write terminating null character Append terminating null character String to copy Copied string using strcpy Copied first 14 characters using strncpy
127
2008 Pearson Education, Inc. All rights reserved. 127 9.13.2 String Manipulation Functions of the String-Handling Library (Cont.) Concatenating strings – char *strcat( char *s1, const char *s2 ) Appends second argument to first argument – First character of second argument replaces null character terminating first argument – You must ensure first argument large enough to store concatenated result and null character – char *strncat( char *s1, const char *s2, size_t n ) Appends specified number of characters from second argument to first argument – Appends terminating null character to result
128
2008 Pearson Education, Inc. All rights reserved. 128 Outline StringFunctions. cpp (1 of 2) contains prototypes for strcat and strncat Append s2 to s1 Append first 6 characters of s1 to s3
129
2008 Pearson Education, Inc. All rights reserved. 129 Outline StringFunctions. cpp (2 of 2) Append s1 to s3
130
2008 Pearson Education, Inc. All rights reserved. 130 9.13.2 String Manipulation Functions of the String-Handling Library (Cont.) Comparing strings – int strcmp( const char *s1, const char *s2 ) Compares character by character Returns – Zero if strings are equal – Negative value if first string is less than second string – Positive value if first string is greater than second string – int strncmp( const char *s1, const char *s2, size_t n ) Compares up to specified number of characters – Stops if it reaches null character in one of arguments
131
2008 Pearson Education, Inc. All rights reserved. 131 Common Programming Error 9.21 Assuming that strcmp and strncmp return one (a true value) when their arguments are equal is a logic error. Both functions return zero (Visual C++'s false value) for equality. Therefore, when testing two strings for equality, the result of the strcmp or strncmp function should be compared with zero to determine whether the strings are equal.
132
2008 Pearson Education, Inc. All rights reserved. 132 Outline StringFunctions. cpp (1 of 2) contains prototypes for strcmp and strncmp Compare s1 and s2 Compare s1 and s3 Compare s3 and s1 Compare up to 6 characters of s1 and s3 Compare up to 7 characters of s1 and s3 Compare up to 7 characters of s3 and s1
133
2008 Pearson Education, Inc. All rights reserved. 133 Outline StringFunctions. cpp (2 of 2)
134
2008 Pearson Education, Inc. All rights reserved. 134 9.13.2 String Manipulation Functions of the String-Handling Library (Cont.) Comparing strings (Cont.) – Characters represented as numeric codes Strings compared using numeric codes – Character codes / character sets ASCII – “American Standard Code for Information Interchage” EBCDIC – “Extended Binary Coded Decimal Interchange Code” Unicode
135
2008 Pearson Education, Inc. All rights reserved. 135 Portability Tip 9.4 The internal numeric codes used to represent characters may be different on different computers that use different character sets.
136
2008 Pearson Education, Inc. All rights reserved. 136 Portability Tip 9.5 Do not explicitly test for ASCII codes, as in if ( rating == 65 ) ; rather, use the corresponding character constant, as in if ( rating == 'A' ).
137
2008 Pearson Education, Inc. All rights reserved. 137 9.13.2 String Manipulation Functions of the String-Handling Library (Cont.) Tokenizing – Breaking strings into tokens Tokens usually logical units, such as words (separated by spaces) Separated by delimiting characters – Example "This is my string" has 4 word tokens (separated by spaces)
138
2008 Pearson Education, Inc. All rights reserved. 138 9.13.2 String Manipulation Functions of the String-Handling Library (Cont.) Tokenizing (Cont.) – char *strtok( char *s1, const char *s2 ) Multiple calls required – First call contains two arguments, string to be tokenized and string containing delimiting characters Finds next delimiting character and replaces with null character – Subsequent calls continue tokenizing Call with first argument NULL Stores pointer to remaining string in a static variable Returns pointer to current token
139
2008 Pearson Education, Inc. All rights reserved. 139 Outline StringTokenize.cpp (1 of 2) contains prototype for strtok First call to strtok begins tokenization Subsequent calls to strtok with NULL as first argument to indicate continuation
140
2008 Pearson Education, Inc. All rights reserved. 140 Outline StringTokenize.cpp (2 of 2)
141
2008 Pearson Education, Inc. All rights reserved. 141 Common Programming Error 9.22 Not realizing that strtok modifies the string being tokenized, then attempting to use that string as if it were the original unmodified string is a logic error.
142
2008 Pearson Education, Inc. All rights reserved. 142 9.13.2 String Manipulation Functions of the String-Handling Library (Cont.) Determining string lengths – size_t strlen( const char *s ) Returns number of characters in string – Terminating null character is not included in length – This length is also the index of the terminating null character
143
2008 Pearson Education, Inc. All rights reserved. 143 Outline Strlen.cpp (1 of 1) contains prototype for strlen Using strlen to determine length of strings
144
2008 Pearson Education, Inc. All rights reserved. 9.14 Introduction to C++/CLI Handles Denoted with the ^ symbol (pronounced “hat”) Often performs as a pointer would Date ^dHandle, dateCount; – Variable dHandle is of type Date ^ (i.e., a handle to a Date object) Read, “dHandle is a handle to Date” Or “dHandle points to an object of type Date.” – Variable dateCount is declared to be a Date object, not a handle to a Date object The ^ in the declaration applies only to dHandle Use the C++/CLI keyword nullptr to assign a null value to a handle
145
2008 Pearson Education, Inc. All rights reserved. 9.14 Introduction to C++/CLI Handles (Cont.) Differences Between Handles and Pointers – Handles must point to managed objects – Cannot perform pointer arithmetic operations on handles – Handles cannot be compared meaningfully with boolean operators i.e., == or != – Attempting to create a handle to a handle results in a compilation error – Cannot create a handle to a function – No void ^ (analogous to void *)
146
2008 Pearson Education, Inc. All rights reserved. 9.14 Introduction to C++/CLI Handles (Cont.) Handle Operators – % operator returns the memory address of a managed object Date ^dHandle = nullptr; Date d; dHandle = %d; – Dereferenced with using the * operator or the -> operator (explained in Chapter 10) – Everything from Section 9.3, Pointer Operators, can be applied in an analogous way to handles Using const with Handles – Handles can be declared const – Data they point to can be declared const – C++/CLI forbids its use in some places where native C++ emphasizes it
147
2008 Pearson Education, Inc. All rights reserved. Error-Prevention Tip 9.5 Remember to use the nullptr keyword to initialize handles to a null value. Using 0 or NULL may compile but will not set the handle to a null value and may cause hard to find logic errors.
148
2008 Pearson Education, Inc. All rights reserved. Common Programming Error 9.23 Remember that the & operator returns a pointer. The % returns a handle. Using the & operator on a managed object is a compilation error. Likewise, using the % operator on a native object is also a compilation error.
149
2008 Pearson Education, Inc. All rights reserved. 149 Outline Data.h (1 of 1)
150
2008 Pearson Education, Inc. All rights reserved. 150 Outline HandleExample.cpp (1 of 1) Create a managed Date object Declare dHandle as a handle to a Date object Assign the address of d to dHandle Dereference dHandle to access the Date object is points to
151
2008 Pearson Education, Inc. All rights reserved. 9.15 Passing Arguments to Functions by Reference with Handles Use handles and the dereference operator ( * ) on managed objects to accomplish pass-by-reference just as in Section 9.4 Handle passed to the function is copied for use in the function body – Points to the same object as original handle – Copy destroyed when function ends
152
2008 Pearson Education, Inc. All rights reserved. 152 Outline HandleByReference. cpp (1 of 2) Create a managed Date object
153
2008 Pearson Education, Inc. All rights reserved. 153 Outline HandleByReference. cpp (2 of 2) dH is a copy of the handle passed to the function Modify the object referenced by the original handle Changes visible in original object
154
2008 Pearson Education, Inc. All rights reserved. 9.16 Tracking References and References Analogous to native C++ references but reference managed objects Can use as an alias for another variable (of a managed type) in a function just as with reference parameters – Date d; Date %dRef = d; dRef.Day = 30; Pronounced as “dRef is a tracking reference to a Date object.” All operations performed on the alias (i.e., the reference) are actually performed on the original variable
155
2008 Pearson Education, Inc. All rights reserved. 9.16 Tracking References and References (Cont.) Must be initialized in its declaration and cannot be reassigned as an alias to a different variable Often used with function parameters to specify pass-by-reference Tracking reference to a handle – Pass and handle by reference – Used as an alias to the handle
156
2008 Pearson Education, Inc. All rights reserved. Outline PassHandleByReference.cpp Part 1 of 2 s is a handle to a String s is destroyed when function ends
157
2008 Pearson Education, Inc. All rights reserved. Outline PassHandleByReference.cpp Part 2 of 2 s is a tracking reference to a handle to a String Changes made to s are actually made to text Original handle modified when passed by reference
158
2008 Pearson Education, Inc. All rights reserved. Outline ForEachByReference.cpp Tracking reference to a handle used to modify elements in a for each statement
159
2008 Pearson Education, Inc. All rights reserved. 9.17 Interior Pointers Two important features of native pointers unavailable with handles – Point directly to the memory address of an object’s data member Handles must point to whole managed objects – Pointer arithmetic and comparison Declared with a template-style syntax interior_ptr ptrName = memoryAddress; Date d; d.Day = 30; interior_ptr interiorPointer = &d.value;
160
2008 Pearson Education, Inc. All rights reserved. 9.17 Interior Pointers (Cont.) Use & and not % with interior pointers Using the address operator ( & ) on an interior pointer returns a native pointer Native pointers are implicitly converted to interior pointers (but not vice versa) Cannot be used as data members of a class Cannot point directly to managed objects—only to handles to managed objects
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.