JAVA Module 1
JAVA Module 1
An Overview of Java
Encapsulation:
Encapsulation is the mechanism that binds together code and data it manipulates,
and keeps both safe from outside interference and misuse.
In Java the basis of encapsulation is the class. A class defines the state and behavior
(data & code) that will be shared by set of objects.
Each object contains the structure and behavior defined by the class. The data
defined by the class are called instance variables (member variables), the code that
operates on that data are called methods (member functions).
Inheritance:
Inheritance is the process by which one object acquires the properties of another
object. This is important as it supports the concept of hierarchical classification.
By the use of inheritance, a class has to define only those qualities that make it
unique. The general qualities can be derived from the parent class or base class.
Ex: A child inheriting properties from parents.
Polymorphism
Polymorphism (meaning many forms) is a feature that allows one interface to be
used for a general class of actions. The specific action determined by the exact
nature of the situation. This concept is often expressed as ― one interface, multiple
methods‖.
Ex: + can be used for addition of 2 numbers and also concatenation of 2 strings.
System.out.println(2+4); // outputs 6 as answer
System.out.println(Hello + Gautham); // outputs Hello Gautham as answer Apart
from this the additional features include:
Object:
An object can be any real world entity.
Ex: an animal, bank, human, box, fan etc
An object is a software bundle of related state and behavior.
An object is an instance of class.
Class:
A class is a blueprint or prototype from which objects are created.
Its just a template for an object, which describes an object.
Ex: a class describes how an animal looks like.
A class is a user defined data type.
Abstraction:
Data abstraction refers to providing only essential information to the outside world
and hiding their background details i.e., to represent the needed informatin in
program without presenting the details.
Ex: a database system hides certain details of how data is stored and created and
maintained.
2. Save the above program with .java extension, here file name and class name
should be same,
ex: Example.java
3. Open the command prompt and Compile the above program
javac Example.java
From the above compilation the java compiler produces a bytecode (.class file)
4. Finally run the program through the
interpreter java Example.java
Note:
In Java all code must reside inside a class and name of that class should match the
name of the file that holds the program.
Java is case-sensitive
Description:
(1) Class declaration: ―class Example‖ declares a class, which is an object- oriented
construct. Sampleone is a Java identifier that specifies the name of the class to be
defined.
(2) Opening braces: Every class definition of Java starts with opening braces and ends
The statement System.out.println(― the value of n is ―+n), the sign + causes the value of
―n‖ to be appended to the string that precedes it, and the resulting string is output. (Actually
n is first converted from an integer into its string equivalent and the concatenated with the
string that precedes it).
The System.out.print( ) method is just like println( ) except that it does not output a newline
character after each call.
if statement
The if- statement is the most basic of all the control flow statements. It tells your
program to execute a certain section of code only if a particular test evaluates
to true.
Here is the general form of the if statement:
if (condition) statement;
Here the condition is Boolean expression.
If the condition is true then the statement is executed, if false then statement will be
skipped.
Example:
class Example
{
public static void main(String args[])
{
int a=10;
if(a>0)
System.out.println(―a is positive number‖);
System.out.println(― End of program‖);
}
In the above program since a is greater than 0 it prints the output asa is positive number.
If incase a is -1 or negative value the condition fails and it prints onlyEnd of program
Output:
0
1
2
3
4
End of program
Lexical issues:
Java programs are a collection of whitespace, identifiers, literals, comments, operators,
separators, and keywords.
Whitespace:
Java is a free from language- means no need to follow any indentation rules.
Whitespace is a space, tab, or newline.
Java character set:
The smallest unit of Java language is its character set used to write Java tokens. This
character is defined by unicode character set that tries to create character for a large
number of characters worldwide.
The Unicode is a 16-bit character coding system and currently supports 34,000
defined characters derived from 24 languages of worldwide.
Key Words:
Java program is basically a collection of classes. A class is defined by a set of declaration
statements and methods containing executable statements. Most statement contains an
expression that contains the action carried out on data. The compiler recognizes the tokens
for building up the expression and statements. Smallest individual units of programs are
known as tokens. Java language includes five types of tokens. They are
(a) Reserved Keyword
(b) Identifiers
(c) Literals.
(d) Operators
(e) Separators.
Reserved keyword:
Java language has 61 words as reserved keywords. They implement specific feature of the
language. The keywords combined with operators and separators according to syntax build
the Java language.
Identifiers:
Identifiers are programmer-designed token used for naming classes methods variable,
objects, labels etc. The rules for identifiers are
1. They can have alphabets, digits, dollar sign and underscores.
2. They must not begin with digit.
3. Uppercase and lower case letters are distinct.
4. They can be any lengths.
Literals:
Literals in Java are sequence of characters that represents constant values to be stored in
variables. Java language specifies five major types of Literals. They are:
1. Integer Literals. Ex: 100
2. Floating-point Literals. Ex: 98.6
3. Character Literals. Ex: ‗X‘
4. String Literals. Ex: ―This is a Test‖
5. Boolean Literals. Ex: true or false
Operators:
An operator is a symbol that takes one or more arguments and operates on them to produce
an result.
Separators:
Separators are the symbols that indicate where group of code are divided and arranged.
Some of the operators are:
Comments:
Java supports 3 styles of comments
Multiline comment: this type of comment begins with /* and ends with */
Ex: /* Welcome to
Java Programming */
Single line comments: this type of comment begins with // and ends at the end of
current line
Ex: // Welcome to java Programming
Documentation Comment: this type of comment is used to produce an HTML file
that documents your program. The documentation comment begins with /** and
ends with */
Data types
The various data types supported in java is as follows:
Java defines eight primitive types of data: byte, short, int, long, char, float, double, and
boolean. As shown in above figure.
The primitive types represent single values—not complex objects. Although Java is
otherwise completely object-oriented, the primitive types are not.
They are analogous to the simple types found in most other non–object-oriented
languages.
The reason for this is efficiency. Making the primitive types into objects would have
degraded performance too much. The primitive types are defined to have an explicit
range and mathematical behavior.
Because of Java‗s portability requirement, all data types have a strictly defined range.
For example, an int is always 32 bits, regardless of the particular platform.
Integers
Java defines four integer types: byte, short, int, and long.
All of these are signed, positive and negative values. Java does not support unsigned,
positive-only integers.
Many other computer languages support both signed and unsigned integers.
However, Java‗s designers felt that unsigned integers were unnecessary. Specifically,
they felt that the concept of unsigned was used mostly to specify the behavior of
the high-order bit, which defines the sign of an integer value.
byte
The smallest integer type is byte.
This is a signed 8-bit type that has a range from –128 to127.
Variables of type byte are especially useful when you‗re working with a stream of
data from a network or file.
Byte variables are declared by use of the byte keyword.
For example, the following declares two byte variables called b and c: byte b, c;
short
short is a signed 16-bit type.
It has a range from –32,768 to 32,767.
It is probably the least-used Java type.
Floating-point numbers, also known as real numbers, are used when evaluating
expressions that require fractional precision.
For example, calculations such as square root, or transcendental such as sine and
cosine, result in a value whose precision requires a floating-point type.
There are two kinds of floating-point types, float and double, which represent
single- and double-precision numbers, respectively.
float
The type float specifies a single-precision value that uses 32 bits of storage.
Ex: float hightemp;
double
Double precision, as denoted by the double keyword, uses 64 bits to store a value.
Double precision is actually faster than single precision on some modern processors
that have been optimized for high-speed mathematical calculations.
Characters
In Java, the data type used to store characters is char.
However, C/C++ programmers beware: char in Java is not the same as char in C or
C++.
In C/C++, char is 8 bits wide. This is not the case in Java. Instead, Java uses Unicode
Dept. of ISE, GSSSIETW, Mysuru.
Object Oriented Programming with Java BCS306A
to represent characters.
Unicode defines a fully international character set that can represent all of the
characters found in all human languages.
It is a unification of dozens of character sets, such as Latin, Greek
Arabic, Cyrillic,Hebrew, Katakana, Hangul, and many more. For this purpose, it
requires 16 bits.
Thus, in Java char is a 16-bit type. The range of a char is 0 to 65,536. There are no
negative.
Booleans:
Java has a simple type called boolean for logical values. It can have only one of two possible
values. They are true or false.
Literals:
A constant value in Java is created by using a literal representation of it. There are 5 types of
literals.
Integer Literals.
Floating-point Literals.
Character Literals.
String Literals.
Boolean Literals.
Integer literals:
Any whole number value is an integer literal.
These are all decimal values describing a base 10 number.
There are two other bases which can be used in integer literal, octal( base 8) where 0
is prefixed with the value, hexadecimal (base 16) where 0X or 0x is prefixed with the
integer value.
Example:
int decimal = 100;
int octal = 0144;
int hexa = 0x64;
Example:
0.0314 *10² (i.e 3.14).
6.5E+32 (or 6.5E32) Double-precision floating-point literal
7D Double-precision floating-point literal
.01f Floating-point literal
Character literals:
char data type is a single 16-bit Unicode character.
We can specify a character literal as a single printable character in a pair of single
quote characters such as 'a', '#', and '3'.
You must know about the ASCII character set. The ASCII character set includes 128
characters including letters, numerals, punctuation etc.
Below table shows a set of these special characters.
Boolean Literals:
The values true and false are treated as literals in Java programming.
When we assign a value to a boolean variable, we can only use these two values.
Unlike C, we can't presume that the value of 1 is equivalent to true and 0 is equivalent
to false in Java.
We have to use the values true and false to represent a Boolean value.
Example
boolean chosen = true;
String Literal
The set of characters in represented as String literals in Java.
Always use "double quotes" for String literals.
There are few methods provided in Java to combine strings, modify strings and to
know whether to strings have the same values.
Example:
―hello world‖
―Java‖
Variables:
A variable is an identifier that denotes a storage location used to store a data value. A
variable may have different value in the different phase of the program. To declare one
identifier as a variable there are certain rules. They are:
1. They must not begin with a digit.
2. Uppercase and lowercase are distinct.
3. It should not be a keyword.
4. White space is not allowed.
Dynamic initialization:
Java allows variables to be initialized dynamically, using expression valid at the time
variable is declared.
Example:
class Example
{
public static void main(String args[])
{
double a=10, b=2.6;
double c=a/b;
System.out.println(―value of c is‖+c);
}
}
scope, you are localizing that variable and protecting it from unauthorized access
and/or modification.
class Scope
{
public static void main(String args[])
{
int x; // known to all code within main x = 10;
if(x == 10) // start new scope
{
int y = 20; // known only to this block
// x and y both known here.
System.out.println("x and y: " + x + " " + y); x = y * 2;
}
// y = 100; // Error! y not known here
// x is still known here. System.out.println("x is " + x);
}
}
Note:
There should not be two variables with the same name in different scope.
The variable at outer scope can be accessed in inner scope but vice versa is not
Dept. of ISE, GSSSIETW, Mysuru.
Object Oriented Programming with Java BCS306A
possible.
Example :
}
}
Output :
Double value 100.04
Long value 100
Int value 100
an expression.
byte b = 50;
b = b * 2; // Error! Cannot assign an int to a byte!
The operands were automatically promoted to int when the expression was evaluated,
theresult has also been promoted to int. Thus, the result of the expression is now of type
int,which cannot be assigned to a byte without the use of a cast.
byte b = 50;
b = (byte)(b * 2); which yields the correct value of 100.
Java defines several type promotion rules that apply to expressions. They are as follows:
First, all byte, short, and char values are promoted to int, as just described.
Then, if one operand is a long, the whole expression is promoted to long.
If one operand is a float, the entire expression is promoted to float.
If any of the operands is double, the result is double.
Arrays in Java
Array, which stores a fixed-size sequential collection of elements of the same
type. An array is used to store a collection of data, but it is often more useful to think of
an array as a collection of variables of the same type.
Example:
Creating Arrays:
You can create an array by using the new operator with the following syntax:
Declaring an array variable, creating an array, and assigning the reference of the array to
the variable can be combined in one statement, as shown below:
Example:
Following picture represents array myList. Here, myList holds ten double values and
the indices are from 0 to 9.
Processing Arrays:
When processing array elements, we often use either for loop or foreach loop because all
of the elements in an array are of the same type and the size of the array is known.
Example:
Here is a complete example of showing how to create, initialize and process arrays:
class TestArray
{
public static void main(String[] args)
{
double[] myList = {1.9, 2.9, 3.4, 3.5};
Multidimensional Arrays
Java does not support multidimensional arrays. However, you can declare and create an array
of arrays (and those arrays can contain arrays, and so on, for however many dimensions you
need), and access them as you would C-style multidimensional arrays:
int coords[] [] = new int[12] [12];
coords[0] [0] = 1; coords[0] [1] = 2;
It is possible to let the compiler infer the type of a local variable based on the type of its
initialize. Thus avoiding the need to explicitly specify the type.
To support local variable type inference the context sensitive identifier var was added to
java as a reserved type name.
To use local variable type inference, the variable must be declared with var as the type
name and it must include an initialize. Ex: double avg=10.0;
Using type inference this declaration can be written as var avg=10.0;
In both the cases, avg will be of type. In the first case, its type is explicitly specified. In
the second, its type is inferred as double because the initialize 10.0 is of type double.
var is simply a user defined identifier with no special meaning. Ex: int var = 1; is still
valid.
var cannot be used as the name of a class, other reference types like interface,
enumeration or annotation or as the name of a generic type parameter.
Some var Restrictions:
o Only one variable can be declared at a time.
o A variable cannot use null as an initialize.
o The variable being declared cannot be used by the initialize expression.
o Var cannot be used with array initialize.
o For Ex: var myArray = new int[10]; // This is valid.
o Var myArray = {1,2,3}; // This is not valid.
Programs:
// Compute distance light travels using long variables.
class Light
{
public static void main(String args[])
{
int lightspeed;
long days;
long seconds;
long distance; // approximate speed of light in miles per second
lightspeed = 186000;
days = 1000; // specify number of days here
seconds = days * 24 * 60 * 60; // convert to seconds
distance = lightspeed * seconds; // compute distance
System.out.print("In " + days);
System.out.print(" days light will travel about ");
System.out.println(distance + " miles.");
}
}
This program generates the following output:
In 1000 days light will travel about 16070400000000 miles.
b = false;
System.out.println("b is " + b);
b = true;
System.out.println("b is " + b); // a boolean value can control the if statement
if(b)
System.out.println("This is executed.");
b = false;
if(b)
System.out.println("This is not executed.");
System.out.println("10 > 9 is " + (10 > 9));
}
}
The output generated by this program is shown here:
b is false
b is true
This is executed.
10 > 9 is true
Scope of variable
class LifeTime
{
public static void main(String args[])
{
int x;
for(x = 0; x < 3; x++)
{
int y = -1; // y is initialized each time block is entered
System.out.println("y is: " + y); // this always prints -1
y = 100;
System.out.println("y is now: " + y);
}
}
}
The output generated by this program is shown here:
y is: -1
y is now: 100
y is: -1
y is now: 100
y is: -1
y is now: 100
Type conversion
class Conversion
{
public static void main(String args[])
{
byte b;
int i = 257;
double d = 323.142;
System.out.println("\nConversion of int to byte.");
b = (byte) i;
System.out.println("i and b " + i + " " + b);
System.out.println("\nConversion of double to int.");
i = (int) d;
System.out.println("d and i " + d + " " + i);
System.out.println("\nConversion of double to byte.");
b = (byte) d; System.out.println("d and b " + d + " " + b);
}
}
This program generates the following output:
Conversion of int to byte.
i and b 257 1
Conversion of double to int.
d and i 323.142 323
Conversion of double to byte.
d and b 323.142 67
Operators
Arithmetic Operators:
Arithmetic operators are used in mathematical expressions in the same way that they are used
in algebra. The following table lists the arithmetic operators:
The operands of the arithmetic operators must be of a numeric type. You cannot use them on
boolean types, but you can use them on char types, since the char type in Java is, essentially,
a subset of int. The following simple example program demonstrates the arithmetic operators:
x mod 10 = 2
y mod 10 = 2.25
The compound assignment operators provide two benefits. First, they save you a bit of typing,
because they are ―shorthand‖ for their equivalent long forms. Second, they are implemented
more efficiently by the Java run-time system than are their equivalent long forms.
// Demonstrate several assignment operators.
class OpEquals {
public static void main(String args[]) {
int a = 1;
int b = 2;
int c = 3;
a += 5;
b *= 4;
c += a * b;
c %= 6;
System.out.println("a = " + a);
System.out.println("b = " + b);
System.out.println("c = " + c);
Dept. of ISE, GSSSIETW, Mysuru.
Object Oriented Programming with Java BCS306A
}
}
The output of this program is shown here:
a = 6
b = 8
c = 3
The Bitwise OR
The OR operator, |, combines bits such that if either of the bits in the operands is a 1, then the
resultant bit is a 1, as shown here:
00101010 42
| 00001111 15
00101111 47
Relational Operators
The relational operators determine the relationship that one operand has to the other.
Specifically, they determine equality and ordering. The outcome of these operations is a
boolean value. The relational operators are most frequently used in the expressions that control
the if statement and the various loop statements.
Here is a program that is almost the same as the BitLogic example shown earlier, but it operates
on boolean logical values instead of binary bits:
Output:
The ? Operator
Java includes a special ternary (three-way) operator that can replace certain types of if-then-
else statements. The ? has this general form:
expression1 ? expression2 : expression3
Here, expression1 can be any expression that evaluates to a boolean value. If expression1 is
true, then expression2 is evaluated; otherwise, expression3 is evaluated. The result of the ?
operation is that of the expression evaluated. Both expression2 and expression3 are required
to return the same type, which can‘t be void.
Here is an example of the way that the ? is employed:
ratio = denom == 0 ? 0 : num / denom;
When Java evaluates this assignment expression, it first looks at the expression to the left of the
question mark. If denom equals zero, then the expression between the question mark and the
colon is evaluated and used as the value of the entire ? expression. If denom does not equal
zero, then the expression after the colon is evaluated and used for the value of the entire ?
expression. The result produced by the ? operator is then assigned to ratio.
Here is a program that demonstrates the ? operator. It uses it to obtain the absolute value of a
variable.
// Demonstrate ?.
class Ternary {
public static void main(String args[]) {
int i, k;
i = 10;
k = i < 0 ? -i : i; // get absolute value of i
System.out.print("Absolute value of ");
System.out.println(i + " is " + k);
i = -10;
k = i < 0 ? -i : i; // get absolute value of i
System.out.print("Absolute value of ");
System.out.println(i + " is " + k);
}
}
The output generated by the program is shown here:
Absolute value of 10 is 10
Absolute value of -10 is 10
Using Parentheses
Parentheses raise the precedence of the operations that are inside them. This is often necessary
to obtain the result you desire. For example, consider the following expression:
a >> b + 3
This expression first adds 3 to b and then shifts a right by that result. That is, this expression
can be rewritten using redundant parentheses like this:
a >> (b + 3)
However, if you want to first shift a right by b positions and then add 3 to that result, you will
need to parenthesize the expression like this:
(a >> b) + 3
Operator Precedence
Control Statements
Java’s program control statements can be put into the following categories: selection,
iteration, and jump.
Selection statements allow your program to choose different paths of execution based
upon the outcome of an expression or the state of a variable.
Iteration statements enable program execution to repeat one or more statements (that
is, iteration statements form loops).
Jump statements allow your program to execute in a nonlinear fashion.
The if statement
The if statement executes a block of code only if the specified expression is true.
If the value is false, then the if block is skipped and execution continues with the rest
of the program.
You can either have a single statement or a block of code within an if statement.
Note that the conditional expression must be a Boolean expression.
Syntax:
if (<conditional expression>) {
<statements>
}
Example:
public class Example {
public static void main(String[] args) {
int a = 10, b = 20;
if (a > b)
System.out.println("a > b");
if (a < b)
Syntax:
if (condition)
statement1;
else statement2;
Nested ifs
A nested if is an if statement that is the target of another if or else.
When you nest ifs, the main thing to remember is that an else statement always refers
to the nearest if statement that is within the same block as the else and that is not
already associated with an else.
Here is an example:
if(i == 10) {
if(j < 20) a = b;
if(k > 100) c = d; // this if is
else a = c; // associated with this else
}
else a = d; // this else refers to if(i == 10)
if(condition)
statement;
else if(condition)
statement;
else if(condition)
statement;
...
else
statement;
Example:
class IfElse {
public static void main(String args[]) {
int month = 4; // April
String season;
if(month == 12 || month == 1 || month == 2)
season = "Winter";
else if(month == 3 || month == 4 || month == 5)
season = "Spring";
else if(month == 6 || month == 7 || month == 8)
season = "Summer";
else if(month == 9 || month == 10 || month == 11)
season = "Autumn";
else
season = "Bogus Month";
System.out.println("April is in the " + season + ".");
}
}
The program will select the value of the case label that equals the value of the
controlling expression and branch down that path to the end of the code block.
If none of the case label values match, then none of the codes within the switch
statement code block will be executed. Java includes a default label to use in cases
where there are no matches.
We can have a nested switch within a case block of an outer switch.
Syntax:
switch (<non-long integral expression>) {
case label1: <statement1> ; break;
case label2: <statement2> ; break;
…
case labeln: <statementn> ; break;
default: <statement>
}
Example:
public class Example {
public static void main(String[] args) {
int a = 10, b = 20, c = 30;
int status = -1;
if (a > b && a > c) {
status = 1;
} else if (b > c) {
status = 2;
} else {
status = 3;
}
switch (status) {
case 1:
System.out.println("a is the greatest");
break;
case 2:
The break statement is optional. If you omit the break, execution will continue on
into the next case.
It is sometimes desirable to have multiple cases without break statements between
them.
For example, consider the following program:
// In a switch, break statements are optional.
class MissingBreak {
public static void main(String args[]) {
for(int i=0; i<12; i++)
switch(i) {
case 0:
case 1:
case 2:
case 3:
case 4:
System.out.println("i is less than 5");
break;
case 5:
case 6:
case 7:
case 8:
case 9:
In summary, there are three important features of the switch statement to note:
The switch differs from the if in that switch can only test for equality, whereas if can
evaluate any type of Boolean expression. That is, the switch looks only for a match
between the value of the expression and one of its case constants.
No two case constants in the same switch can have identical values. Of course, a
switch statement and an enclosing outer switch can have case constants in common.
A switch statement is usually more efficient than a set of nested ifs.
Syntax:
while (<loop condition>) {
<statements>
}
Example:
public class Example {
public static void main(String[] args) {
int count = 1;
System.out.println("Printing Numbers from 1 to 10");
while (count <= 10) {
System.out.println(count++);
}
}
}
Syntax:
do {
<loop body>
} while (<loop condition>);
Syntax:
for (<initialization>; <loop condition>; <increment expression>) {
<loop body>
}
Example:
public class Example {
public static void main(String[] args) {
System.out.println("Printing Numbers from 1 to 10");
for (int count = 1; count <= 10; count++) {
System.out.println(count);
}
}
}
Here is another interesting for loop variation. Either the initialization or the iteration
expression or both may be absent, as in this next program:
// Parts of the for loop can be empty.
class ForVar {
public static void main(String args[]) {
int i;
boolean done = false;
i = 0;
for( ; !done; ) {
System.out.println("i is " + i);
if(i == 10) done = true;
i++;
}
}
}
Here, the initialization and iteration expressions have been moved out of the for. Thus, parts
of the for are empty
Here is one more for loop variation. You can intentionally create an infinite loop (a
loop that never terminates) if you leave all three parts of the for empty.
For example:
for( ; ; ) {
// ...
}
This loop will run forever because there is no condition under which it will terminate.
Here, type specifies the type and itr-var specifies the name of an iteration variable
that will receive the elements from a collection, one at a time, from beginning to end.
The collection being cycled through is specified by collection.
There are various types of collections that can be used with the for, but the only type
used in this chapter is the array.
Working:
With each iteration of the loop, the next element in the collection is retrieved and
stored in itr-var.
The loop repeats until all elements in the collection have been obtained.
Because the iteration variable receives values from the collection, type must be the
same as (or compatible with) the elements stored in the collection.
Thus, when iterating over arrays, type must be compatible with the base type of the
array.
class ForEach {
public static void main(String args[]) {
int nums[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
int sum = 0;
for(int x : nums) {
sum += x;
}
System.out.println("Summation: " + sum);
}
}
With each pass through the loop, x is automatically given a value equal to the next
element in nums. Thus, on the first iteration, x contains 1; on the second iteration, x
contains 2; and so on.
Not only is the syntax streamlined, but it also prevents boundary errors.
For example, this program sums only the first five elements of nums:
class ForEach2 {
Java program to search given key element using for each loop.
class Search {
public static void main(String args[]) {
int nums[] = { 6, 8, 3, 7, 5, 6, 1, 4 };
int val = 5;
boolean found = false;
// use for-each style for to search nums for val
for(int x : nums) {
if(x == val) {
found = true;
break;
}
}
if(found)
System.out.println("Value found!");
}
}
Nested Loops
Like all other programming languages, Java allows loops to be nested.
That is, one loop may be inside another. For example, here is a program that nests for
loops:
class Nested {
public static void main(String args[]) {
int i, j;
for(i=0; i<10; i++) {
for(j=i; j<10; j++)
System.out.print(".");
System.out.println();
Jump Statements
Java supports three jump statements: break, continue, and return. These statements
transfer control to another part of your program.
Syntax:
break; // the unlabeled form
break <label>; // the labeled form
second: {
third: {
}
System.out.println("This is after second block.");
System.out.println("Before the break.");
Syntax:
continue; // the unlabeled form
continue <label>; // the labeled form
Syntax:
The return statement has two forms:
One that returns a value
return val;
One that doesn't returns a value
return;