In Addition... To the string class from the standard library accessed by #include C++ also has another library of string functions for C strings that can.

Slides:



Advertisements
Similar presentations
1 Arrays and Strings Chapter 9 2 "All students to receive arrays!" reports Dr. Austin. Declaring arrays scores :
Advertisements

 2003 Prentice Hall, Inc. All rights reserved Fundamentals of Characters and Strings Character constant –Integer value represented as character.
Strings.
1 Chapter 10 Strings and Pointers. 2 Introduction  String Constant  Example: printf(“Hello”); “Hello” : a string constant oA string constant is a series.
Lecture 20 Arrays and Strings
What is a pointer? First of all, it is a variable, just like other variables you studied So it has type, storage etc. Difference: it can only store the.
Current Assignments Homework 5 will be available tomorrow and is due on Sunday. Arrays and Pointers Project 2 due tonight by midnight. Exam 2 on Monday.
Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide 8- 1 Overview 8.1 An Array Type for Strings 8.2 The Standard string.
C Strings. The char Data Type for Storing Characters The char data type can is used to declare a variable that can hold a single character. Examples:
Chapter 10.
1 Lecture 19:String Data Type Introduction to Computer Science Spring 2006.
C-Strings A C-string (also called a character string) is a sequence of contiguous characters in memory terminated by the NUL character '\0'. C-strings.
Lecture 18:Topic: I/O Formatting and Files Dale/Weems/Headington
1 Lecture 20:Arrays and Strings Introduction to Computer Science Spring 2006.
Chapter 9: Arrays and Strings
Chapter 9: Arrays and Strings
Chapter 9: Arrays and Strings
How to Program in C++ CHAPTER 3: INPUT & OUTPUT INSTRUCTOR: MOHAMMAD MOJADDAM.
Chapter 8 Arrays and Strings
Chapter 7. 2 Objectives You should be able to describe: The string Class Character Manipulation Methods Exception Handling Input Data Validation Namespaces.
Chapter 3: Input/Output
Computer Science 210 Computer Organization Strings in C.
CHAPTER 9 ARRAYS AND STRINGS
1 Applied Arrays: Lists and Strings. 2 Chapter 13 Topics  Meaning of a List  Insertion and Deletion of List Elements  Selection Sort of List Elements.
Chapter 9 Character Strings 9.1 Character String Constants A character string constant is a sequence of characters enclosed in double quotation mark. Examples.
1 Data Structures A Data Structure is an arrangement of data in memory. A Data Structure is an arrangement of data in memory.  The purpose is to map real.
CHAPTER 3 INPUT/OUTPUT. In this chapter, you will:  Learn what a stream is and examine input and output streams  Explore how to read data from the standard.
1 Chapter 4 Program Input and the Software Design Process.
Dr. Yang, QingXiong (with slides borrowed from Dr. Yuen, Joe) LT8: Characters and Strings CS2311 Computer Programming.
Chapter 8 Arrays and Strings
1 Chapter 4 Program Input and the Software Design Process Dale/Weems/Headington.
EGR 2261 Unit 9 Strings and C-Strings  Read Malik, pages in Chapter 7, and pages in Chapter 8.  Homework #9 and Lab #9 due next week.
C++ PROGRAMMING: PROGRAM DESIGN INCLUDING DATA STRUCTURES, FIFTH EDITION Chapter 10: Strings and string type.
C++ Programming: From Problem Analysis to Program Design, Fifth Edition Arrays.
Character Arrays Based on the original work by Dr. Roger deBry Version 1.0.
CS Midterm Study Guide Fall General topics Definitions and rules Technical names of things Syntax of C++ constructs Meaning of C++ constructs.
C++ Programming: Program Design Including Data Structures, Fourth Edition Chapter 8: User-Defined Simple Data Types, Namespaces, and the string Type.
Representing Strings and String I/O. Introduction A string is a sequence of characters and is treated as a single data item. A string constant, also termed.
12/15/2015Engineering Problem Solving with C++, Second Edition, J. Ingber 1 Engineering Problem Solving with C++, Etter Chapter 6 One-Dimensional Arrays.
1 Character Strings (Cstrings) Reference: CS215 textbook pages
CSC141- Introduction to Computer programming Teacher: AHMED MUMTAZ MUSTEHSAN Lecture – 21 Thanks for Lecture Slides:
Copyright © 2002, Department of Systems and Computer Engineering, Carleton University 1 INPUT STREAMS ifstream xin; // declares an input stream.
1 Arrays and Strings Lecture: Design Problem l Consider a program to calculate class average Why?? ?
Fall 1999CS Composite Data Types. Fall 1999CS Topics to be Covered l Abstract data types l One-dimensional arrays l Two-dimensional arrays.
Chapter 15 Strings as Character Arrays
1 Chapter 13 Applied Arrays: Lists and Strings Dale/Weems/Headington.
Chapter 3: Input/Output. Objectives In this chapter, you will: – Learn what a stream is and examine input and output streams – Explore how to read data.
C++ Programming Lecture 19 Strings The Hashemite University Computer Engineering Department (Adapted from the textbook slides)
More about strings in C++. String member functions The next three slides present information about functions that are members of the C++ string class.
Prof. amr Goneid, AUC1 CSCE 110 PROGRAMMING FUNDAMENTALS WITH C++ Prof. Amr Goneid AUC Part 9. Streams & Files.
Program Input and the Software Design Process ROBERT REAVES.
Input/Output. Objectives In this chapter you will: Learn what a stream is and examine input and output streams Explore how to use the input stream functions.
A FIRST BOOK OF C++ CHAPTER 14 THE STRING CLASS AND EXCEPTION HANDLING.
1 Chapter 4 Program Input and the Software Design Process.
1 Recall that... char str [ 8 ]; str is the base address of the array. We say str is a pointer because its value is an address. It is a pointer constant.
1 Chapter 15-1 Pointers, Dynamic Data, and Reference Types Dale/Weems.
1 Pointers: Parameter Passing and Return. 2 Passing Pointers to a Function Pointers are often passed to a function as arguments  Allows data items within.
DCT1063 Programming 2 CHAPTER 3 STRINGS Mohd Nazri Bin Ibrahim Faculty of Computer, Media & Technology TATi University College
1 Applied Arrays Lists and Strings Chapter 12 2 Applying What You Learn Searching through arrays efficiently Sorting arrays Using character arrays as.
Arrays Declaring arrays Passing arrays to functions Searching arrays with linear search Sorting arrays with insertion sort Multidimensional arrays Programming.
ECE 103 Engineering Programming Chapter 29 C Strings, Part 2 Herbert G. Mayer, PSU CS Status 7/30/2014 Initial content copied verbatim from ECE 103 material.
Principles of Programming - NI Chapter 10: Character & String : In this chapter, you’ll learn about; Fundamentals of Strings and Characters The difference.
Chapter 3: Input/Output. Objectives In this chapter, you will: – Learn what a stream is and examine input and output streams – Explore how to read data.
Chapter 13 Applied Arrays: Lists and Strings
Basic Input and Output Operations
Computer Science 210 Computer Organization
String in C++ A string is an array of characters which contains a non-printing null character ‘\0’ ( with ASCII value 0 ) marking its end. A string.
Engineering Problem Solving with C++, Etter
Chapter 13 Applied Arrays: Lists and Strings
C++ Programming Lecture 20 Strings
Presentation transcript:

