Presentation is loading. Please wait.

Presentation is loading. Please wait.

Copyright © 2012 Pearson Education, Inc. Chapter 1: Introduction to Computers and Programming 1.

Similar presentations


Presentation on theme: "Copyright © 2012 Pearson Education, Inc. Chapter 1: Introduction to Computers and Programming 1."— Presentation transcript:

1 Copyright © 2012 Pearson Education, Inc. Chapter 1: Introduction to Computers and Programming 1

2 Copyright © 2012 Pearson Education, Inc. A Second Chance ALL the topics and MORE Topics gradually evolve Readings and Coding Examples Checkpoint Review Questions & Exercises 2

3 Copyright © 2012 Pearson Education, Inc. 1.1 Why Program? 3

4 Copyright © 2012 Pearson Education, Inc. 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 SO, without programmers, no programs; without programs, a computer cannot do anything! 4

5 Copyright © 2012 Pearson Education, Inc. Why Program? (Contd) Page 2 5

6 Copyright © 2012 Pearson Education, Inc. 1.2 Computer Systems: Hardware and Software 6

7 Copyright © 2012 Pearson Education, Inc. Main Hardware Component Categories: 1.Central Processing Unit (CPU) 2.Main Memory 3.Secondary Memory / Storage 4.Input Devices 5.Output Devices 7

8 Copyright © 2012 Pearson Education, Inc. Main Hardware Component Categories Figure 1-2 8

9 Copyright © 2012 Pearson Education, Inc. 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 9

10 Copyright © 2012 Pearson Education, Inc. 1.3 Programs and Programming Languages 10

11 Copyright © 2012 Pearson Education, Inc. Programs and Programming Languages A program is a set of instructions that the computer follows to perform a task We start with an algorithm, which is a set of well-defined steps 11

12 Copyright © 2012 Pearson Education, Inc. Example Algorithm for Calculating Gross Pay Why can’t we just execute this on a computer using these instructions? 12

13 Copyright © 2012 Pearson Education, Inc. 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 13

14 Copyright © 2012 Pearson Education, Inc. Machine Language Machine language instructions are binary numbers, such as 1011010000000101 Rather than writing programs in machine language, programmers use programming languages 14

15 Copyright © 2012 Pearson Education, Inc. Programs and Programming Languages Types of languages: –Low-level: used for communication with computer hardware directly. Often written in binary machine code (0’s/1’s) directly –High-level: closer to human language 15

16 Copyright © 2012 Pearson Education, Inc. Some Well-Known Programming Languages BASIC FORTRAN COBOL C C++ C# Java JavaScript Python Ruby Visual Basic Why C++ for 1435? Mixes low and high level features It is portable 16

17 Copyright © 2012 Pearson Education, Inc. From a High-Level Program to an Executable File 1. Create file containing the program with a text editor (nano lab2.cpp) 2. Run preprocessor to convert source file directives to source code program statements 3. Run compiler to convert source program into machine instructions 4. Run linker to connect hardware-specific code to machine instructions, producing an executable file (a.out) Steps 2-4 are often performed by a single command or button click (g++ lab2.cpp) Errors detected at any step will prevent execution of following steps 17

18 Copyright © 2012 Pearson Education, Inc. From a High-Level Program to an Executable File 18

19 Copyright © 2012 Pearson Education, Inc. 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 19

20 Copyright © 2012 Pearson Education, Inc. Integrated Development Environments (IDEs) We won’t be using IDEs this semester –Very platform dependent…(which is annoying) –“Real” programmers learn command line (Secure Shell) programming 20

21 Copyright © 2012 Pearson Education, Inc. Integrated Development Environments (IDEs) 21

22 Copyright © 2012 Pearson Education, Inc. Appendices J Binary Numbers 22

23 Copyright © 2012 Pearson Education, Inc. 0-23 Bits and Bit Patterns Bit: Binary Digit (0 or 1) Bit Patterns are used to represent information. –Numbers –Text characters –Images –Sound –And others

24 Copyright © 2012 Pearson Education, Inc. 0-24 Boolean Operations Boolean Operation: An operation that manipulates one or more true/false values Specific operations –AND –OR –XOR (exclusive or) –NOT

25 Copyright © 2012 Pearson Education, Inc. 0-25 Boolean Operations (Contd) ANDHe is crazy AND He is a nerd => ? ORHe is crazy OR He is a nerd => ? XOREither he is crazy OR he is a nerd but not both => ? NOTNOT (He is crazy) => ?

