1
MODULE 1
Introduction to Programming
Lesson 5:
Variable and Constants
In this lesson, you will be introduced to the fascinating world of computers. You will
learn what is a computer program, examples of computer programs, its purpose,
etc. We will also
discuss what is a
programming
language.
Learning Outcomes
At the end of this lesson, you shall be able to:
∙ define what are variables and constants;
∙ identify list of C++ keywords;
∙ explain how to properly use variables;
∙ explain how to use input in C++;
∙ appreciate the value of programming
2
LESSON PROPER
VARIABLES & CONSTANTS
Declaration and use of variables and Constants in C++ programming
This lesson will teach you how to declare and use variables in C++. A variable, or
object in C++ lingo, is used to hold data within your program. A variable represents a
location in your computer's memory. You can put data into this location and retrieve
data out of this location. Every variable has two parts, a name and a data type.
Variable Names
Valid names can consist of letters, numbers and the underscore, but may not start
with a number. A variable name may not be a C++ keyword such as if, for, else, or
while. Variable names are case sensitive. So, Age, AGE, aGE and AgE could be names
for different variables, although this is not recommended since it would probably
cause confusion and errors in your programs. Let's look at some variable
declarations to better understand these rules. Note that int, float and double are
built in C++ data types as explained latter in this lesson.
3
List of C++ Keywords
asm case const
auto catch const_cast continue
bool char default
break class delete
do long static_cast
double mutable struct
dynamic_cast else namespace switch
enum new template
explicit operator this
export private throw
true
extern protected
try
false public
typedef typeid
float register
typename union
for reinterpret_cast return
unsigned using
friend short
goto virtual
signed
if void
sizeof
inline volatile
static
int wchar_t while
4
Which of the following are valid variable names?
int idnumber;
int transaction_number;
int __my_phone_number__;
float 4myfriend;
float its4me;
double VeRyStRaNgE;
float while;
float myCash;
int CaseNo;
int CASENO;
int caseno;
Data Types
C++ also allows for user defined data types. It provides built in data types for boolean,
character, float and integer data. Boolean variables are declared with the keyword bool and
contain one of two values, true or false.
Examples:
bool myStatus = true;
bool yourStatus = false;
As an aside, in C++ you may assign a value to a variable when you declare it.
Integer variables are used to store whole numbers. There are several keywords used to declare
integer variables, including int, short, long, unsigned short, unsigned long. The difference deals
5
with the number of bytes used to store the variable in memory, long vs. short, or whether
negative and positive numbers may be stored, signed vs. unsigned. For now, use int to declare
integer variables. On most systems, int is synonymous with signed long.
Examples:
int count;
int number_of_students = 30;
Float variables are used to store floating point numbers. Floating point numbers may contain
both a whole and fractional part, for example, 52.7 or 3.33333333. There are several keywords
used to declare floating point numbers in C++ including float, double and long double. The
difference here is the number of bytes used to store the variable in memory. Double allows
larger values than float. Long double allows even larger values. For now, use float to declare
floating point variables.
Examples:
float owned = 0.0;
float owed = 1234567.89;
Character variables are used character variables. The use of characters and strings will be
covered in a latter tutorial. Character variables are declared with the keyword char.
Examples:
char firstInitial = 'J';
char secondInitial = 'K';
6
LVALUES/RVALUES
C++ has the notion of lvalues and rvalues associated with variables and constants. The rvalue is
the data value of the variable, that is, what information it contains. The "r" in rvalue can be
thought of as "read" value. A variable also has an associated lvalue. The "l" in lvalue can be
though of as location, meaning that a variable has a location that data or information can be
put into. This is contrasted with a constant. A constant has some data value, that is an rvalue.
But, it cannot be written to. It does not have an lvalue.
Another view of these terms is that objects with an rvalue, namely a variable or a constant can
appear on the right hand side of a statement. They have some data value that can be
manipulated. Only objects with an lvalue, such as variable, can appear on the left hand side of a
statement. An object must be addressable to store a value.
Here are two examples.
int x;
x = 5; // This is fine, 5 is an rvalue, x can be an lvalue.
5 = x; // This is illegal. A literal constant such as 5 is not
// addressable. It cannot be a lvalue.
Constants
A constant is similar to a variable in the sense that it represents a memory location. It differs, as
I sure you can guess, in that cannot be reassigned a new value after initialization. In general,
constants are a useful feature that can prevent program bugs and logic errors. Unintended
modifications are prevented from occurring. The compiler will catch attempts to reassign
constants new values.
Defining Constants in C++
There are three techniques used to define constants in C++. The first technique comes from the
C programming language. Constants may be defined using the preprocessor directive, #define.
The preprocessor is a program that modifies your source file prior to compilation. Common
7
preprocessor directives are #include, which is used to include additional code into your source
file, #define, which is used to define a constant and #if/#endif, which can be used to
conditionally determine which parts of your code will be compiled. The #define directive is used
as follows.
#define pi 3.1415
#define id_no 12345
Wherever the constant appears in your source file, the preprocessor replaces it by its value. So,
for instance, every "pi" in your source code will be replace by 3.1415. The compiler will only see
the value 3.1415 in your code, not "pi". The problem with this technique is that the
replacement is done lexically, without any type checking, without any bound checking and
without any scope checking. Every "pi" is just replaced by its value. The technique is outdated,
exists to support legacy code and should be avoided.
Const
The second technique is to use the keyword const when defining a variable. When used the
compiler will catch attempts to modify variables that have been declared const.
const float pi = 3.1415;
const int id_no = 12345;
There are two main advantages over the first technique. First, the type of the constant is
defined. "pi" is float. "id_no" is int. This allows some type checking by the compiler. Second,
these constants are variables with a definite scope. The scope of a variable relates to parts of
your program in which it is defined. Some variables may exist only in certain functions or in
certain blocks of code. You may want to use "id_no" in one function and a completely unrelated
"id_no" in your main program. Sorry if this is confusing, the scope of variables will be covered in
a latter lesson. I had a chicken and egg type of problem and my solution was that the chicken is
constant and the scope is an egg.
8
Enumerations
The third technique is called enumeration. An enumeration defines a new type and limits the
values of this type to a programmer defined set. For example:
enum COLOR { RED, BLUE, GREEN};
enum SHAPE {SQUARE, RECTANGLE, TRIANGLE, CIRCLE, ELLIPSE};
Each enumerated constant (sometimes called an enumerator) has an integer value. Unless
specified, the first constant has a value of zero. The values increase by one for each additional
constant in the enumeration. So, RED equals 0, BLUE equals 1, and GREEN = 2. SQUARE equals
0, RECTANGLE equals 1, TRIANGLE equals 2 and so forth. The values of each constant can also
be specified.
enum SHAPE {SQUARE=5,RECTANGLE,TRIANGLE=17,CIRCLE,ELLIPSE};
Here, SQUARE equals 5, RECTANGLE equals 6, TRIANGLE equals 17, CIRCLE equals 18 and
ELLIPSE equals 19. The advantage of enumerations is that if a variable is declared to be the type
of an enumeration, it has a type and its values are limited and checked during compiling. Try
compiling the below program. What error does it contain?
#include <iostream>
using namespace std;
int main()
{
enum color {RED, GREEN, BLUE};
color myColor = RED;
if (myColor == RED) {
cout << "hot" << endl;
9
}
if (myColor == BLUE) {
cout << "cold" << endl;
}
if (myColor == GREEN) {
cout << "Is not easy being" << endl;
}
return 0;
}
10
INPUT AND OUTPUT
An introduction to the string class
This lesson will teach you about using basic input and output in C++ and introduce the string
class. Usually i/o, input and output, form an important part of any program. To do anything
useful your program needs to be able to accept input data and report back your results. In C++,
input and output are provided by the iostream library. To use this library, add #include
<iostream> to the top of your program. This tells the preprocessor to add code from the file
iostream.h into your source file. Including this file defines and initializes the following objects
for use in your program.
cin - This object provides for input from the terminal (keyboard)
cout - This object provides for output to the screen.
cerr - This object provides unbuffered output to the standard error device, which
defaults to the screen. Unbuffered means that any messages or data will be
written immediately. With buffered input, data is saved to a buffer by the
operating system, transparently to your program. When the buffer is full,
everything in it is written out. This is more efficient because each write
requires a certain amount of overhead from the operating system. Writing out
one large buffer has less overhead than writing out multiple smaller messages.
The downside is that if a program crashes before the buffer is written, nothing
in the buffer is output. Output via cerr is unbuffered to ensure that error
messages will be written out.
clog - This object provides buffered output to the standard error device, which defaults
to the screen.
11
The best way to learn to use these objects is by example and practice.
#include <iostream>
#include <string>
using namespace std;
int main()
{
string name;
int ID;
cout << "Enter your name ";
cin >> name;
cout << "Enter your ID number ";
cin >> ID;
cout << "Hello " << name << " or should I say " << ID << endl;
return 0;
}
C++ defines a string class as part of its standard libraries. To use this class, you must include the
"string" include file in your source code. To use the string class, you must declare a string
object. The class defines what members it includes and what methods it has. Members are used
to store the data of the class. Methods provide the functionality of the class, that is, what it can
do. This will become clearer in latter lessons. For now, use the string class as in the examples .
An object is an instance of a class. Just as ID an object of data type "int", name is an object of
class "string". Try compiling and executing the above program for practice.
The input operator, >>, is used to put data into variables in your program. It is also called the
insertion operator. The output operator, <<, is used to direct output to standard output or
standard error. It is also called the extraction operator. These operators also work with other
streams including files.