In Addition... To the string class from the standard library accessed by #include C++ also has another library of string functions for C strings that can be accessed by #include 1

2 What is a C String? A C string is a char array terminated by the null character ‘\0’ ( with ASCII value 0 ). A C string variable can be initialized in its declaration in two equivalent ways. char message [ 8 ] = { ‘H’, ‘e’, ‘l’, ‘l’, ‘o’, ‘\0’ }; char message [ 8 ] = “Hello” ; message [0] [1] [2] [3] [4] [5] [6] [7] ‘H’ ‘e’ ‘l’ ‘l’ ‘o’ ‘\0’

3 char vs. C string ‘A’ has data type char and is stored in 1 byte “A” is a C string of 2 characters and is stored in 2 bytes 5000 ‘A’ 6000 ‘A’ 6001 ‘\0’

4 Recall that... char message[8]; // declaration allocates memory To the compiler, the value of the identifier message alone is the base address of the array. We say message is a pointer (because its value is an address). It “points” to a memory location. message [0] [1] [2] [3] [4] [5] [6] [7] ‘H’ ‘e’ ‘l’ ‘l’ ‘o’ ‘\0’ 6000

5 Aggregate C String I/O in C++ I/O of an entire C string is possible using the array identifier with no subscripts and no looping. EXAMPLE char message [ 8 ] ; cin >> message ; cout << message ; HOWEVER...

6 Extraction operator >> When using the extraction operator ( >> ) to read input characters into a string variable, the >> operator skips any leading whitespace characters such as blanks and newlines it then reads successive characters into the array, and stops at the first trailing whitespace character (which is not consumed, but remains waiting in the input stream) the >> operator adds the null character to the end of the string

7 Example Using >> char name [ 5 ] ; cin >> name ; Suppose input stream looks like this: J o e name [0] name [1] name [2] name [3] name [4] 7000 total number of elements in the array null character is added ‘J’ ‘o’ ‘e’ ‘\0’

