Jump to content
xisto Community
Sign in to follow this  
Blackbelt012

C Strings [c++]

Recommended Posts

This tutorial was not made by me and I take no credit what so ever.

 

Site Found From: http://www.cprogramming.com/

C StringsIn C++ there are two types of strings, C-style strings, and C++-style strings. This lesson will discuss C-style strings. C-style strings are really arrays, but there are some different functions that are used for strings, like adding to strings, finding the length of strings, and also of checking to see if strings match. The definition of a string would be anything that contains more than one character strung together. For example, "This" is a string. However, single characters will not be strings, though they can be used as strings.

 

Strings are arrays of chars. String literals are words surrounded by double quotation marks.

 

"This is a static string"

To declare a string of 49 letters, you would want to say:

 

char string[50];

This would declare a string with a length of 50 characters. Do not forget that arrays begin at zero, not 1 for the index number. In addition, a string ends with a null character, literally a '\' character. However, just remember that there will be an extra character on the end on a string. It is like a period at the end of a sentence, it is not counted as a letter, but it still takes up a space. Technically, in a fifty char array you could only hold 49 letters and one null character at the end to terminate the string.

 

TAKE NOTE: char *arry; Can also be used as a string. If you have read the tutorial on pointers, you can do something such as:

 

arry = new char[256];

which allows you to access arry just as if it were an array. Keep in mind that to use delete you must put [] between delete and arry to tell it to free all 256 bytes of memory allocated.

 

For example:

 

delete [] arry.

Strings are useful for holding all types of long input. If you want the user to input his or her name, you must use a string. Using cin>> to input a string works, but it will terminate the string after it reads the first space. The best way to handle this situation is to use the function cin.getline. Technically cin is a class (a beast similar to a structure), and you are calling one of its member functions. The most important thing is to understand how to use the function however.

 

The prototype for that function is:Strings are useful for holding all types of long input. If you want the user to input his or her name, you must use a string. Using cin>> to input a string works, but it will terminate the string after it reads the first space. The best way to handle this situation is to use the function cin.getline. Technically cin is a class (a beast similar to a structure), and you are calling one of its member functions. The most important thing is to understand how to use the function however.

 

The prototype for that function is:

 

istream& getline(char *buffer, int length, char terminal_char);

The char *buffer is a pointer to the first element of the character array, so that it can actually be used to access the array. The int length is simply how long the string to be input can be at its maximum (how big the array is). The char terminal_char means that the string will terminate if the user inputs whatever that character is. Keep in mind that it will discard whatever the terminal character is.

 

It is possible to make a function call of cin.getline(arry, 50); without the terminal character. Note that '\n' is the way of actually telling the compiler you mean a new line, i.e. someone hitting the enter key.

 

For a example:

 

#include <iostream>using namespace std;int main(){  char string[256];							   // A nice long string  cout<<"Please enter a long string: ";  cin.getline ( string, 256, '\n' );			  // Input goes into string  cout<<"Your long string was: "<< string <<endl;  cin.get();}

Remember that you are actually passing the address of the array when you pass string because arrays do not require an address operator (&) to be used to pass their address. Other than that, you could make '\n' any character you want (make sure to enclose it with single quotes to inform the compiler of its character status) to have the getline terminate on that character.

 

cstring is a header file that contains many functions for manipulating strings. One of these is the string comparison function.

 

int strcmp ( const char *s1, const char *s2 );

strcmp will accept two strings. It will return an integer. This integer will either be:

 

Negative if s1 is less than s2.Zero if s1 and s2 are equal.Positive if s1 is greater than s2.

Strcmp is case sensitive. Strcmp also passes the address of the character array to the function to allow it to be accessed.

 

char *strcat ( char *dest, const char *src );

strcat is short for string concatenate, which means to add to the end, or append. It adds the second string to the first string. It returns a pointer to the concatenated string. Beware this function, it assumes that dest is large enough to hold the entire contents of src as well as its own contents.

 

char *strcpy ( char *dest, const char *src );

strcpy is short for string copy, which means it copies the entire contents of src into dest. The contents of dest after strcpy will be exactly the same as src such that strcmp ( dest, src ) will return 0.

 

size_t strlen ( const char *s );

strlen will return the length of a string, minus the termating character ('\'). The size_t is nothing to worry about. Just treat it as an integer that cannot be negative, which it is.

 

Here is a small program using many of the previously described functions:

 

#include <iostream> //For cout#include <cstring>  //For the string functionsusing namespace std;int main(){  char name[50];  char lastname[50];  char fullname[100]; // Big enough to hold both name and lastname    cout<<"Please enter your name: ";  cin.getline ( name, 50 );  if ( strcmp ( name, "Julienne" ) == 0 ) // Equal strings	cout<<"That's my name too.\n";  else									// Not equal	cout<<"That's not my name.\n";  // Find the length of your name  cout<<"Your name is "<< strlen ( name ) <<" letters long\n";  cout<<"Enter your last name: ";  cin.getline ( lastname, 50 );  fullname[0] = '\';			// strcat searches for '\' to cat after  strcat ( fullname, name );	 // Copy name into full name  strcat ( fullname, " " );	  // We want to separate the names by a space  strcat ( fullname, lastname ); // Copy lastname onto the end of fullname  cout<<"Your full name is "<< fullname <<"\n";  cin.get();}

Safe Programming

 

The above string functions all rely on the existence of a null terminator at the end of a string. This isn't always a safe bet. Moreover, some of them, noticeably strcat, rely on the fact that the destination string can hold the entire string being appended onto the end. Although it might seem like you'll never make that sort of mistake, historically, problems based on accidentally writing off the end of an array in a function like strcat, have been a major problem.

 

Fortunately, in their infinite wisdom, the designers of C have included functions designed to help you avoid these issues. Similar to the way that fgets takes the maximum number of characters that fit into the buffer, there are string functions that take an additional argument to indicate the length of the destination buffer. For instance, the strcpy function has an analogous strncpy function

 

char *strncpy ( char *dest, const char *src, size_t len );

which will only copy len bytes from src to dest (len should be less than the size of dest or the write could still go beyond the bounds of the array). Unfortunately, strncpy can lead to one niggling issue: it doesn't guarantee that dest will have a null terminator attached to it (this might happen if the string src is longer than dest). You can avoid this problem by using strlen to get the length of src and make sure it will fit in dest. Of course, if you were going to do that, then you probably don't need strncpy in the first place, right? Wrong. Now it forces you to pay attention to this issue, which is a big part of the battle.

Edited by Blackbelt012 (see edit history)

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
Sign in to follow this  

×
×
  • Create New...

Important Information

Terms of Use | Privacy Policy | Guidelines | We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.