What is C++ getline() function?
The getline() function:
- Defined in the <string.h> header file
- It is used to take user input in single and multi-line settings.
- A user can enter single or multiple words.
- The characters are extracted from the input stream by getline() function. These characters are appended to the string object until the delimiter character is met. (Syntax section below will make it clearer)
- The cin object can also be used to take user input (as shown in many examples of our C++ tutorials), however, it does not allow multiple lines or words – terminates where whitespace is met.
Syntax for using getline() function in C++
There are three variations while using the getline() function.
Syntax 1:
Syntax 2:
There:
Part | Description |
is | specifies the input stream i.e. from where to read the input. |
str | After reading from the stream, the input is stored in this string object. |
delim | The getline() function stop reading further as this given delimiter is met in the input string. |
Difference:
You may notice that the only difference between the above two syntaxes is the third parameter. The first syntax contains char delim as the third parameter.
So, you may specify a delimiter of your choice. For example, dot, comma, etc.
In the case of the second syntax, you may not specify the delimiter, so the default is used as the delimiter.
Getline() function with character array
There is another syntax for using the getline() function with a character array:
This is explained with an example in the last section of this tutorial.
An example that uses getline() function (two params)
#include <iostream> #include <string> using namespace std; int main() { string str_name; cout << "What is your full name?" << endl; getline(cin, str_name); cout << "Hello and Welcome, " << str_name << "!" << endl; }
Sample output:
In the above program:
- A string variable is declared
- In the getline() function, we used two parameters.
- cin is for console input
- The entered name is displayed (try multiple words)
What if simply used cin rather getline() example
In the program below, we simply used input stream cin and displayed the value of a variable. Enter your full name and you can see the difference:
#include <iostream> #include<string.h> using namespace std; int main() { //Creating variable string str_name; std::cout << "What is your full name? " << std::endl; //Taking user input cin>>str_name; //Display variable value cout << "Hello and Welcome, " << str_name << "!" << endl; return 0; }
Sample output:
In the sample output, you can see I entered the name “Mike Millan”. However, the program only displayed the first name i.e. Mike.
This is because; C++ compiler terminates it as it finds a whitespace in the string.
This is where getline() function plays its role.
An example of using three parameters in getline() function
As mentioned earlier, you may specify a delimiter of your choice in the third parameter of the getline() function.
In this example, I used the dot (full-stop) a delimiter character in the getline(). See the code and a sample output below:
#include <iostream> #include <string> using namespace std; int main() { string str_fruits; cout << "Enter your favourite fruits?" << endl; //getline function with dot delimiter getline(cin, str_fruits,'.'); cout << "Hello and Welcome, " << str_fruits << "!" << endl; }
Sample output:
in the output, you can see that we entered three fruit names as input. As I entered a dot after banana, the string terminated and it only displayed two fruit names.
Using the comma as a delimiter example
Similarly, you may use other characters as delimiters in the getline() function. For example, a comma, semicolon, a , b, c, space, etc.
The following example uses a comma as a delimiter character:
#include <iostream> #include <string> using namespace std; int main() { string str_fruits; cout << "Enter your favourite fruits?" << endl; //getline function with dot delimiter getline(cin, str_fruits,','); cout << "My fruits are:, " << str_fruits << "!" << endl; }
Sample output:
An example of using getline() with character array
As mentioned in the section above, there is another syntax for using the getline() function with a character array. i.e.:
The following example shows a C++ program using it:
#include <iostream> #include<string.h> using namespace std; int main() { //Declaring country array char countries[50]; cout<< "Country Names: "; //Specifying array in getline() cin.getline(countries, 50); //Display entered country names cout << "\nThe country names are :"<<countries << std::endl; return 0; }
In the program:
- We declared a character array to be used in the getline() function
- In the getline() implementation (cin.getline(countries, 50);), the array is specified along with the size in integer.
- This size parameter acts as the delimiter whereas entered value cannot exceed this limit.
- If input increases the limit, the additional characters are terminated.