8 Function get( ) because the extraction operator stops reading at the first trailing whitespace, >> cannot be used to input a string with blanks in it if your string’s declared size is not large enough to hold the input characters and add the ‘\0’, the extraction operator stores characters into memory beyond the end of the array use get function with 2 parameters to overcome these obstacles EXAMPLE char message [ 8 ] ; cin.get ( message, 8 ) ; // inputs at most 7 characters plus ‘\0’

9 inFileStream.get ( str, count + 1) get does not skip leading whitespace characters such as blanks and newlines get reads successive characters (including blanks) into the array, and stops when it either has read count characters, or it reaches the newline character ‘\n’, whichever comes first get appends the null character to str if it is reached, newline is not consumed by get, but remains waiting in the input stream

10 Function ignore( ) can be used to consume any remaining characters up to and including the newline ‘\n’ left in the input stream by get EXAMPLE cin.get ( string1, 81 ) ; // inputs at most 80 characters cin.ignore ( 30, ‘\n’ ) ; // skips at most 30 characters // but stops if ‘\n’ is read cin.get ( string2, 81 ) ;

11 Another Example Using get( ) char ch ; char fullName [ 31 ] ; char address [ 31 ] ; cout << “Enter your full name: “ ; cin.get ( fullName, 31 ) ; cin.get (ch) ; // to consume the newline cout << “Enter your address: “ ; cin.get ( address, 31 ) ; fullName [0] ‘N’ ‘e’ ‘l’ ‘l’ ‘ ’ ‘D’ ‘a’ ‘l’ ‘e’ ‘\0’... address [0] ‘A’ ‘u’ ‘s’ ‘t’ ‘i‘ ‘n’ ‘ ’ ‘T’ ‘X’ ‘\0’...

12 String Function Prototypes in int strlen (char str [ ] ); // FCTNVAL == integer length of string str ( not including ‘\0’ ) int strcmp ( char str1 [ ], char str2 [ ] ); // FCTNVAL== negative, if str1 precedes str2 lexicographically //== positive, if str1 follows str2 lexicographically //== 0, if str1 and str2 characters same through ‘\0’ char * strcpy ( char toStr [ ], char fromStr [ ] ); // FCTNVAL== base address of toStr ( usually ignored ) // POSTCONDITION : characters in string fromStr are copied to //string toStr, up to and including ‘\0’, //overwriting contents of string toStr

13 # include. char author [ 21 ] ; int length ; cin.get ( author, 21 ) ; length = strlen ( author ) ; // What is the value of length ? 5000 author [0] ‘C’ ‘h’ ‘i’ ‘p’ ‘ ’ ‘W’ ‘e’ ‘e’ ‘m’ ‘s’ ‘\0’....

14 char myName [ 21 ] = “Huang” ;// WHAT IS OUTPUT? char yourName [ 21 ] ; cout << “Enter your last name : “ ; cin.get ( yourName, 21 ) ; if ( strcmp ( myName, yourName ) == 0 ) cout << “We have the same name! “ ; else if ( strcmp ( myName, yourName ) < 0 ) cout << myName << “ comes before “ << yourName ; else if ( strcmp ( myName, yourName ) > 0 ) cout << yourName << “comes before “ << myName ; myName [0] ‘H’ ‘u’ ‘a’ ‘n’ ‘g’ ‘\0’... yourName [0] ‘H’ ‘e’ ‘a’ ‘d’ ‘i‘ ‘n’ ‘ g’ ‘t’ ‘o’ ‘n’ ‘\0’...

15 char myName [ 21 ] = “Huang” ; char yourName [ 21 ] ; if ( myName == yourName ) // compares addresses only! { // That is, 4000 and 6000 here.. // DOES NOT COMPARE CONTENTS!. } myName [0] ‘H’ ‘u’ ‘a’ ‘n’ ‘g’ ‘\0’... yourName [0] ‘H’ ‘e’ ‘a’ ‘d’ ‘i‘ ‘n’ ‘ g’ ‘t’ ‘o’ ‘n’ ‘\0’

16 char myName [ 21 ] = “Huang” ; char yourName [ 21 ] ; cin.get ( yourName, 21 ) ; yourName = myName; // DOES NOT COMPILE! // What is the value of myName ? myName [0] ‘H’ ‘u’ ‘a’ ‘n’ ‘g’ ‘\0’... yourName [0] ‘H’ ‘e’ ‘a’ ‘d’ ‘i‘ ‘n’ ‘ g’ ‘t’ ‘o’ ‘n’ ‘\0’...

