C 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 '\\0' 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:```
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   
  
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 < 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 ('\\0'). 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  //For cout  
#include   //For the string functions  
  
using 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\] = '\\0';            // strcat searches for '\\0' 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 );


See also