01 Slide
01 Slide
Algorithms, PsudoCode
Programs, and Java
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
1
Programs
Computer programs, known as software, are instructions to
the computer.
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
2
Designing & Documenting Programs
To understand, analyze a problem statement
and develop an algorithm to solve the problem,
we use program development techniques (flow-
charts, pseudo-code, Algorithms, etc.):
1. Structured Programming: Major steps in
structured programming include:
1. Define the problem;
2. Identify input, output, and processes;
3. Design algorithm; AND / OR Develop flowchart, pseudo-
code, etc.;
3
4. Code the program -- write the program;
5. Test the program --run it;
6. Debug the program (fix errors if any);
7. Document completed program (final pseudo-code, flowchart,
print chart, etc.).
2. Flow Charts:
1. A flow chart is defined as
a pictorial representation
describing a procedure;
1. Provides
people
(Developers,
programmers
, etc.) with a
common language or symbolic reference point;
(Use: MS Visio)
4
3. An algorithm is a formula or set of steps for solving a
particular problem;
1. A clear set of rules; and
2. Have a clear stopping point.
1. START
2. Input number1, number2
3. Sum = number1 + number2
4. Display heading message “Number1, Number2, Sum”
5. Display number1, number2, Sum
6. End
5
5. Pseudo-code:
1. An outline of a program or algorithm, written in a form that
can easily be converted into real programming statements;
2. E.g. the pseudo-code for a bubble sort routine might be
written:
• while not at end of list
• compare adjacent elements
• if second is greater than first
• switch them
• get next two elements
• if elements were switched
• repeat for entire list
6
START
READ Numer1,
Number2
SUM =
Number1+Number2
DISPLAY “ SUM,
Numer1, Number2”
DISPLAY SUM,
Numer1, Number2
END
7
5. Pseudo-code: An outline of a program or algorithm,
written in a form that can easily be converted into real
programming statements;
1. Example: The pseudo-code to add two numbers might be
written:
– Start
– Input number1, number2
– Sum = number1 + number2
– Display heading message “Number1, Number2, Sum”
– Display number1, number2, Sum
– End
2. Can not be compiled nor executed, and there are no real
formatting or syntax rules.
6. Caution: Never write your program before either
Algorithming, flowcharting or pseudo-coding it.
8
Develop a Java program to Compute the Volume
and Dimensional weight of a box?
1. Analysis:
1101101010011010
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
11
Programming Languages
Machine Language Assembly Language High-Level Language
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
12
Programming Languages
Machine Language Assembly Language High-Level Language
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
13
Interpreting/Compiling Source Code
A program written in a high-level language is called
a source program or source code. Because a
computer cannot understand a source program, a
source program must be translated into machine
code for execution. The translation can be done
using another programming tool called an
interpreter or a compiler.
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
14
Interpreting Source Code
An interpreter reads one statement from the source
code, translates it to the machine code or virtual
machine code, and then executes it right away, as
shown in the following figure. Note that a statement
from the source code may be translated into several
machine instructions.
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
15
Compiling Source Code
A compiler translates the entire source code into a
machine-code file, and the machine-code file is
then executed, as shown in the following figure.
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
16
Operating Systems
The operating system (OS) is a
program that manages and controls
a computer’s activities. The
popular operating systems for
general-purpose computers
are Microsoft Windows, Mac
OS, and Linux. Application
programs, such as a Web
browser or a word processor,
cannot run unless an
operating system is installed
and running on the computer.
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
17
Why Java?
The answer is that Java enables users to develop and deploy
applications on the Internet for servers, desktop computers, and
small hand-held devices. The future of computing is being
profoundly influenced by the Internet, and Java promises to
remain a big part of that future. Java is the Internet
programming language.
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
18
Java, Web, and Beyond
Java can be used to develop standalone
applications.
Java can be used to develop applications
running from a browser.
Java can also be used to develop applications
for hand-held devices.
Java can be used to develop applications for
Web servers.
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
19
JDK Editions
Java Standard Edition (J2SE)
– J2SE can be used to develop client-side
standalone applications or applets.
Java Enterprise Edition (J2EE)
– J2EE can be used to develop server-side
applications such as Java servlets, Java
ServerPages, and Java ServerFaces.
Java Micro Edition (J2ME).
– J2ME can be used to develop applications for
mobile devices such as cell phones.
This book uses J2SE to introduce Java
programming.
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
20
Popular Java IDEs
NetBeans
Eclipse
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
21
A Simple Java Program
Listing 1.1
// This program prints Welcome to Java!
public class Welcome {
public static void main(String[] args) {
System.out.println("Welcome to Java!");
}
}
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
22
Creating and Editing Using NotePad
To use NotePad, type
notepad Welcome.java
from the DOS prompt.
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
23
Creating and Editing Using WordPad
To use WordPad, type
write Welcome.java
from the DOS prompt.
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
24
Creating, Compiling, and
Running Programs
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
25
Compiling Java Source Code
You can port a source program to any machine with appropriate
compilers. The source program must be recompiled, however, because
the object program can only run on a specific machine. Nowadays
computers are networked to work together. Java was designed to run
object programs on any platform. With Java, you write the program
once, and compile the source program into a special type of object
code, known as bytecode. The bytecode can then run on any computer
with a Java Virtual Machine, as shown below. Java Virtual Machine is
a software that interprets Java bytecode.
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
26
animation
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
27
animation
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
28
animation
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
29
Two More Simple Examples
WelcomeWithThreeMessages Run
ComputeExpression Run
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
30
Compiling and Running Java
from TextPad
Companion
Website
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
31
Anatomy of a Java Program
Class name
Main method
Statements
Statement terminator
Reserved words
Comments
Blocks
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
32
Class Name
Every Java program must have at least one class.
Each class has a name. By convention, class names
start with an uppercase letter. In this example, the
class name is Welcome.
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
33
Main Method
Line 2 defines the main method. In order to run a
class, the class must contain a method named main.
The program is executed from the main method.
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
34
Statement
A statement represents an action or a sequence of actions.
The statement System.out.println("Welcome to Java!") in
the program in Listing 1.1 is a statement to display the
greeting "Welcome to Java!“.
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
35
Statement Terminator
Every statement in Java ends with a semicolon (;).
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
36
Reserved words
Reserved words or keywords are words that have a
specific meaning to the compiler and cannot be used for
other purposes in the program. For example, when the
compiler sees the word class, it understands that the word
after class is the name for the class.
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
37
Blocks
A pair of braces in a program forms a block that groups
components of a program.
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
38
Special Symbols
" " Opening and closing Enclosing a string (i.e., sequence of characters).
quotation marks
; Semicolon Marks the end of a statement.
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
39
{ …}
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
45
Appropriate Comments
Include a summary at the beginning of the
program to explain what the program does, its key
features, its supporting data structures, and any
unique techniques it uses.
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
46
Naming Conventions
Choose meaningful and descriptive names.
Class names:
– Capitalize the first letter of each word in the
name. For example, the class name
ComputeExpression.
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
47
Proper Indentation and Spacing
Indentation
– Indent two spaces.
Spacing
– Use blank line to separate segments of the code.
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
48
Block Styles
Use end-of-line style for braces.
End-of-line
style
public class Test {
public static void main(String[] args) {
System.out.println("Block Styles");
}
}
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
49
Programming Errors
Syntax Errors
– Detected by the compiler
Runtime Errors
– Causes the program to abort
Logic Errors
– Produces incorrect result
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
50
Syntax Errors
public class ShowSyntaxErrors {
public static main(String[] args) {
System.out.println("Welcome to Java);
}
}
ShowSyntaxErrors Run
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
51
Runtime Errors
public class ShowRuntimeErrors {
public static void main(String[] args) {
System.out.println(1 / 0);
}
}
ShowRuntimeErrors Run
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
52
Logic Errors
public class ShowLogicErrors {
public static void main(String[] args) {
System.out.println("Celsius 35 is Fahrenheit degree ");
System.out.println((9 / 5) * 35 + 32);
}
}
ShowLogicErrors Run
Liang, Introduction to Java Programming, Eleventh Edition, (c) 2017 Pearson Education, Inc. All
rights reserved.
53