17 char myName [ 21 ] = “Huang” ; char yourName [ 21 ] ; cin.get ( yourName, 21 ) ; strcpy ( yourName, myName ) ; // changes string yourName // OVERWRITES CONTENTS! myName [0] ‘H’ ‘u’ ‘a’ ‘n’ ‘g’ ‘\0’... yourName [0] ‘H’ ‘e’ ‘a’ ‘d’ ‘i‘ ‘n’ ‘ g’ ‘t’ ‘o’ ‘n’ ‘\0’ ‘u’ ‘n’ ‘g’ ‘\0’

 There is a difference between 'A' and "A". The first one is character A and the second is string A.  Since strings are null terminated, "A" represents two characters, 'A' and '\0'.  "Hello" represents six characters, 'H', 'e', 'l', 'l', 'o', and '\0'.  To store 'A' we need only one memory cell of the type char, while to store "A", we need two memory cells of the type char, one for 'A' and the other for '\0'.  To store the string "HELLO" in computer we need six memory cells of the type char.  Consider the statement. char name[16];  Since C strings are null terminated and name has sixteen components, the largest string that can be stored in name is 15.  If you store a string of length, say 10 in name, the first 11 components of name are used and the last 5 are left unused.

char name[16] = {'J', 'o', 'h', 'n', '\0'};  During char array variable declaration, C++ allows the string notation to be used in the initialization statement. char name[16] = "John";//Line A The statement char name[] = "John";//Line B declares a string variable name of length large enough, that is, 5 (here) and stores "John" in it.  There is a difference between the last two statements. Both statements stores "John" in na m e.  The size of name in the statement in Line A is 16 while its size in the statement in Line B is 5.

Most of the rules that apply to other arrays also apply to character arrays. Consider the statement char studentName[26]; studentName = "Lisa L. Johnson"; //Illegal

String Comparison In C++, C-strings are compared character by character using the collating sequence of the system. Let us assume that we are using the ASCII character set. 1. The string "Air" is smaller than the string "Boat". 2. The string "Air" is smaller than the string "An". 3. The string "Bill" is smaller than the string "Billy". 4. The string "Hello" is smaller than "hello".

Example 9-7 char studentName[21]; char myname[16]; char yourname[16]; StatementEffect a. strcpy(myname,"John Robinson");myname=John Robinson b. strlen("John Robinson"); Returns 13, the length of the string c.int len; len = strlen ("Sunny Day"); Stores 9 into len d. strcpy(yourname,"Lisa Miller");yourname = Lisa Miller strcpy(studentName,yourname); studentName = Lisa Miller e. strcmp("Bill", "Lisa"); Returns a value < 0 f. strcpy(yourname, "Kathy Brown"); yourname = Kathy Brown strcpy(myname, "Mark G. Clark"); myname = Mark G. Clark strcmp(myname,yourname); Return a value > 0

Reading and Writing Strings char name[31];  String Input  Since aggregate operations are allowed for string input, the statement cin>>name; will store the next input string into name.  Strings that contain blanks cannot be read using the extraction operator >>.

 To read strings with blanks, the general form (syntax) of get function together with an input stream variable, such as cin is: cin.get(str,m+1); This statement stores the next m characters or until the newline character '\n' is found into str. The newline character is not stored in str.  If the input string has fewer than m characters, then the reading stops at the newline character.

 Consider the following statements: char str[31]; cin.get(str,31);  If the input is William T. Johnson then "William T. Johnson" will be stored in str and  If the input is Hello there. My name is Mickey Mouse. then the string "Hello there. My name is Mickey" is stored in str.

char str1[26]; char str2[26]; char discard; Input is, say Summer is warm. Winter will be cold. The following statements store line 1 in str1 and line 2 in str2. cin.get(str1,26); cin.get(discard); cin.get(str2,26);

String Output The statement cout<<name; will output the content of name on the screen.  The insertion operator << continues to write the contents of name until it finds the null character.  If name does not contain the null character, then we will see strange output since << continues to output data from memories adjacent to name until '\0' is found.

Specifying Input/Output Files at the Execution Time ifstream infile; ofstream outfile; char fileName[51]; cout<<"Enter the input file name: "; cin>>fileName; infile.open(fileName); //open the input file. cout<<"Enter the output file name: "; cin>>fileName; outfile.open(fileName); /open the output file

The string type and Input/Output Files  Values (that is, strings) of the type string are not null terminated.  Variables of type string can also be used to read and store the names of input/output files.  The argument to the function open must be a null terminated string, that is a C string.  if we use a variable of the type string to read the name of an input/output file and then use this variable to open a file, the value of the variable must (first) be converted to a C -string (that is, a null- terminated string).

 The header file string contains the function c_str, which converts a value of the type string to a null-terminated character array (that is, C -string).  The syntax to use the function c_str is strVar.c_str() where strVar is a variable of the type string.

ifstream infile; string fileName; cout<<"Enter the input file name: "; cin>>fileName; infile.open(fileName.c_str()); //open the input file