1.11. Identifiers, Types, and Literals

[ fromfile: cppintro.xml id: idliterals ]

Identifiers are names that are used in C++ programs for functions, parameters, variables, constants, classes, and types.

An identifier consists of a sequence of letters, digits, and underscores that does not begin with a digit. An identifier cannot be a reserved keyword. See Appendix A for a list of them. The standard does not specify a limit to the length of an identifier, but certain implementations of C++ only examine the first 31 characters to distinguish between identifiers.

A literal is a constant value that appears somewhere in a program. Since every value has a type, every literal has a type also. It is possible to have literals of each of the native data types, and also character string literals. Table 1.1 shows some examples of literals and their types.

Table 1.1.  Examples of Literals

Literal Meaning
5an int literal
5u u or U specifies unsigned int
5L l or L specifies long int after an integer
05 an octal int literal
0x5 a hexadecimal int literal
true a bool literal
5.0Ff or F specifies single precision floating point literal
5.0 a double precision floating point literal
5.0L l or L specifies long double if it comes after a floating point
'5' a char literal (ASCII 53)
“50” a const char* containing the chars '5' '0' and '\0'
“any” “body” “anybody”
'\a' alert
'\\' backslash
'\b' backspace
'\r' carriage return
'\'' single quote
'\“' double quote
'\f' formfeed (newpage)
'\t' tab
'\n' newline char literal
“\n”newline followed by null terminator (const char*)
'\0' null character
'\v' vertical tab
“a string with newline\n” another const char*

String literals are special in C++, due to its historical roots in the C language. Example 1.14 shows how certain characters need to be escaped inside double-quoted string delimiters.

Example 1.14. src/early-examples/literals/qliterals.cpp

#include <QTextStream>
#include <QString>

int main() {
    const char* charstr = "this is one very long string "
                " so I will continue it on the next line";
    QTextStream cout(stdout);  
    QString str = charstr; 1
    cout << str << endl;
    cout << "\nA\tb\\c\'d\"" << endl;
    return 0;
}

1

c-style strings can be converted to QString

We compile and run the way we described earlier:

src/early-examples/literals> qmake -project
src/early-examples/literals> qmake
src/early-examples/literals> make
g++ -c -pipe -O2 -Wall -W -D_REENTRANT -DQT_NO_DEBUG -DQT_GUI_LIB
  -DQT_CORE_LIB -DQT_SHARED -I/usr/share/qt4/mkspecs/linux-g++ -I.
  -I/usr/include/qt4/QtCore -I/usr/include/qt4/QtCore
  -I/usr/include/qt4/QtGui -I/usr/include/qt4/QtGui
  -I/usr/include/qt4 -I. -I. -I. -o qliterals.o qliterals.cpp
g++  -o literals qliterals.o  -L/usr/lib -lQtGui -lQtCore -lpthread
src/early-examples/literals> ./literals

The output should look something like this:

this is one very long string  so I will continue it on the next line

A       b\c'd"

Notice that this program shows a way to avoid very long lines when dealing with string literals. They can be broken at any white space character and are concatenated automatically using this syntax.