SOW - C++ - CSO - Chapter - 01 - 9e - Introduction To Computers and Programming
SOW - C++ - CSO - Chapter - 01 - 9e - Introduction To Computers and Programming
SOW - C++ - CSO - Chapter - 01 - 9e - Introduction To Computers and Programming
Introduction
to
Computers
and
Programming
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
1.1
Why Program?
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Why Program?
Computer – programmable machine designed
to follow instructions
Program – instructions in computer memory to
make it do something
Programmer – person who writes instructions
(programs) to make computer perform a task
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
1.2
Computer Systems: Hardware
and Software
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Main Hardware Component
Categories:
1. Central Processing Unit (CPU)
2. Main Memory
3. Secondary Memory / Storage
4. Input Devices
5. Output Devices
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Main Hardware Component
Categories
Figure 1-2
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Central Processing Unit (CPU)
Comprised of:
Control Unit
Retrieves and decodes program instructions
Coordinates activities of all other parts of computer
Arithmetic & Logic Unit
Hardware optimized for high-speed numeric
calculation
Hardware designed for true/false, yes/no decisions
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
CPU Organization
Figure 1-3
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Main Memory
It is volatile. Main memory is erased when
program terminates or computer is turned off
Also called Random Access Memory (RAM)
Organized as follows:
bit: smallest piece of memory. Has values 0 (off,
false) or 1 (on, true)
byte: 8 consecutive bits. Bytes have addresses.
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Main Memory
Addresses – Each byte in memory is
identified by a unique number known as
an address.
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Main Memory
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Secondary Storage
Non-volatile: data retained when program
is not running or computer is turned off
Comes in a variety of media:
magnetic: traditional hard drives that use a
moveable mechanical arm to read/write
solid-state: data stored in chips, no moving
parts
optical: CD-ROM, DVD
Flash drives, connected to the USB port
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Input Devices
Devices that send information to the
computer from outside
Many devices can provide input:
Keyboard, mouse, touchscreen, scanner,
digital camera, microphone
Disk drives, CD drives, and DVD drives
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Software-Programs That Run on a
Computer
Categories of software:
System software: programs that manage the
computer hardware and the programs that run
on them.
Examples: operating systems, utility programs,
software development tools
Application software: programs that provide
services to the user.
Examples : word processing, games, programs to
solve specific problems
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
1.3
Programs and Programming
Languages
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Programs and Programming
Languages
A program is a set of instructions that the
computer follows to perform a task
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Example Algorithm for Calculating
Gross Pay
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Machine Language
Although the previous algorithm defines
the steps for calculating the gross pay, it is
not ready to be executed on the computer.
The computer only executes machine
language instructions
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Machine Language
Machine language instructions are binary
numbers, such as
1011010000000101
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Programs and Programming
Languages
Types of languages:
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Some Well-Known Programming
Languages (Table 1-1 on Page 10)
C++
BASIC Ruby
FORTRAN
Java
Visual Basic
COBOL
C#
JavaScript
C Python
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
From a High-Level Program to an
Executable File
a) Create file containing the program with a text
editor.
b) Run preprocessor to convert source file
directives to source code program statements.
c) Run compiler to convert source program into
machine instructions.
d) Run linker to connect hardware-specific code to
machine instructions, producing an executable
file.
Steps b–d are often performed by a single
command or button click.
Errors detected at any step will prevent
execution of following steps.
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
From a High-Level Program to an
Executable File
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Integrated Development
Environments (IDEs)
An integrated development environment,
or IDE, combine all the tools needed to
write, compile, and debug a program into a
single software application.
Examples are Microsoft Visual C++, Turbo
C++ Explorer, CodeWarrior, etc.
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Integrated Development
Environments (IDEs)
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
1.4
What is a Program Made of?
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
What is a Program Made of?
Common elements in programming
languages:
Key Words
Programmer-Defined Identifiers
Operators
Punctuation
Syntax
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Program 1-1
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Key Words
Also known as reserved words
Have a special meaning in C++
Can not be used for any other purpose
Key words in the Program 1-1: using,
namespace, int, double, and return
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Key Words
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Programmer-Defined Identifiers
Names made up by the programmer
Not part of the C++ language
Used to represent various things: variables
(memory locations), functions, etc.
In Program 1-1: hours, rate, and pay.
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Operators
Used to perform operations on data
Many types of operators:
Arithmetic - ex: +,-,*,/
Assignment – ex: =
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Operators
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Punctuation
Characters that mark the end of a
statement, or that separate items in a list
In Program 1-1: , and ;
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Punctuation
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Syntax
The rules of grammar that must be
followed when writing a program
Controls the use of key words, operators,
programmer-defined symbols, and
punctuation
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Variables
A variable is a named storage location in
the computer’s memory for holding a piece
of data.
In Program 1-1 we used three variables:
The hours variable was used to hold the
hours worked
The rate variable was used to hold the pay
rate
The pay variable was used to hold the gross
pay
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Variable Definitions
To create a variable in a program you
must write a variable definition (also called
a variable declaration)
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Variable Definitions
There are many different types of data,
which you will learn about in this course.
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Variable Definitions
Once again, line 7 from Program 1-1:
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
1.5
Input, Processing, and Output
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Input, Processing, and Output
Three steps that a program typically
performs:
1) Gather input data:
from keyboard
from files on disk drives
2) Process the input data
3) Display the results as output:
send it to the screen
write to a file
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
1.6
The Programming Process
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
The Programming Process
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
1.7
Procedural and Object-Oriented
Programming
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.
Procedural and Object-Oriented
Programming
Procedural programming: focus is on the
process. Procedures/functions are written
to process data.
Object-Oriented programming: focus is on
objects, which contain data and the means
to manipulate the data. Messages sent to
objects to perform operations.
Copyright © 2018, 2015, 2012, 2009 Pearson Education, Inc., All rights reserved.