26 Copyright © 2012 Pearson Education, Inc. 0-26 The Boolean Operations AND, OR, and XOR (exclusive or)

27 Copyright © 2012 Pearson Education, Inc. 0-27 Gates Gate: A device that computes a Boolean operation –Often implemented as (small) electronic circuits –Provide the building blocks from which computers are constructed

28 Copyright © 2012 Pearson Education, Inc. 0-28 A Pictorial Representation of AND Gate

29 Copyright © 2012 Pearson Education, Inc. 0-29 A Pictorial Representation of OR Gate

30 Copyright © 2012 Pearson Education, Inc. 0-30 A Pictorial Representation of XOR Gate

31 Copyright © 2012 Pearson Education, Inc. 0-31 A Pictorial Representation of NOT Gate

32 Copyright © 2012 Pearson Education, Inc. 0-32 A Simple Circuit

33 Copyright © 2012 Pearson Education, Inc. 0-33 The Base Ten and Base Two Systems

34 Copyright © 2012 Pearson Education, Inc. 0-34 Decoding the binary representation

35 Copyright © 2012 Pearson Education, Inc. 0-35 Algorithm for Finding the Binary Representation

36 Copyright © 2012 Pearson Education, Inc. 0-36 Applying the Algorithm to Obtain the Binary Representation

37 Copyright © 2012 Pearson Education, Inc. 0-37 The message “Hello.” in ASCII

38 Copyright © 2012 Pearson Education, Inc. Binary Representation 38

39 Copyright © 2012 Pearson Education, Inc. 1.4 What is a Program Made of? 39

40 Copyright © 2012 Pearson Education, Inc. What is a Program Made of? Common elements in programming languages: –Key Words –Programmer-Defined Identifiers –Operators –Punctuation –Syntax 40

41 Copyright © 2012 Pearson Education, Inc. Program 1-1 41

42 Copyright © 2012 Pearson Education, Inc. 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 42

43 Copyright © 2012 Pearson Education, Inc. Key Words 43

44 Copyright © 2012 Pearson Education, Inc. 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 44

45 Copyright © 2012 Pearson Education, Inc. Programmer-Defined Identifiers 45

46 Copyright © 2012 Pearson Education, Inc. Operators Used to perform operations on data Many types of operators: –Arithmetic - ex: +,-,*,/ –Assignment – ex: = Some operators in Program1-1: > = * 46

47 Copyright © 2012 Pearson Education, Inc. Operators 47

48 Copyright © 2012 Pearson Education, Inc. Punctuation Characters that mark the end of a statement, or that separate items in a list In Program 1-1:, and ; 48

49 Copyright © 2012 Pearson Education, Inc. Punctuation 49

50 Copyright © 2012 Pearson Education, Inc. 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 C++ Style Guide! 50

51 Copyright © 2012 Pearson Education, Inc. 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 51

52 Copyright © 2012 Pearson Education, Inc. Variable Definitions To create a variable in a program you must write a variable definition (also called a variable declaration) Here is the statement from Program 1-1 that defines the variables: double hours, rate, pay; 52

53 Copyright © 2012 Pearson Education, Inc. Variable Definitions There are many different types of data, which you will learn about in this course A variable holds a specific type of data The variable definition specifies the type of data a variable can hold, and the variable name 53

54 Copyright © 2012 Pearson Education, Inc. Variable Definitions Once again, line 7 from Program 1-1: double hours, rate, pay; The word double specifies that the variables can hold double-precision floating point numbers. (You will learn more about that in Chapter 2) 54

55 Copyright © 2012 Pearson Education, Inc. 1.5 Input, Processing, and Output 55

56 Copyright © 2012 Pearson Education, Inc. Input, Processing, and Output Three steps that a program typically performs: 1) Gather input data: from keyboard (cin >> hours) from files on disk drives 2) Process the input data (pay = hours * rate) 3) Display the results as output: send it to the screen (cout << “Hello world!”) write to a file 56

57 Copyright © 2012 Pearson Education, Inc. 1.6 The Programming Process 57

58 Copyright © 2012 Pearson Education, Inc. The Programming Process 58

59 Copyright © 2012 Pearson Education, Inc. 1.7 Procedural and Object-Oriented Programming 59

60 Copyright © 2012 Pearson Education, Inc. 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 60


Download ppt "Copyright © 2012 Pearson Education, Inc. Chapter 1: Introduction to Computers and Programming 1."

Similar presentations


Ads by Google