Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved. 013225445X 1 Chapter 7 Pointers and C-Strings.

Slides:



Advertisements
Similar presentations
Strings.
Advertisements

This Time Pointers (declaration and operations) Passing Pointers to Functions Const Pointers Bubble Sort Using Pass-by-Reference Pointer Arithmetic Arrays.
Pointers and Strings. Introduction Pointers –Powerful, but difficult to master –Simulate call-by-reference –Close relationship with arrays and strings.
Copyright © 2012 Pearson Education, Inc. Chapter 9: Pointers.
Chapter 10.
Copyright © 2008 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Starting Out with C++ Early Objects Sixth Edition Chapter 10: Pointers by.
Pointers A pointer is a variable that contains memory address as its value. A variable directly contains a specific value. A pointer contains an address.
Pointers. Topics Pointers Pointer Arithmetic Pointers and Arrays.
Chapter 8. 2 Objectives You should be able to describe: One-Dimensional Arrays Array Initialization Arrays as Arguments Two-Dimensional Arrays Common.
Copyright © 2015, 2012, 2009 Pearson Education, Inc., Publishing as Addison-Wesley All rights reserved. Chapter 9: Pointers.
1 Chapter 9 Pointers. 2 Topics 8.1 Getting the Address of a Variable 8.2 Pointer Variables 8.3 Relationship Between Arrays and Pointers 8.4 Pointer Arithmetic.
Pointers CS362. Pointers A Pointer is a variable that can hold a memory address Pointers can be used to: Indirectly reference existing variables (sometimes.
Liang, Introduction to Programming with C++, Second Edition, (c) 2010 Pearson Education, Inc. All rights reserved Chapter 7 Single-Dimensional.
 2006 Pearson Education, Inc. All rights reserved Arrays.
CHAPTER 07 Arrays and Vectors (part I). OBJECTIVES 2 In this part you will learn:  To use the array data structure to represent a set of related data.
Copyright © 2009 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 9: Pointers.
(continue) © by Pearson Education, Inc. All Rights Reserved.
Chapter 10. Characters, Strings and the string class Csc 125 Introduction to C++ Fall 2005.
CS Midterm Study Guide Fall General topics Definitions and rules Technical names of things Syntax of C++ constructs Meaning of C++ constructs.
CHAPTER 7 arrays I NTRODUCTION T O C OMPUTER P ROGRAMMING (CSC425)
Copyright © 2012 Pearson Education, Inc. Chapter 10: Characters, C- Strings, and More About the string Class.
1 Pointers and Strings Chapter 5 2 What You Will Learn...  How to use pointers Passing arguments to functions with pointers See relationship of pointers.
Pointers. What is pointer l Everything stored in a computer program has a memory address. This is especially true of variables. char c=‘y’; int i=2; According.
Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X1 Chapter 3 Control Statements.
19&20-2 Know how to declare pointer variables. Understand the & (address) and *(indirection) operators. Dynamic Memory Allocation Related Chapter: ABC.
Chapter 13 – C++ String Class. String objects u Do not need to specify size of string object –C++ keeps track of size of text –C++ expands memory region.
1 CISC181 Introduction to Computer Science Dr. McCoy Lecture 13 October 13, 2009.
 2000 Deitel & Associates, Inc. All rights reserved Introduction Pointers –Powerful, but difficult to master –Simulate call-by-reference –Close.
Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 1 Chapter 6 Arrays.
Pointers A pointer is a variable that contains a memory address as it’s value. The memory address points to the actual data. –A pointer is an indirect.
Copyright © 2012 Pearson Education, Inc. Chapter 10: Characters, C- Strings, and More About the string Class.
Copyright © 2009 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 10: Characters, Strings, and the string class.
Chapter 2: Introduction to C++. Language Elements Keywords Programmer-defined symbols (identifiers) Operators Punctuation Syntax Lines and Statements.
Copyright © 2015, 2012, 2009 Pearson Education, Inc., Publishing as Addison-Wesley All rights reserved. Chapter 10: Characters, C- Strings, and More About.
Review 1 List Data Structure List operations List Implementation Array Linked List.
Lecture – Pointers1 C++ Pointers Joseph Spring/Bob Dickerson School of Computer Science Operating Systems and Computer Networks Based on notes by Bob Dickerson.
 2003 Prentice Hall, Inc. All rights reserved. 1 Pointers and Strings Outline Introduction Pointer Variable Declarations and Initialization Pointer Operators.
Liang, Introduction to Programming with C++, Second Edition, (c) 2010 Pearson Education, Inc. All rights reserved Chapter 6 Arrays.
Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 1 Chapter Array Basics.
© Copyright 2013 by Pearson Education, Inc. All Rights Reserved. 1 Chapter 7 Single-Dimensional Arrays and C-Strings.
C++ Programming Lecture 19 Strings The Hashemite University Computer Engineering Department (Adapted from the textbook slides)
1 2/2/05CS250 Introduction to Computer Science II Pointers.
Lecture 5 Computer programming -1-. Input \ Output statement 1- Input (cin) : Use to input data from keyboard. Example : cin >> age; 2- Output (cout):
Liang, Introduction to Java Programming, Fifth Edition, (c) 2005 Pearson Education, Inc. All rights reserved Chapter 6 Arrays.
1 Chapter 7 Pointers and C-Strings. 2 Objectives  To describe what a pointer is (§7.1).  To learn how to declare a pointer and assign a value to it.
Copyright © 2012 Pearson Education, Inc. Chapter 9: Pointers.
Copyright © 2009 Pearson Education, Inc. Publishing as Pearson Addison-Wesley 9-1 Pointer Variables Pointer variable : Often just called a pointer, it's.
1 C++ Data Types structured array struct union class address pointer reference simple integral enum char short int long bool floating float double long.
Liang, Introduction to Programming with C++, Second Edition, (c) 2010 Pearson Education, Inc. All rights reserved Chapter 6 Arrays.
Pointers Lecture: 5. Topics 1 Pointers and the Address Operator 2 Pointer Variables 3 The Relationship Between Arrays and Pointers 4 Pointer Arithmetic.
Topic 5 Addresses, Pointers and Arrays. 2 Objectives (Textbook Chapter 14) You should be able to describe: Addresses and Pointers Pointer Operators Pointer.
Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 1 Chapter 7 Enumerated Types and Strings Types.
Chapter 1.2 Introduction to C++ Programming
Chapter 1.2 Introduction to C++ Programming
Chapter 7 Pointers and C-Strings
Chapter 1.2 Introduction to C++ Programming
Chapter 1.2 Introduction to C++ Programming
Chapter 6 Arrays Lecturer: Mrs Rohani Hassan
Pointers and Pointer-Based Strings
Pointers Psst… over there.
Andy Wang Object Oriented Programming in C++ COP 3330
Pointers Psst… over there.
Chapter 9: Pointers.
Chapter 2 Elementary Programming
Chapter 7 Single-Dimensional Arrays and C-Strings
7 Arrays.
Pointers and Pointer-Based Strings
C++ Programming Lecture 20 Strings
Introducing Arrays Array is a data structure that represents a collection of the same types of data. From resourses of Y. Daniel Liang, “Introduction.
Presentation transcript:

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 1 Chapter 7 Pointers and C-Strings

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 2 What is a Pointer? Pointer variables, simply called pointers, are designed to hold memory addresses as their values. Normally, a variable contains a specific value, e.g., an integer, a floating-point value, and a character. However, a pointer contains the memory address of a variable that in turn contains a specific value.

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 3 Declare a Pointer Like any other variables, pointers must be declared before they can be used. To declare a pointer, use the following syntax: dataType *pVarName; Each variable being declared as a pointer must be preceded by an asterisk (*). For example, the following statement declares a pointer variable named pCount that can point to an int varaible. int *pCount, count; Count=5; pCount=&count; // & is the address operator. TestPointer.cpp Run

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X #include using namespace std; int main() { int count = 5; int *pCount = &count; cout << "The address of count is " << &count << endl; cout << "The address of count is " << pCount << endl; cout << "The value of count is " << count << endl; cout << "The value of count is " << *pCount << endl; return 0; } 4 TestPointer.cpp

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 5 Dereferencing Referencing a value through a pointer is called indirection (dereferencing). The syntax for referencing a value from a pointer is *pointer For example, you can increase count using count++; // direct reference or (*pCount)++; // indirect reference

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 6 Pointer Type A pointer variable is declared with a type such as int, double, etc. You have to assign the address of the variable of the same type. It is a syntax error if the type of the variable does not match the type of the pointer. For example, the following code is wrong. int area = 1; double *pArea = &area; // Wrong

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 7 Initializing Pointer  Like a local variable, a local pointer is assigned an arbitrary value if you don’t initialize it.  A pointer may be initialized to 0, which is a special value for a pointer to indicate that the pointer points to nothing.  You should always initialize pointers to prevent errors.  Dereferencing a pointer that is not initialized could cause fatal runtime error or it could accidentally modify important data.

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 8 Caution You can declare two variables on the same line. For example, the following line declares two int variables: int i = 0, j = 1; Can you declare two pointer variables on the same line as follows? int* pI, pJ; No, this line is equivalent to: int *pI, pJ; You have to put: int *pI, *pJ;

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 9 Passing Arguments by Reference with Pointers There are three ways to pass arguments to a function in C++: F pass by value, F pass by reference with reference arguments F pass by reference with pointers. TestPointerArgument.cpp

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X #include using namespace std; // Swap two variables void swap(int *pValue1, int *pValue2) { // Swap n1 with n2 int temp = *pValue1; *pValue1 = *pValue2; *pValue2 = temp; } 10 TestPointerArgument.cpp

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X int main() { // Declare and initialize variables int num1 = 1; int num2 = 2; cout << "Before invoking the swap function, num1 is " << num1 << " and num2 is " << num2 << endl; // Invoke the swap function to attempt to swap two variables swap(&num1, &num2); cout << "After invoking the swap function, num1 is " << num1 << " and num2 is " << num2 << endl; return 0; } 11

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 12 Arrays and Pointers Recall that an array variable without a bracket and a subscript actually represents the starting address of the array. In this sense, an array variable is essentially a pointer. Suppose you declare an array of int value as follows: int list[6] = {11, 12, 13, 14, 15, 16};

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 13 Array Pointer *(list + 1) is different from *list + 1. The dereference operator (*) has precedence over +. So, *list + 1 adds 1 to the value of the first element in the array, while *(list + 1) dereference the element at address (list + 1) in the array. ArrayPointer.cpp

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X #include using namespace std; int main() { int list[6] = {11, 12, 13, 14, 15, 16}; for (int i = 0; i < 6; i++) cout << "address: " << (list + i) << " value: " << *(list + i) << " " << " value: " << list[i] << endl; return 0; } 14 ArrayPointer.cpp list[i] is equivalent to *(list+i)

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 15 Using const with Pointers You learned how to declare a constant using the const keyword. A constant cannot be changed once it is declared. You can declare a constant pointer. For example, see the following code: double radius = 5; double * const pValue = &radius; const double * const pValue=&radius ; // pointer is a constant and data pointed by the pointer is also a constant.

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 16 Using const with Pointers double radius=5; double * const pValue=&radius; double length = 5; *pValue=6; //OK pValue=&length; // Wrong because pValue is a constant pointer. const double *pValue1=&radius; *pValue=6; //Wrong because pValue1 points to constant data. pValue1=&length; //OK const double * const pValue2=&radius; *pValu2=6; //Wrong because pValue2 points to a constant data *pValue2=&length; //Wrong because pValue2 is a constant pointer

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X #include using namespace std; void printArray(const int *, const int); // function prototype int main() { int list[6] = {11, 12, 13, 14, 15, 16}; printArray(list, 6); return 0; } void printArray(const int * list, const int size) { for (int i = 0; i < size; i++) cout << list[i] << " "; } ConstParameter.cpp

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 18 Characters and C-Strings Strings are used often in programming. You have used string literals. A string is a sequence of characters. There are two ways to process strings in C++. One way is to treat strings as arrays of characters. This is known as pointer-based strings or C-strings. The other way is to process strings using the string class. The string class will be introduced in §9.14. This section introduces pointer-based strings.

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 19 Character Test Functions

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 20 Case Conversion Functions

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 21 #include using namespace std; int main() { cout << "Enter a character: "; char ch; cin >> ch; cout << "You entered " << ch << endl; if (islower(ch)) { cout << "It is a lowercase letter " << endl; cout (toupper(ch)) << endl; } else if (isupper(ch)) { cout << "It is an uppercase letter " << endl; cout (tolower(ch)) << endl; } else if (isdigit(ch)) { cout << "It is a digit character " << endl; } return 0;} CharacterFunctions.cpp

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 22 CharacterFunctions.cpp

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 23 Storing and Accessing Strings A pointer-based string in C++ is an array of characters ending in the null terminator ('\0'), which indicates where a string terminates in memory. An array can be accessed via a pointer. So a string can also be accessed via a pointer, which points to the first character in the string. So you can declare a string variable using an array or a pointer. For example, the following two declarations are both fine: char city[7] = "Dallas"; // Option 1 char *pCity = "Dallas"; // Option 2

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 24 Pointer Syntax char city[7] = "Dallas"; // Option 1 char *pCity = "Dallas"; // Option 2 You can access city or pCity using the array syntax or pointer syntax. For example, cout << city[1] << endl; cout << *(city + 1) << endl; cout << pCity[1] << endl; cout << *(pCity + 1) << endl; each displays character a (the second element in the string).

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 25 Reading Strings You can read a string from the keyboard using the cin object. For example, see the following code: cout << "Enter a city: "; cin >> city; // read to array city cout << "You entered " << city << endl;

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 26 Reading Strings Using getline C++ provides the cin.getline function in the iostream header file, which reads a string into an array. The syntax of the function is: cin.getline(char array[], int size, char delimitChar) The function stops reading characters when the delimiter character is encountered or when the size - 1 number of characters are read. The last character in the array is reserved for the null terminator ('\0'). If the delimiter is encountered, it is read, but not stored in the array. The third argument delimitChar has a default value ('\n').

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 27 String Functions

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 28 String Functions

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 29 #include using namespace std; int main() { char s1[20]; char s2[20] = "Dallas, Texas"; char s3[20] = "AAAAAAAAAA"; strcpy(s1, s2); strncpy(s3, s2, 6); s3[6] = '\0'; // Insert null terminator cout << "The string in s1 is " << s1 << endl; cout << "The string in s2 is " << s2 << endl; cout << "The string in s3 is " << s3 << endl; cout << "The length of string s3 is " << strlen(s3) << endl; return 0;} CopyString.cpp

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 30 #include using namespace std; int main() { char *s1 = "abcdefg"; char *s2 = "abcdg"; char *s3 = "abcdg"; cout << "strcmp(s1, s2) is " << strcmp(s1, s2) << endl; cout << "strcmp(s2, s1) is " << strcmp(s2, s1) << endl; cout << "strcmp(s2, s3) is " << strcmp(s2, s3) << endl; cout << "strncmp(s1, s2, 3) is " << strncmp(s1, s2, 3) << endl; return 0; } CompareString.cpp

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 31 #include using namespace std; int main() { char s1[20] = "Dallas"; char s2[20] = "Texas, USA"; char s3[20] = "Dallas"; strcat(strcat(s1, ", "), s2); strncat(strcat(s3, ", "), s2, 5); cout << "The string in s1 is " << s1 << endl; cout << "The string in s2 is " << s2 << endl; cout << "The string in s3 is " << s3 << endl; cout << "The length of string s1 is " << strlen(s1) << endl; cout << "The length of string s3 is " << strlen(s3) << endl; return 0; } CombineString.cpp

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 32 Checking Palindromes A string is a palindrome if it reads the same forward and backward. The words “mom,” “dad,” and “noon,” for example, are all palindromes. CheckPalindrome.cpp

Liang, Introduction to C++ Programming, (c) 2007 Pearson Education, Inc. All rights reserved X 33 # include using namespace std; // Check if a string is a palindrome bool isPalindrome(const char *); int main() { // Prompt the user to enter a string cout << "Enter a string: "; char s[80]; cin.getline(s, 80); if (isPalindrome(s)) cout << s << " is a palindrome" << endl; else cout << s << " is not a palindrome" << endl; return 0; } bool isPalindrome(const char * const s) { // The index of the first character in the string int low = 0; // The index of the last character in the string int high = strlen(s) - 1; while (low < high) { if (s[low] != s[high]) return false; // Not a palindrome low++; high--; } return true; // The string is a palindrome } bool isPalindrome(const char * const s) { // The index of the first character in the string int low = 0; // The index of the last character in the string int high = strlen(s) - 1; while (low < high) { if (s[low] != s[high]) return false; // Not a palindrome low++; high--; } return true; // The string is a palindrome }