noskipws


manipulator function
<ios>
ios_base& noskipws ( ios_base& str );

Do not skip whitespaces

Clears the skipws format flag for the str stream.

When the skipws format flag is not set, the extraction operation considers initial whitespace characters as valid content to be extracted. Tab spaces, carriage returns and blank spaces are all considered whitespaces.

This flag can be set with the skipws manipulator. When this flag is set, as many initial whitespace characters as necessary are read and discarded from the stream until a non-whitespace character is found before every extraction operation.

Notice that many extraction operations consider the whitespaces themselves as the terminating character, therfore, with the skipws flag disabled, some extraction operations may extract no characters at all from the stream.

The skipws flag is set in standard streams on initialization.

Parameters

str
Stream object where to apply.
Because this function is a manipulator, it is designed to be used alone with no arguments in conjunction with the insertion (<<) and extraction (>>) operations on streams (see example below).


Return Value

A reference to the stream object.

Example

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
// noskipws flag example
#include <iostream>
#include <sstream>
using namespace std;

int main () {
  char a, b, c;

  istringstream iss ("  123");
  iss >> noskipws >> a >> b >> c;
  cout << a << b << c << endl;

  iss.seekg(0);
  iss >> skipws >> a >> b >> c;
  cout << a << b << c << endl;
  return 0;
}


The execution of this example displays something similar to:
  1
123

Notice that in the first set of extractions, the leading spaces were extracted, while in the second they were skipped.

See also