Introduction to Java

advertisement
Introduction to Java
Java program example
/*
Introduction to OOP with Java 4th Ed, McGraw-Hill
Wu/Otani
Chapter 2 Sample Program: Displays a Window
File: Ch2Sample1.java
*/
import javax.swing.*;
class Ch2Sample1 {
public static void main(String[] args) {
JFrame myWindow;
myWindow = new JFrame();
myWindow.setSize(300, 200);
myWindow.setTitle("My First Java Program");
myWindow.setVisible(true);
}
}
Running the program
produces this result:
How it works
• Declares a class named Chapter2Sample1,
including a single method called main which
contains all of the instructions in the program
• Declares a JFrame object named myWindow
• Sends messages to the object requesting it to set
its size and title, then display the window
Line-by-line analysis
/*
Introduction to OOP with Java 4th Ed, McGraw-Hill
Wu/Otani
Chapter 2 Sample Program: Displays a Window
File: Ch2Sample1.java
*/
• The program begins with a comment – all of the
text between the /* and */ symbols is not, strictly
speaking, code – the markers indicate that the
computer can ignore this section, which contains
information strictly for the human reader – later,
we’ll look at comments in more depth
Line-by-line analysis
import javax.swing.*;
• import statement: allows the program to
use code from a package in the Java API –
in this case, we’re importing code from the
swing package, which contains class
definitions for graphical objects, like
windows
Import statements
o import statements always appear at the beginning of a
program file
o syntax: import packagename.classname;
o example of this syntax: import javax.swing.JFrame;
o this syntax indicates that we want the JFrame class, which is part
of the swing package, which is a subpackage of a larger package
called javax
o a package is simply a grouping of related Java classes – later on,
we’ll see how to create our own packages
o note the semicolon – in Java, this indicates the end of an
instruction
o the word import is a Java reserved word – that is, this is a symbol
that belongs to the Java language, and it can only be used in an
import statement
Import statements
o We can choose to import an entire package rather than a
single class – then the syntax would be import
packagename.*;
o Our program example uses this syntax – the line
import javax.swing.*;
indicates we wish to import the entire swing package
o this is more common than importing a single class
o import statements are often used when we want to incorporate code
from the Java standard classes
o it would have been possible to write this program without the
import statement, but that would have made other statements more
complicated – we’ll see how in a moment
o there are usually multiple import statements in a program
Analysis continued
• Class declaration: every Java program
consists of one or more classes
• There must be at least one main class (that
is, a class containing a main method) –
program execution starts with the first
instruction in this main method
Class declaration
• Class declaration syntax:
class classname {
class member declarations
}
• In our example program, the class declaration
looks like this:
class Ch2Sample1 {
/* main method declaration here */
}
Class declaration
class classname {
class member declarations
}
• Note the curly brackets – these indicate the
beginning (left bracket) and ending (right bracket) of a
block of code
• The contents of a class are always contained within a code
block
• The same is true for the body of a method – in fact, a
method is always a subblock within the block containing
the class
• Most programs contain additional subblocks, which are
enclosed within methods
Analysis continued
• Method declaration: a method declaration consists of
a heading and a body containing a set of instructions
to be executed to perform a task
• The general syntax for method declaration is:
modifier(s) returntype methodname (parameter(s)) {
instructions
}
Method declaration
• The main method header always looks exactly like
this:
public static void main (String [ ] args) {
– For the record, public and static are modifiers, void is
the return type, main is the name of the method, and
String[] and args are the data type and name of the
parameter, respectively
– The purpose and meaning of all of these things will
become clear during the semester – for now, just
memorize this sequence of words and symbols, you’ll
be using them a lot
Analysis continued
• Instructions: the body of main consists of a
sequence of program instructions – when the
program executes, each instruction will be
performed exactly once, in the order given
• Every instruction ends with a semicolon (;)
• Although it isn’t necessary from the computer’s
point of view that every instruction be on its own
line of code, it’s important in terms of human
readability, which is an important factor in writing
code that is easy to maintain
Instructions
• The instructions in this program include:
– an object declaration
– an object creation
– three messages
Object declaration
• Object declaration: designates the name of
an object and the class to which it belongs
– syntax: classname objectname;
– example: JFrame myWindow;
– you can declare more than one object in a
single line of code – for example, the following
code declares two JFrame objects:
JFrame window1, window2;
Object declaration
• In order to declare an object of a particular class, the class
must already be defined – in this instance, we are using
one of the standard classes from the Java API
• JFrame is a class defined in the swing package, which is
part of the javax package – the import statement we
looked at earlier made JFrame and all other swing classes
available, as you may recall
• Without the import statement, we still could have declared
a JFrame object, but instead of just the class name we
would have had to use JFrame’s fully qualified name,
which lists the package(s) it belongs to – in that case, our
declaration would have looked like this:
javax.swing.JFrame myWindow;
Object declaration
• The name of an object is an identifier chosen by
the programmer – a valid Java identifier has the
following characteristics:
• A sequence of one or more letters, digits,
underscores (_) and/or dollar signs ($) – no spaces
are allowed
• The first character must be a letter
• Java reserved words can’t be used for identifiers –
for example, you can’t name an object “import” or
“public” or “class”
Java identifiers
• Java is case-sensitive: this means the language
distinguishes between upper and lowercase
characters (therefore, although it’s not advisable,
you could create an object named “Class”)
• The Java standard naming convention adds
these additional guidelines:
– Class names start with a capital letter
– Object names start with a lowercase letter
– If an identifier contains multiple words, the first letter
of every word (except the first if the thing being named
isn’t a class) is capitalized
Analysis continued
• object creation: a declaration simply reserves a name;
to actually create an object, memory must be allocated
for storage – this operation is accomplished using the
new operator
• syntax: objectname = new
classname(argument(s));
• example: myWindow = new JFrame();
Object creation
• The object creation statement is a message to a
special method of the class called the class
constructor
• In this example, there are no arguments passed to
the constructor – we will look at arguments when
we examine messages, below
• It is possible to declare and create an object using
a single line of code, as in the example below:
JFrame myWindow = new JFrame();
Analysis continued
• Messages: a message is a request to an object (or
class) for some task to be performed – the message
specifies the name of the method requested (which
must be defined within the specified object’s class)
and any data that must be passed to the object in
order for it to accomplish the task
• Syntax:
objectname.methodname(argument(s));
Messages
• There are messages in the sample program – they
are:
myWindow.setSize(300, 200);
myWindow.setTitle("My First Java Program");
myWindow.setVisible(true);
Messages
• Each of the messages is addressed to an object named
myWindow
– the first one calls the setSize method and sends it 2 arguments
which specify the width and length of the window to be created
– the second one calls the setTitle method and passes it a single
argument in the form of the string literal “My First Java Program”
– this argument specifies the title of the window
– the third one calls the setVisible method, with the argument true –
true is a Java reserved word – this method displays the window – if
we passed the opposite argument to the method (false), the
window would disappear
Comments
• Comments: provide internal documentation for your code - we have
already seen an example of a comment – there are 3 types:
• multiline comments: this is the kind we have seen – any text enclosed
between the 2-character symbol /* and the symbol */ is considered a
comment
• single line comments: a comment that begins with the 2-character symbol
// and ends at the end of the line of text containing it – this type of
comment is often used to provide narrative explanation for code on the
same line – for example:
myWindow.setVisible(true);
// displays window
• javadoc comments: specialized type of comment that can appear before
class declarations, method declarations, and other program elements – this
type of comment is used to create external documentation in the form of
a web page– we will look at this type of comment in depth later in the
semester
Download