Documenti di Didattica
Documenti di Professioni
Documenti di Cultura
Introduction
Pointers (Declaration and Initialization, Operators)
Calling Function by Reference
Object Oriented Programming Using Const Keyword
Pointer Examples , Pass by Reference (Bubble Sort)
Pointer Expression and Arithmetic
Relationship Between Pointers and Arrays
Arrays of Pointers
Introduction to Character and Strings
String Manipulation Functions
Powerful, but difficult to master Normally, variable contains specific value (direct reference)
Simulate pass-by-reference Pointers contain address of variable that has specific value (indirect reference)
Pointer declarations 7
* indicates variable is pointer
int *myPtr;
count
declares pointer to int, pointer of type int *
Multiple pointers require multiple asterisks 7
int *myPtr1, *myPtr2;
y yptr y
address of
y is value
of yptr
Pointers: Operators Pointers: Operators
2 // Using the & and * operators.
3 #include <iostream>
4
* (indirection/dereferencing operator) 5 using std::cout;
6 using std::endl;
Returns synonym for object its pointer operand points to 7
8 int main()
9 {
*yPtr returns y (because yPtr points to y). 10 int a; // a is an integer
11 int *aPtr; // aPtr is a pointer to an integer
dereferenced pointer is l value 12
13 a = 7;
14 aPtr = &a; // aPtr assigned address of a
15
16 cout << "The address of a is " << &a
* and & are inverses
*yptr = 9; // assigns 9 to y 17 << "\nThe value of aPtr is " << aPtr;
18 of each other
19 cout << "\n\nThe value of a is " << a
20 << "\nThe value of *aPtr is " << *aPtr;
21
* and & are inverses of each other 22 cout << "\n\nShowing that * and & are inverses of "
vPtr points to v[ 2 ]
v[0] v[1] v[2] v[3] v[4]
Pointer Expressions and Pointer Arithmetic Pointer Expressions and Pointer Arithmetic
1 // 26
2 // Copying a string using array notation Use array subscript notation to
3 // and pointer notation.
27 } // end main
copy string in s2 to character
4 #include <iostream> 28 array s1.
5 29 // copy s2 to s1 using array notation
6 using std::cout; 30 void copy1( char *s1, const char *s2 )
7 using std::endl;
8 31 {
9 void copy1( char *, const char * ); // prototype 32 for ( int i = 0; ( s1[ i ] = s2[ iUse]pointer) != '\0';
notation to copy
10 void copy2( char *, const char * ); // prototype i++ ) string in s2 to character array in
11 s1.
12 int main()
33 ; // do nothing in body
13 { 34
14 char string1[ 10 ]; 35 } // end function copy1
15 char *string2 = "Hello";
16 char string3[ 10 ];
36
17 char string4[] = "Good Bye"; 37 // copy s2 to s1 using pointer notation
Increment both pointers to point
18 38 void copy2( char *s1, const char to next )
*s2 elements in
19 copy1( string1, string2 ); corresponding arrays.
39 {
20 cout << "string1 = " << string1 << endl;
21
40 for ( ; ( *s1 = *s2 ) != '\0'; s1++, s2++ )
22 copy2( string3, string4 ); 41 ; // do nothing in body
23 cout << "string3 = " << string3 << endl; 42
24 string1 = Hello
43 } // end function copy2
25 return 0; // indicates successful termination
string3 = Good Bye
Hearts 0
suit[0] H e a r t s \0
Diamonds 1
suit[1] D i a m o n d s \0 Clubs 2
Spades 3
suit[2] C l u b s \0
deck[2][12] represents the King of Clubs
suit[3] S p a d e s \0
Clubs King
Place 1-52 into the array to specify the order in which the cards
suit array has fixed size, but strings can be of any size are dealt
Case Study: Card Shuffling and Dealing Nine of Spades Seven of Clubs
Five of Spades Eight of Clubs
Simulation Queen of Diamonds Three of Hearts
Jack of Spades Five of Diamonds
Jack of Diamonds Three of Diamonds
Three of Clubs Six of Clubs
Pseudocode for shuffling and dealing simulation Ten of Clubs Nine of Diamonds
Ace of Hearts Queen of Hearts
Seven of Spades Deuce of Spades
Third refinement Six of Hearts Deuce of Clubs
First refinement Ace of Clubs Deuce of Diamonds
Second refinement Nine of Hearts Seven of Diamonds
Choose slot of deck randomly
Initialize the suit array Six of Spades Eight of Diamonds
For each of the 52 cards Ten of Spades King of Hearts
Initialize the face array While chosen slot of deck has
Initialize the deck array
Four of Clubs Ace of Spades
Place card number in randomly been previously chosen Ten of Hearts Four of Spades
selected unoccupied slot of deck Choose slot of deck randomly Eight of Hearts Eight of Spades
Place card number in chosen Jack of Hearts Ten of Diamonds
Shuffle the deck slot of deck Four of Diamonds King of Diamonds
Seven of Hearts King of Spades
Queen of Spades Four of Hearts
For each of the 52 cards For each slot of the deck array Nine of Clubs Six of Diamonds
Deal 52 cards Deuce of Hearts Jack of Clubs
King of Clubs Three of Spades
Find card number in deck array If slot contains card number Queen of Clubs Five of Clubs
and print face and suit of card Print the face and suit of the Five of Hearts Ace of Diamonds
card
Array of characters, ends with null character '\0' Alternative for character array
String is constant pointer char color[] = { b, l, u, e, \0 };
Pointer to strings first character
Like arrays
String Manipulation Functions of the String- String Manipulation Functions of the String-
handling Library handling Library
int strncmp( const char *s1, const char *s2, size_t n ); Copying strings
Compares up to n characters of the string s1 with the string s2. The
function returns zero, less than zero or greater than zero if s1 is equal to, char *strcpy( char *s1, const char
less than or greater than s2, respectively. *s2 )
char *strtok( char *s1, const char *s2 ); Copies second argument into first argument
A sequence of calls to strtok breaks string s1 into tokenslogical pieces First argument must be large enough to store string and terminating
such as words in a line of textdelimited by characters contained in null character
string s2. The first call contains s1 as the first argument, and subsequent char *strncpy( char *s1, const char
calls to continue tokenizing the same string contain NULL as the first
argument. A pointer to the current token is returned by each call. If there *s2, size_t n )
are no more tokens when the function is called, NULL is returned. Specifies number of characters to be copied from string into
array
size_t strlen( const char *s ); Does not necessarily copy terminating null character
Determines the length of string s. The number of characters preceding the
terminating null character is returned.
1
2
3
//
// Using strcpy and strncpy.
#include <iostream>
<cstring> contains prototypes
for strcpy and strncpy. String Manipulation Functions of the
4
5
6
7
using std::cout;
using std::endl; String-handling Library
8 #include <cstring> // prototypes for strcpy and strncpy Copy entire string in array x into
9
10
11
int main()
{
array y. Concatenating strings
12
13
char x[] = "Happy Birthday to You";
char y[ 25 ];
char *strcat( char *s1, const char *s2 )
14
15
char z[ 15 ];
Copy first 14 characters of array x Appends second argument to first argument
16
17
strcpy( y, x ); // copy contents of x into y into array y. Note that this does First character of second argument replaces null character terminating
18 cout << "The string in array x is: " << x not write terminating null first argument
19 << "\nThe string in array y is: " << y << '\n';
character.
20
21 // copy first 14 characters of x into z Ensure first argument large enough to store concatenated result and
22
23
strncpy( z, x, 14 ); // does not copy null character
z[ 14 ] = '\0'; // append '\0' to z's contents null character
24
25 cout << "The string in array z is: " << z << endl; char *strncat( char *s1, const char *s2,
26
27 return 0; // indicates successful termination
Append terminating null
size_t n )
28
29 } // end main character. Appends specified number of characters from second argument to first
argument
Appends terminating null character to result
String Manipulation Functions of the String- String Manipulation Functions of the String-
handling Library handling Library
Comparing strings Comparing strings
Characters represented as numeric codes int strcmp( const char *s1, const char *s2 )
Compares character by character
Strings compared using numeric codes Returns
Character codes / character sets Zero if strings equal
ASCII Negative value if first string less than second string
American Standard Code for Information Interchage Positive value if first string greater than second string
EBCDIC int strncmp( const char *s1,
Extended Binary Coded Decimal Interchange Code const char *s2, size_t n )
Compares up to specified number of characters
Stops comparing if reaches null character in one of arguments
Compare up to 6 characters of s1
1
and s3.
// 26
2 // Using strcmp and strncmp. 27 cout << "\n\nstrncmp(s1, s3, 6) = " << setw( 2 )
3 #include <iostream>
28 << strncmp( s1, s3, 6 ) << "\nstrncmp(s1, s3, 7) = "
4 <cstring> contains prototypes
5 29 << setw( 2 ) << strncmp( s1, s3, 7 )
using std::cout; for strcmp and strncmp.
6 using std::endl; 30 << "\nstrncmp(s3, s1, 7) = "
7 31 << setw( 2 ) << strncmp( s3, s1, 7 ) << endl;
Compare up to 7 characters of s1
8 #include <iomanip> 32 and s3.
9 33 return 0; // indicates successful termination
10 using std::setw;
34 Compare up to 7 characters of s3
11
12 #include <cstring> // prototypes for strcmp and strncmp 35 } // end main and s1.
13
14 int main()
Compare s1 to s2.
15 {
16 char *s1 = "Happy New Year"; s1 = Happy New Year
17 char *s2 = "Happy New Year"; s2 = Happy New Year
18 char *s3 = "Happy Holidays";
s3 = Happy Holidays
19
20 cout << "s1 = " << s1 << "\ns2 = " << s2
21 << "\ns3 = " << s3 << "\n\nstrcmp(s1, s2) = " strcmp(s1, s2) = 0
22 << setw( 2 ) << strcmp( s1, s2 ) strcmp(s1, s3) = 1
23 << "\nstrcmp(s1, s3) = " << setw( 2 ) Compare s1 to s3. strcmp(s3, s1) = -1
24 << strcmp( s1, s3 ) << "\nstrcmp(s3, s1) = "
25 << setw( 2 ) << strcmp( s3, s1 );
strncmp(s1, s3, 6) = 0
strncmp(s1, s3, 7) = 1
Compare s3 to s1. strncmp(s3, s1, 7) = -1
String Manipulation Functions of the String- 1 //
2 // Using strtok.
handling Library 3
4
#include <iostream> <cstring> contains prototype
5 using std::cout; for strtok.
6 using std::endl;
7
Tokenizing 8 #include <cstring> // prototype for strtok
9
Breaking strings into tokens, separated by delimiting characters 10 int main()
11
Tokens usually logical units, such as words (separated by 12
{
char sentence[] = "This is a sentence with 7 tokens";
spaces) 13 char *tokenPtr; First call to strtok begins
14 tokenization.
"This is my string" has 4 word tokens (separated by 15 cout << "The string to be tokenized is:\n" << sentence
16
spaces) 17
<< "\n\nThe tokens are:\n\n";
char *strtok( char *s1, const char *s2 ) 18 // begin tokenization of sentence
19 tokenPtr = strtok( sentence, " " );
Multiple calls required 20
First call contains two arguments, string to be tokenized and string 21 // continue tokenizing sentence until tokenPtr becomes NULL
containing delimiting characters 22 while ( tokenPtr != NULL ) {
23 cout << tokenPtr << '\n';
Finds next delimiting character and replaces with null character 24 tokenPtr = strtok( NULL, " " ); // get next token
Subsequent calls continue tokenizing 25
Call with first argument NULL 26 } // end while
27
28 cout << "\nAfter strtok, sentence = " << sentence << endl;
29
30 return 0; // indicates successful termination
Subsequent calls to strtok with
31
32 } // end main NULL as first argument to
indicate continuation.
This
is
Determining string lengths
a size_t strlen( const char *s )
sentence
with Returns number of characters in string
7 Terminating null character not included in length
tokens
1 //
2 // Using strlen.
3 #include <iostream>
4 <cstring> contains prototype
5 using std::cout; for strlen.
6 using std::endl;
7
8 #include <cstring> // prototype for strlen
9
10 int main()
11 {
12 char *string1 = "abcdefghijklmnopqrstuvwxyz";
13 char *string2 = "four";
14 char *string3 = "Boston";
15
16 cout << "The length of \"" << string1
17 << "\" is " << strlen( string1 ) Using strlen to
18 << "\nThe length of \"" << string2 determine length of strings.
19 << "\" is " << strlen( string2 )
20 << "\nThe length of \"" << string3
21 << "\" is " << strlen( string3 ) << endl;
22
23 return 0; // indicates successful termination
24
25 } // end main