KEMBAR78
Java Terminal Exam | PDF | Java Virtual Machine | Java (Programming Language)
0% found this document useful (0 votes)
109 views55 pages

Java Terminal Exam

Java is an important programming language for the internet for several reasons: 1. Java allows for seamless distribution of software across networks due to its portability. Programs written in Java can run on any device with a Java Virtual Machine, regardless of hardware or operating system. 2. Java is commonly used to develop a wide variety of applications including desktop programs, mobile apps, games, web apps, and enterprise software. 3. Java was designed to be easy to use, write, compile, debug, and learn compared to other languages. It allows for modular programming and reusable code.

Uploaded by

WaSifAliRajput
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
109 views55 pages

Java Terminal Exam

Java is an important programming language for the internet for several reasons: 1. Java allows for seamless distribution of software across networks due to its portability. Programs written in Java can run on any device with a Java Virtual Machine, regardless of hardware or operating system. 2. Java is commonly used to develop a wide variety of applications including desktop programs, mobile apps, games, web apps, and enterprise software. 3. Java was designed to be easy to use, write, compile, debug, and learn compared to other languages. It allows for modular programming and reusable code.

Uploaded by

WaSifAliRajput
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
You are on page 1/ 55

Chapter # 1

Q. Why Java is important to the Internet? (Fall 2022 MCS Morning)


 Java became important primarily because it provides for the seamless and invisible
distribution of software across the Net.
 Java is designed to be portable and platform-independent, meaning that a
program written in Java can run on any device with a Java Virtual Machine (JVM)
installed, regardless of the underlying hardware and operating system.
 Java is commonly used for developing a wide range of applications, including
desktop applications, mobile apps, games, web applications, and enterprise-level
applications.
 Java was designed to be easy to use and is therefore easy to write, compile,
debug, and learn than other programming languages.
 This allows you to create modular programs and reusable code.
 The language is known for its simplicity, reliability, security, and object-oriented
programming.
 Java is designed to be portable and platform-independent, meaning that a
program written in Java can run on any device with a Java Virtual Machine (JVM)
installed, regardless of the underlying hardware and operating system.
 One of the most significant advantages of Java is its ability to move easily from
one computer system to another. The ability to run the same program on many
different systems is crucial to World Wide Web software, and Java succeeds at this
by being platform-independent at both the source and binary levels.

Because of Java's robustness, ease of use, cross-platform capabilities and security


features, it has become a language of choice for providing worldwide Internet solutions.
 

Q. Java Applets and Applications:

Parameters Java Application Java Applet

Applications are just like a Applets are small Java programs


Java program that can be that are designed to be included
Definition executed independently with the HTML web document. They
without using the web require a Java-enabled web browser
browser. for execution.

The application program The applet does not require the


main ()
requires a main() method for main() method for its execution
method
its execution. instead init() method is required.

The “javac” command is used


Applet programs are compiled with
to compile application
the “javac” command and run using
Compilation programs, which are then
either the “appletviewer” command
executed using the “java”
or the web browser.
command. 
Parameters Java Application Java Applet

Java application programs


Applets don’t have local disk and
File access have full access to the local
network access.
file system and network.

Applications can access all Applets can only access browser-


Access level kinds of resources available specific services. They don’t have
on the system. access to the local system.

First and foremost, the


installation of a Java The Java applet does not need to be
Installation
application on the local installed beforehand.
computer is required. 

Applications can execute the


Applets cannot execute programs
Execution programs from the local
from the local machine.
system.

An application program is
An applet program is needed to
Program needed to perform some
perform small tasks or part of them.
tasks directly for the user.

It cannot start on its own, but it can


It cannot run on its own; it
Run be executed using a Java-enabled
needs JRE to execute. 
web browser.

Connection Connectivity with other It is unable to connect to other


with servers servers is possible. servers.

Read and It supports the reading and It does not support the reading and
Write writing of files on the local writing of files on the local
Operation computer. computer.

Application can access the Executed in a more restricted


system’s data and resources environment with tighter security.
Security
without any security They can only use services that are
limitations. exclusive to their browser.

 Java applications are self-


Applet programs cannot run on their
contained and require no
Restrictions own, necessitating the maximum
additional security because
level of security. 
they are trusted.
Q. Java ByteCode
 Java bytecode is the instruction set for the Java Virtual Machine. It acts similar to
an assembler which is an alias representation of a C++ code.
 As soon as a java program is compiled, java bytecode is generated. In other
words, java bytecode is the machine code in the form of a .class file.
 With the help of java bytecode we achieve platform independence in java.
Working of Bytecode:
 When a Java program is executed, the compiler compiles that piece of code and a
Bytecode is generated for each method in that program in the form of a .class file.
 We can run this bytecode on any other platform as well. But the bytecode is a
non-runnable code that requires or relies on an interpreter. This is where JVM
plays an important part.
 The bytecode generated after the compilation is run by the Java virtual machine.
Resources required for the execution are made available by the Java virtual
machine for smooth execution which calls the processor to allocate the resources.
 JVM's are stack-based so they stack implementation to read the codes.

Bytecode vs Machine code


The main difference between the machine code and the bytecode is that the machine
code is a set of instructions in machine language or binary which can be directly
executed by the CPU.
While the bytecode is a non-runnable code generated by compiling a source code that
relies on an interpreter to get executed.
Advantages of Bytecode
Following are a few advantages of Bytecode:
 It helps in achieving platform-independence which is one of the reasons why
James Gosling started the formation of Java.
 The set of instructions for a JVM may differ from system to system but can all
interpret Bytecode.
 Bytecodes are non-runnable codes that rely on the availability of an interpreter,
this is where JVM comes into play.
 It is a machine-level language code that runs on the JVM.
 It adds portability to Java which resonates with the saying, “write once, read
anywhere”.

Q. Java Buzzwords
Java is a high-level, object-oriented programming language. It was first released
in 1995 by Sun Microsystems (now owned by Oracle Corporation) and has since become
one of the most widely used programming languages in the world. 

Java Buzzwords or Features of Java


The Java programming language is a high-level language that can be characterized by
all of the following buzzwords:
1. Simple
2. Object-oriented
3. Distributed
4. Interpreted
5. Robust
6. Secure
7. Architecture neutral
8. Portable
9. High performance
10. Multithreaded
11. Dynamic

1. Simple
 Java was designed to be easy for a professional programmer to learn and use
effectively.
 It’s simple and easy to learn if you already know the basic concepts of Object
Oriented Programming.
 Best of all, if you are an experienced C++ programmer, moving to Java will
require very little effort. Because Java inherits the C/C++ syntax and many of the
object-oriented features of C++, most programmers have little trouble learning
Java.
 Java has removed many complicated and rarely-used features, for example,
explicit pointers, operator overloading, etc.
2. Object Oriented
 Java is a true object-oriented programming language.
 Almost the “Everything is an Object” paradigm. All program code and data reside
within objects and classes.
 The object model in Java is simple and easy to extend.
 Java comes with an extensive set of classes, arranged in packages that can be
used in our programs through inheritance.
 Object-oriented programming (OOPs) is a methodology that simplifies software
development and maintenance by providing some rules.
The basic concepts of OOPs are:
 Object
 Class
 Inheritance
 Polymorphism
 Abstraction
 Encapsulation
3. Distributed
 Java is designed to create distributed applications on networks.
 Java applications can access remote objects on the Internet as easily as they can
do in the local system.
 Java enables multiple programmers at multiple remote locations to collaborate and
work together on a single project.
 Java is designed for the distributed environment of the Internet because it handles
TCP/IP protocols.
4. Compiled and Interpreted
 Usually, a computer language is either compiled or Interpreted. Java combines
both this approach and makes it a two-stage system.
 Compiled: Java enables the creation of cross-platform programs by compiling
them into an intermediate representation called Java Bytecode.
 Interpreted: Bytecode is then interpreted, which generates machine code that
can be directly executed by the machine that provides a Java Virtual machine.
5. Robust
 It provides many features that make the program execute reliably in a variety of
environments.
 Java is a strictly typed language. It checks code both at compile time and runtime.
 Java takes care of all memory management problems with garbage collection.
 Java, with the help of exception handling, captures all types of serious errors and
eliminates any risk of crashing the system.
6. Secure
 Java provides a “firewall” between a networked application and your computer.
 When a Java Compatible Web browser is used, downloading can be done safely
without fear of viral infection or malicious intent.
 Java achieves this protection by confining a Java program to the Java execution
environment and not allowing it to access other parts of the computer.
7. Architecture Neutral
 Java language and Java Virtual Machine helped in achieving the goal of “write
once; run anywhere, any time, forever.”
 Changes and upgrades in operating systems, processors and system resources will
not force any changes in Java Programs.
8. Portable
 Java Provides a way to download programs dynamically to all the various types of
platforms connected to the Internet.
 Java is portable because of the Java Virtual Machine (JVM). The JVM is an abstract
computing machine that provides a runtime environment for Java programs to
execute. The JVM provides a consistent environment for Java programs to run on,
regardless of the underlying hardware and operating system. This means that a
Java program can be written on one device and run on any other device with a
JVM installed, without any changes or modifications.
9. High Performance
 Java performance is high because of the use of bytecode.
 The bytecode was used so that it can be easily translated into native machine
code.
10. Multithreaded
 Multithreaded Programs handled multiple tasks simultaneously, which was helpful
in creating interactive, networked programs.
 Java run-time system comes with tools that support multiprocess synchronization
used to construct smoothly interactive systems.
11. Dynamic
 Java is capable of linking in new class libraries, methods, and objects.
 Java programs carry with them substantial amounts of run-time type information
that is used to verify and resolve accesses to objects at runtime. This makes it
possible to dynamically link code in a safe and expedient manner.

Chapter 2
OOP Components:
Object-oriented Programming has mainly 4 components – 
1. Objects – Object is the entity that makes the classes to be implemented into the
program. It makes the features, properties, and behaviors of the class to be
implemented. 
Example – A car is an object that has property color, model, brand name, fuel
type, etc, and behaviors like, it runs. So these properties and behavior make an
object (CAR).
2. Classes – A class can be stated as the blueprint of the object. This states what an
object can do. It contains all the features, attributes, and behavior of what the
model can do. We can say that class contains the definition of the object. 
Example – Car color, engine type, etc. And with the definition, we can create any
number of  objects.
3. Methods – Methods are the attributes of the class which are defined for the
specified behavior of the object. It can also modify the state of the class. 
Example – Method to drive a car, It changes the state of the car from parking
state to running state.
4. Instances – It is the members of the class who holds some values related to the
objects of the class.

To understand better about these components better, let’s consider an example –


Consider the same example of television.
So according to the Object-Oriented Programming approach, you will perform certain
steps-
 Define object name as a Television.
 Define the properties of television like channel, volume, on and off, etc.
 Create a function that will handle the functionality of tree-like changing the
channel adjusting volume, or other things.
 Now implement all features into a program.

Now when you define an object as Television then it is the class. And then you declare
the properties of that Television -like channel, volume, etc is the instances of the class
Television. You create functions to change the properties, which are the methods of
Television. And finally when you implement this in your program then you will create
an object of class Televisionto implement into the program.

Programmatically it should be like –


class Television{
int channel; //Instance
int volume; //Instance
boolean on = false;
.
.
void changeChannel(){} //Methods
void adjustVolume(){} //Methods
void switchOnOff(){} //Methods
.
.
}

Television tv = new Television(); //Television Object

OOP Principles:
Object-Oriented Principles mainly include the 4 pillars that together make the OOP a
very powerful concept. That is – 
1. Abstraction
2. Encapsulation
3. Inheritance
4. Polymorphism

1) Abstraction
Abstraction can be defined as “hiding internal implementation and showing only
the required features or set of services that are offered”. Abstraction aims to hide
complexity from users and show them only relevant information.

For example, people do not think of a car as a set of tens of thousands of


individual parts. They think of it as a well-defined object with its own unique behavior.
This abstraction allows people to use a car to drive to the grocery store without being
overwhelmed by the complexity of the parts that form the car. They can ignore the
details of how the engine, transmission, and braking systems work. Instead they are
free to utilize the object as a whole.

 A powerful way to manage abstraction is through the use of hierarchical


classifications.
o This allows you to layer the semantics of complex systems, breaking them
into more manageable pieces.
o From the outside, the car is a single object.
o Once inside, you see that the car consists of several subsystems: steering,
brakes, sound system, seat belts, heating, cellular phone, and so on.
o In turn, each of these subsystems is made up of more specialized units.
o For instance, the sound system consists of a radio, a CD player, and/or a
tape player.
o The point is that you manage the complexity of the car (or any other
complex system) through the use of hierarchical abstractions
• Hierarchical abstractions of complex systems can also be applied to computer
programs.
• The data from a traditional process-oriented program can be transformed by
abstraction into its component objects.
• A sequence of process steps can become a collection of messages between these
objects.
• Thus, each of these objects describes its own unique behavior.
• You can treat these objects as concrete entities that respond to messages telling
them to do something.

2) Encapsulation:
 Encapsulation is the mechanism that binds together code and the data it
manipulates, and keeps both safe from outside interference and misuse.
 One way to think about encapsulation is as a protective wrapper that prevents the
code and data from being arbitrarily accessed by other code defined outside the
wrapper. Access to the code and data inside the wrapper is tightly controlled
through a well-defined interface
 To relate this to the real world, consider the automatic transmission on an
automobile. It encapsulates hundreds of bits of information about your engine,
such as how much you are accelerating, the pitch of the surface you are on, and
the position of the shift lever.
 The whole idea behind encapsulation is to hide the implementation details from
users. If a data member is private it means it can only be accessed within the
same class.
 No outside class can access private data member (variable) of other class.
o The private data fields then the outside class can access those private data
fields via public methods if we setup
 public getter to update (for example void setSSN(int ssn))
 public setter methods to read (for example  int getSSN())
o This way data can only be accessed by public methods thus making the
private fields and their implementation hidden for outside classes.
o That’s why encapsulation is known as data hiding. 
 How to implement encapsulation in java:
1) Make the instance variables private so that they cannot be accessed directly
from outside the class.
2) You can only set and get values of these variables through the methods of
the class.
3) Have getter and setter methods in the class to set and get the values of the
fields.
 Lets see an example to understand this concept better.
Example of Encapsulation:
class EncapsulationDemo
{
private int ssn;
private String empName;
private int empAge;
//Getter methods
public int getEmpSSN()
{
return ssn;
}
public String getEmpName()
{
return empName;
}
public int getEmpAge()
{
return empAge;
}
//Setter methods
public void setEmpAge(int newValue)
{
empAge = newValue;
}
public void setEmpName(String newValue)
{
empName = newValue;
}
public void setEmpSSN(int newValue)
{
ssn = newValue;
}
}
public class EncapsTest
{
public static void main(String args[])
{
EncapsulationDemo obj = new EncapsulationDemo();
obj.setEmpName("Mario");
obj.setEmpAge(32);
obj.setEmpSSN(112233);

System.out.println("Employee Name: " + obj.getEmpName());


System.out.println("Employee SSN: " + obj.getEmpSSN());
System.out.println("Employee Age: " + obj.getEmpAge());
}
}

Output:
Employee Name: Mario
Employee SSN: 112233
Employee Age: 32

In above example,
 all the three data members (or data fields) are private which cannot be accessed
directly.
 These fields can be accessed via public methods only. Fields:
o empName
o ssn
o empAge
are made hidden data fields using encapsulation technique of OOPs.

Advantages:
Encapsulation in programming has a few key benefits. These include:
 Hiding data: Users will have no idea how classes are being implemented or
stored. All that users will know is that values are being passed and initialized.
 More flexibility: Enables you to set variables as red or write-only. Examples
include: setName(), setAge() or to set variables as write-only then you only need
to omit the get methods like getName(), getAge() etc.
 Easy to reuse: With encapsulation, it's easy to change and adapt to new
requirements
3) Inheritance:
 Inheritance is the method of acquiring features of the existing class into the new
class.
 Suppose there is a class,
o considered as the parent class, that has some methods associated with it.
o we declare a new class, considered as the child class, that has its own
methods.
o when a child class is inherited from the parent class then it will have all the
methods associated with parent class are available in the child class along
with the child class own methods also. So that is Inheritance.
 There are two keywords involved in the inheritance – Base and Derived Class.
o Base Class – It is also termed the parent class. It is the main class that has
the basic properties and methods which is defined.
o Derived Class – This is the extension of the base class and it is also called
the child class. It has the properties and methods that are in the base class
with its own features in it.

Types of Inheritance:
Inheritance has multiple types that depend on programming languages implementation.
Some of the common types of inheritance are:
a) Single Inheritance – When there is only one derived class. In other words, When
a class extends another one class only then we call it a single inheritance. The
below flow diagram shows that class B extends only one class which is A. Here A is
a parent class of B and B would be a child class of A.

For example,
Class A
{
public void methodA()
{
System.out.println("Base class method");
}
}

Class B extends A
{
public void methodB()
{
System.out.println("Child class method");
}
public static void main(String args[])
{
B obj = new B();
obj.methodA(); //calling super class method
obj.methodB(); //calling local method
}
}

b) Multiple Inheritance – When child class is inheriting more than one base class.
Or it refers to the concept of one class extending (or inherits) more than one base
class.
The problem with “multiple inheritance” is that the derived class will have to
manage the dependency on two base classes.

c) Multilevel Inheritance – When there is a level of inheritance. From class A to


class B to class C.

Class X
{
public void methodX()
{
System.out.println("Class X method");
}
}
Class Y extends X
{
public void methodY()
{
System.out.println("class Y method");
}
}
Class Z extends Y
{
public void methodZ()
{
System.out.println("class Z method");
}
public static void main(String args[])
{
Z obj = new Z();
obj.methodX(); //calling grand parent class method
obj.methodY(); //calling parent class method
obj.methodZ(); //calling local method
}
}

d) Hierarchical Inheritance – When more than one derived class is inheriting one
base class. n such kind of inheritance one class is inherited by many sub classes.
In below example class B,C and D inherits the same class A. A is parent class
(or base class) of B,C & D.

class A
{
public void methodA()
{
System.out.println("method of Class A");
}
}
class B extends A
{
public void methodB()
{
System.out.println("method of Class B");
}
}
class C extends A
{
public void methodC()
{
System.out.println("method of Class C");
}
}
class D extends A
{
public void methodD()
{
System.out.println("method of Class D");
}
}
class JavaExample
{
public static void main(String args[])
{
B obj1 = new B();
C obj2 = new C();
D obj3 = new D();
//All classes can access the method of class A
obj1.methodA();
obj2.methodA();
obj3.methodA();
}
}
Output:

method of Class A
method of Class A
method of Class A
Advantages of Inheritance
 Inheritance removes redundancy from the code. A class can reuse the fields and
methods of parent class. No need to rewrite the same redundant code again.
 Inheritance allows us to reuse of code, it improves reusability in your java
application.
 Reduces code size: By removing redundant code, it reduces the number of lines
of the code.
 Improves logical structure: Improves the logical structure of the code that
allows programmer to visualize the relationship between different classes.

4) Polymorphism:
 Polymorphism (from the Greek, meaning “many forms”) is a feature that allows
one interface to be used for a general class of actions. The specific action is
determined by the exact nature of the situation
 Polymorphism refers to the ability to perform a certain action in different ways.
 Types of polymorphism are:
o Compile-time polymorphism (also called static polymorphism or
static method dispatch).
 It can be achieved by method overloading.
 Method overloading happens when various methods with the same
name are present in a class. When they are called, they are
differentiated by the number, order, or types of their parameters. In
this process, an overloaded method is resolved at compile time rather
than resolving at runtime.
o Runtime Polymorphism (Dynamic Polymorphism):
 Runtime polymorphism in Java occurs when we have two or more
classes, and all are interrelated through inheritance.
 It is achieved by method overriding (which occurs when a child class
overrides a method of its parent.)

Q. Java Class Libraries


The Java Class Libraries refers to the set of loadable Java classes that Java applications
can call during runtime. These Java Class Libraries consist of a standardized reusable
code with which programmers become familiar and are free to implement within their
own programs.
These libraries provide –
 Container classes and Regular Expressions.
 Interfaces for tasks that depend on the hardware of the OS such as network
and file access.
 In case, the underlying platform does not support certain feature of Java
then, these libraries surpass that specific feature if needed.

Some examples of Java Class Libraries are:


(1) java.lang
(2) java.Math
(3) java.awt
(4) java.swing
(5) java.util
(6) java.ArrayList

two of Java’s built-in methods: println( ) and print( ) are members of the System class,
which is a class predefined by Java that is automatically included in your programs.
In the larger view, the Java environment relies on several built-in class libraries that
contain many built-in methods that provide support for such things as I/O, string
handling, networking, and graphics.
The standard classes also provide support for windowed output.
Thus, Java as a totality is a combination of the Java language itself, plus its standard
classes.
As you will see, the class libraries provide much of the functionality that comes with
Java.
Indeed, part of becoming a Java programmer is learning to use the standard Java
classes.
Java is not dependent on any specific operating system so Java applications cannot
depend on the platform dependent native libraries, therefore, instead of those Java
provides a set of dynamically loaded libraries that are common to modern operating
systems.

Q.Control Statement

(i) The if Statement


 The Java if statement works much like the IF statement in any other language.
 it is syntactically identical to the if statements in C, C++, and C#.
 Syntax: Its simplest form is shown here:
if(condition) statement;
Here,
condition: is a Boolean expression.
- If condition is true, then the statement is executed.
- If condition is false, then the statement is bypassed.
 Example: Here is an example:

if(num < 100) println("num is less than 100");

In this case, if num contains a value that is less than 100, the conditional
expression is true, and println( ) will execute. If num contains a value greater than
or equal to 100, then the println( ) method is bypassed.
 Java defines a full complement of relational operators which may be used in a
conditional expression. Here are a few:
Operator Meaning
< Less than
> Greater than
== Equal to
*Notice that the test for equality is the double equal sign.
Program:
class IfSample
{
public static void main(String args[])
{
int x, y;
x = 10;
y = 20;
if(x < y) System.out.println("x is less than y");
x = x * 2;
if(x == y) System.out.println("x now equal to y");
x = x * 2;
if(x > y) System.out.println("x now greater than y");
// this won't display anything
If(x == y) System.out.println("you won't see this");
}
}
Output:
The output generated by this program is shown here:
x is less than y
x now equal to y
x now greater than y

(ii) The for Loop


The simplest form of the for loop is shown here:
For (initialization; condition; iteration)
{
statements;
}
In its most common form,
 the initialization portion of the loop sets a loop control variable to an initial value.
 The condition is a Boolean expression that tests the loop control variable. If the
outcome of that test is true, the for loop continues to iterate. If it is false, the loop
terminates.
 The iteration expression determines how the loop control variable is changed each
time the loop iterates.
Example
class ForTest
{
public static void main(String args[])
{
int x;
for(x = 0; x<10; x = x+1)
{
System.out.println("This is x: " + x);
}
}
}

Output: This program generates the following output:


This is x: 0
This is x: 1
This is x: 2
This is x: 3
This is x: 4
This is x: 5
This is x: 6
This is x: 7
This is x: 8
This is x: 9
Chapter 3
Q.Variable (MCS Morning, Fall 2022)
 A variable is defined by the combination of an identifier, a type, and an optional
initializer.
 The variable is the basic unit of storage in a Java program.
 In addition, all variables have a scope, which defines their visibility, and a lifetime.
Declaring a Variable
 In Java, all variables must be declared before they can be used.
 The basic form of a variable declaration is shown here:
type identifier [ = value][, identifier [= value] ...] ;
 The type is one of Java’s atomic types, or the name of a class or interface.
 The identifier is the name of the variable.
 You can initialize the variable by specifying an equal sign and a value.
 Keep in mind that the initialization expression must result in a value of the same
(or compatible) type as that specified for the variable.
 To declare more than one variable of the specified type, use a comma-separated
list.
Examples:
 Here are several examples of variable declarations of various types. Note that
some include an initialization.

The identifiers that you choose have nothing intrinsic in their names that indicates
their type.
 Java allows any properly formed identifier to have any declared type.
Dynamic Initialization
 Although the preceding examples have used only constants as initializers, Java
allows variables to be initialized dynamically, using any expression valid at the
time the variable is declared.
 For example, here is a short program that computes the length of the hypotenuse
of a right triangle given the lengths of its two opposing sides:
Here, three local variables: a, b, and c are declared. The first two, a and b, are initialized
by constants. However, c is initialized dynamically to the length of the hypotenuse
(using the Pythagorean theorem). The program uses another of Java’s built-in methods,
sqrt( ), which is a member of the Math class, to compute the square root of its
argument. The key point here is that the initialization expression may use any element
valid at the time of the initialization, including calls to methods, other variables, or
literals.
The Scope and Lifetime of Variables
 The scope defined by a method begins with its opening curly brace.
 As a general rule, variables declared inside a scope are not visible (that is,
accessible) to code that is defined outside that scope. Thus, when you declare a
variable within a scope, you are localizing that variable and protecting it from
unauthorized access and/or modification. Indeed, the scope rules provide the
foundation for encapsulation.
 Scopes can be nested.
o For example, each time you create a block of code, you are creating a new,
nested scope.
o When this occurs, the outer scope encloses the inner scope.
o This means that objects declared in the outer scope will be visible to code
within the inner scope.
o However, the reverse is not true.
o Objects declared within the inner scope will not be visible outside it.
o To understand the effect of nested scopes, consider the following program:
 As the comments indicate, the variable x is declared at the start of main( )’s scope
and is accessible to all subsequent code within main( ).
 Within the if block, y is declared.
 Since a block defines a scope, y is only visible to other code within its block.
 This is why outside of its block, the line y = 100; is commented out.
 If you remove the leading comment symbol, a compile-time error will occur,
because y is not visible outside of its block.
 Within the if block, x can be used because code within a block (that is, a nested
scope) has access to variables declared by an enclosing scope.
 Within a block, variables can be declared at any point, but are valid only after they
are declared.
 Thus, if you define a variable at the start of a method, it is available to all of the
code within that method.
 Conversely, if you declare a variable at the end of a block, it is effectively useless,
because no code will have access to it.
o For example, this fragment is invalid because count cannot be used prior to
its declaration:
 Here is another important point to remember:
o variables are created when their scope is entered, and destroyed when their
scope is left.
o This means that a variable will not hold its value once it has gone out of
scope.
o Therefore, variables declared within a method will not hold their values
between calls to that method.
o Also, a variable declared within a block will lose its value when the block is
left.
o Thus, the lifetime of a variable is confined to its scope.
 If a variable declaration includes an initializer, then that variable will be
reinitialized each time the block in which it is declared is entered.
o For example, consider the next program.

As you can see, y is always reinitialized to –1 each time the inner for loop is entered.
Even though it is subsequently assigned the value 100, this value is lost. One last point:
Although blocks can be nested, you cannot declare a variable to have the same name as
one in an outer scope.
 Here is an example that tries to declare two separate variables with the same name.
In Java, this is illegal. In C/C++, it would be legal and the two bars would be
separate.
Q2: Boolean
 Java has a simple type, called boolean, for logical values.
 It can have only one of two possible values, true or false.
 This is the type returned by all relational operators, such as a < b. Boolean is also the
type required by the conditional expressions that govern the control statements such
as if and for.
 Here is a program that demonstrates the boolean type:
There are three interesting things to notice about this program.
 First, as you can see, when a boolean value is output by println( ), “true” or “false”
is displayed.
 Second, the value of a boolean variable is sufficient, by itself, to control the if
statement.
 There is no need to write an if statement like this:

 Third, the outcome of a relational operator, such as <, is a boolean value. This is
why the expression 10 > 9 displays the value “true.” Further, the extra set of
parentheses around 10 > 9 is necessary because the + operator has a higher
precedence than the >.

Q3: Arrays (MCS Morning, Fall 2022)


 An array is a group of like-typed variables that are referred to by a common
name.
 Arrays of any type can be created and may have one or more dimensions.
 A specific element in an array is accessed by its index. Arrays offer a convenient
means of grouping related information.
One-Dimensional Arrays
 A one-dimensional array is, essentially, a list of like-typed variables.
 To create an array, you first must create an array variable of the desired type.
 The general form of a one-dimensional array declaration is
type var-name[ ];
o Here, type declares the base type of the array that determines the data type
of each element that comprises the array.
o For example, the following declares an array named month_days with the
type “array of int”:
int month_days[];
o The value of month_days is set to null, which represents an array with no
value.
o To link month_days with an actual, physical array of integers, you must
allocate one using new and assign it to month_days. new is a special
operator that allocates memory.
 The general form of new as it applies to one-dimensional arrays appears as
follows:
array-var = new type[size];
Here,
- type specifies the type of data being allocated,
- size specifies the number of elements in the array, and array-var is the
array variable that is linked to the array.
- That is, to use new to allocate an array, you must specify the type and
number of elements to allocate.
- The elements in the array allocated by new will automatically be
initialized to zero.
- This example allocates a 12-element array of integers and links them
to month_days.
month_days = new int[12];
- After this statement executes, month_days will refer to an array of 12
integers.
- Further, all elements in the array will be initialized to zero.
Method 1
 Obtaining an array is a two-step process.
o First, you must declare a variable of the desired array type.
o Second, you must allocate the memory that will hold the array, using new,
and assign it to the array variable.
 Thus, in Java all arrays are dynamically allocated.
 Once you have allocated an array, you can access a specific element in the array
by specifying its index within square brackets.
 All array indexes start at zero. For example, this statement assigns the value 28 to
the second element of month_days.
When you run this program, it prints the number of days in April. As mentioned, Java
array indexes start with zero, so the number of days in April is month_days[3] or 30.It
is possible to combine the declaration of the array variable with the allocation of the
array itself, as shown here:

int month_days[] = new int[12];

Method 2: This is the way that you will normally see it done in professionally written
Java
programs.

 Arrays can be initialized when they are declared.


 The process is much the same as that used to initialize the simple types.
 An array initializer is a list of comma-separated expressions surrounded by curly
braces.
 The commas separate the values of the array elements.
 The array will automatically be created large enough to hold the number of
elements you specify in the array initializer. There is no need to use new.
 For example, to store the number of days in each month, the following code
creates an initialized array of integers:

When you run this program, you see the same output as that generated by the previous
version.
 Here is one more example that uses a one-dimensional array. It finds the average
of a set of numbers.
Multidimensional Arrays
 In Java, multidimensional arrays are actually arrays of arrays.
 These, as you might expect, look and act like regular multidimensional arrays.
 To declare a multidimensional array variable, specify each additional index using
another set of square brackets. For example, the following declares a two-
dimensional array variable called twoD.

 This allocates a 4 by 5 array and assigns it to twoD. Internally this matrix is


implemented as an array of arrays of int. Conceptually, this array will look like
Chapter 4
Bitwise Operator (MCS Morning, Fall 2022)
Java defines several bitwise operators which can be applied to the integer types,
long,int, short, char, and byte. These operators act upon the individual bits of their
operands. They are summarized in the following table:
Operator Result
~ Bitwise unary NOT
& Bitwise AND
| Bitwise OR
^ Bitwise exclusive OR Notations
>> Shift right
>>> Shift right zero fill
<< Shift left
Bitwise exclusive OR
^=
assignment Bitwise
>>= Shift right assignment Assignment
>>>= Shift right zero fill assignment operators
<<= Shift left assignment
Bitwise OR (|)
This operator is a binary operator, denoted by ‘|’. It returns bit by bit OR of input values,
i.e., if either of the bits is 1, it gives 1, else it shows 0.

Example:
a = 5 = 0101 (In Binary)
b = 7 = 0111 (In Binary)
Bitwise OR Operation of 5 and 7
0101
| 0111
________
0111 = 7 (In decimal)

Bitwise AND (&)


This operator is a binary operator, denoted by ‘&.’ It returns bit by bit AND of input
values, i.e., if both bits are 1, it gives 1, else it shows 0.

Example:
a = 5 = 0101 (In Binary)
b = 7 = 0111 (In Binary)

Bitwise AND Operation of 5 and 7


0101
& 0111
________
0101 = 5 (In decimal)

Bitwise XOR (^)


This operator is a binary operator, denoted by ‘^.’ It returns bit by bit XOR of input
values, i.e., if corresponding bits are different, it gives 1, else it shows 0.

Example:
a = 5 = 0101 (In Binary)
b = 7 = 0111 (In Binary)

Bitwise XOR Operation of 5 and 7


0101
^ 0111
________
0010 = 2 (In decimal)

Bitwise Complement (~)


This operator is a unary operator, denoted by ‘~.’ It returns the one’s complement
representation of the input value, i.e., with all bits inverted, which means it makes every
0 to 1, and every 1 to 0.

Example:
a = 5 = 0101 (In Binary)

Bitwise Complement Operation of 5

~ 0101
________
1010 = 10 (In decimal)

Bit-Shift Operators (Shift Operators)


Shift operators are used to shift the bits of a number left or right, thereby multiplying or
dividing the number by two, respectively. They can be used when we have to multiply or
divide a number by two.
Syntax:
number shift_op number_of_places_to_shift;

Example:
// Java program to illustrate
// bitwise operators

public class operators {


public static void main(String[] args)
{
// Initial values
int a = 5;
int b = 7;

// bitwise and
// 0101 & 0111=0101 = 5
System.out.println("a&b = " + (a & b));

// bitwise or
// 0101 | 0111=0111 = 7
System.out.println("a|b = " + (a | b));

// bitwise xor
// 0101 ^ 0111=0010 = 2
System.out.println("a^b = " + (a ^ b));

// bitwise not
// ~00000000 00000000 00000000 00000101=11111111
11111111 11111111 11111010
// will give 2's complement (32 bit) of 5 = -6
System.out.println("~a = " + ~a);

// can also be combined with


// assignment operator to provide shorthand
// assignment
// a=a&b
a &= b;
System.out.println("a= " + a);
}
}
Output
a&b = 5
a|b = 7
a^b = 2
~a = -6
a= 5
Types of Shift Operators:

Shift Operators are further divided into 4 types. These are:

i. Signed Right shift operator (>>)


ii. Unsigned Right shift operator (>>>)
iii. Left shift operator(<<)
iv. Unsigned Left shift operator (<<<)

Example:
import java.util.Scanner;

public class BitwiseOperators {


public static void main(String[] args) {
Scanner input = new Scanner(System.in);

System.out.print("Enter first number: ");


int num1 = input.nextInt();

System.out.print("Enter second number: ");


int num2 = input.nextInt();

System.out.println("Bitwise AND: " + (num1 & num2));


System.out.println("Bitwise OR: " + (num1 | num2));
System.out.println("Bitwise XOR: " + (num1 ^ num2));
System.out.println("Bitwise NOT: " + (~num1));
System.out.println("Bitwise Left Shift: " + (num1 << 2));
System.out.println("Bitwise Right Shift: " + (num1 >> 2));
System.out.println("Bitwise Unsigned Right Shift: " + (num1
>>> 2));

input.close();
}
}

Output
Enter first number: 2
Enter second number: 3
Bitwise AND: 2
Bitwise OR: 3
Bitwise XOR: 1
Bitwise NOT: -3
Bitwise Left Shift: 8
Bitwise Right Shift: 0
Bitwise Unsigned Right Shift: 0
Q. Relational Operators
The relational operators determine the relationship that one operand has to the other.
Specifically, they determine equality and ordering. The relational operators are shown
here:
Operator Result
== Equal to
!= Not equal to
> Greater than
< Less than
>= Greater than or equal to
<= Less than or equal to
Example:
public class RelationalOperators {
public static void main(String[] args) {

int num1 =1;


int num2 = 2;

System.out.println("num1 > num2 is " + (num1 > num2));


System.out.println("num1 < num2 is " + (num1 < num2));
System.out.println("num1 >= num2 is " + (num1 >= num2));
System.out.println("num1 <= num2 is " + (num1 <= num2));
System.out.println("num1 == num2 is " + (num1 == num2));
System.out.println("num1 != num2 is " + (num1 != num2));
}
}
Output
num1 > num2 is false
num1 < num2 is true
num1 >= num2 is false
num1 <= num2 is true
num1 == num2 is false
num1 != num2 is true

Q. Boolean Logical Operators:


The Boolean logical operators shown here operate only on boolean operands. All
of the binary logical operators combine two boolean values to form a resultant boolean
value.
Operator Result
& Logical AND
| Logical OR
^ Logical XOR (exclusive
|| OR)
&& Short Circuit OR
! Short Circuit AND
&= Logical unary NOT
|= AND assignment
^= OR Assignment
== XOR assignment
!= Equal to
?: Not Equal to
Ternary if then else
The logical Boolean operators, &, |, and ^, operate on boolean values in the same way
that they operate on the bits of an integer. The logical ! operator inverts the Boolean
state: !true == false and !false == true. The following table shows the effect of each
logical operation:

Example
// Demonstrate the boolean logical operators.
class BoolLogic {
public static void main(String args[]) {
boolean a = true;
boolean b = false;
boolean c = a | b;
boolean d = a & b;
boolean e = a ^ b;
boolean f = (!a & b) | (a & !b);
boolean g = !a;
System.out.println( " a = " + a);
System.out.println( " b = " + b);
System.out.println( " a | b = " + c);
System.out.println( " a & b = " + d);
System.out.println( " a ^ b = " + e);
System.out.println( " !a & b | a & ! b = " + f);
System.out.println( " !a = " + g);
}
}
Output
a = true
b = false
a | b = true
a & b = false
a ^ b = true
a & b | a & ! b = true
! a = false

1. Logical ‘AND’ Operator (&&) 


This operator returns true when both the conditions under consideration are satisfied or
are true. If even one of the two yields false, the operator results false. In Simple terms, 
cond1 && cond2 returns true when both cond1 and cond2 are true (i.e. non-
zero). 

Syntax:
condition1 && condition2
Illustration:
a = 10, b = 20, c = 20

condition1: a < b
condition2: b == c

if(condition1 && condition2)


d=a+b+c

// Since both the conditions are true


d = 50.

2. Logical ‘OR’ Operator (||) 


This operator returns true when one of the two conditions under consideration is
satisfied or is true. If even one of the two yields true, the operator results true. To make
the result false, both the constraints need to return false. 
Syntax:
condition1 || condition2
Example:
a = 10, b = 20, c = 20

condition1: a < b
condition2: b > c

if(condition1 || condition2)
d=a+b+c

// Since one of the condition is true


d = 50.

3. Logical ‘NOT’ Operator (!)


Unlike the previous two, this is a unary operator and returns true when the condition
under consideration is not satisfied or is a false condition. Basically, if the condition is
false, the operation returns true and when the condition is true, the operation returns
false. 
Syntax:
!(condition)
Example:
a = 10, b = 20

!(a<b) // returns false


!(a>b) // returns true
Short-Circuit Logical Operators
o Java provides two interesting Boolean operators not found in many other computer
languages.
o These are secondary versions of the Boolean AND and OR operators, and are
known as short-circuit logical operators.
o As the OR operator results in true when A is true, no matter what B is. Similarly,
the AND operator results in false when A is false, no matter what B is.
o If you use the || and && forms, rather than the | and & forms of these operators,
Java will not bother to evaluate the right-hand operand when the outcome of the
expression can be determined by the left operand alone.
o For example, the following code fragment shows how you can take advantage of
short-circuit logical evaluation to be sure that a division operation will be valid
before evaluating it:
if (denom != 0 && num / denom > 10)

Q.Arithmetic operator
These operators involve the mathematical operators that can be used to perform various
simple or advanced arithmetic operations on the primitive data types referred to as the
operands. These operators consist of various unary and binary operators that can be
applied on a single or two operands.

Example:
import java.util.Scanner;

public class ArithmeticOperators {


public static void main(String[] args) {
Scanner sc = new Scanner(System.in);

System.out.print("Enter the first number: ");


double num1 = sc.nextDouble();

System.out.print("Enter the second number: ");


double num2 = sc.nextDouble();

double sum = num1 + num2;


double difference = num1 - num2;
double product = num1 * num2;
double quotient = num1 / num2;
System.out.println("The sum of the two numbers is: " + sum);
System.out.println("The difference of the two numbers is: " +
difference);
System.out.println("The product of the two numbers is: " +
product);
System.out.println("The quotient of the two numbers is: " +
quotient);
}
}
Output
Enter the first number: 2
Enter the second number: 3
The sum of the two numbers is: 5.0
The difference of the two numbers is: -1.0
The product of the two numbers is: 6.0
The quotient of the two numbers is: 0.6666666666666666

Chapter 5
Switch statement
 The switch statement is a multiway branch statement. It provides an easy way to
dispatch execution to different parts of code based on the value of the expression.
 Switch is a control statement that allows a value to change control of execution
 As such, it often provides a better alternative than a large series of if-else-if
statements.
 Here is the general form of a switch statement:
SYNTAX:
switch (expression) {
case value1:
// statement sequence
break;
case value2:
// statement sequence
break;
.
.
.
case valueN:
// statement sequence
break;
default:
// default statement sequence

Nested Switch:
Nested-Switch statements refers to Switch statements inside of another Switch
Statements.
Syntax: 
 
switch(n)
{
// code to be executed if n = 1;
case 1:
// Nested switch
switch(num)
{
// code to be executed if num = 10
case 10:
statement 1;
break;
// code to be executed if num = 20
case 20:
statement 2;
break;
.
.
.
// code to be executed if num
// doesn't match any cases
default:
}
break;
// code to be executed if n = 2;
case 2:
statement 2;
break;
.
.
// code to be executed if n doesn't match any cases
default:
}

Since a switch statement defines its own block, no conflicts arise between the case
constants in the inner switch and those in the outer switch.
Chapter 6
Define Constructor and write a program to use constructor to initialize the
dimension of a box: (MCS Morning, Fall 2022)
 A constructor in Java is a special method that is used to initialize objects.
 It has the same name as the class in which it resides and is syntactically similar to
a method.
 Once defined, the constructor is automatically called immediately after the object
is created, before the new operator completes.
 Whenever we use new keyword to create an instance of a class, the constructor is
invoked and the object of the class is returned.
 If we add a return type to a constructor, then it will become a method of the class.
 This is the way java runtime distinguish between a normal method and a
constructor.
/* Here, Box uses a constructor to initialize the
dimensions of a box.
*/
class Box
{
double width;
double height;
double depth;

// This is the constructor for Box.


Box()
{
System.out.println("Constructing Box");
width = 10;
height = 10;
depth = 10;
}

// compute and return volume


double volume()
{
return width * height * depth;
}

class BoxDemo6
{
public static void main(String args[]) {

// declare, allocate, and initialize Box objects


Box mybox1 = new Box();
Box mybox2 = new Box();
double vol;

// get volume of first box


vol = mybox1.volume();
System.out.println("Volume is " + vol);
// get volume of second box
vol = mybox2.volume();
System.out.println("Volume is " + vol);
}
}
Output
Constructing Box
Constructing Box
Volume is 1000.0
Volume is 1000.0

Types of Constructors in Java


There are two types of constructor in java.
1. Default Constructor (No-Args constructor)
2. Parameterized constructor
1) Default Constructor
 The default constructor is often sufficient for simple classes, but it usually won’t do
for more sophisticated ones.
 It’s not required to always provide a constructor implementation in the class code.
 If we don’t provide a constructor, then java provides default constructor
implementation for us to use.
 The default constructor is used to provide the default values to the object like 0,
null, etc., depending on the type.

Syntax of default constructor:


<class_name>()
{
}
Example
//which displays the default values
class Student3
{
int id;
String name;

//method to display the value of id and name


void display(){System.out.println(id+" "+name);}

public static void main(String args[])


{
//creating objects
Student3 s1=new Student3();
Student3 s2=new Student3();
//displaying values of the object
s1.display();
s2.display();
}
}
Output
0 null
0 null
//Java Program to create and call a default constructor

class Bike1{

//creating a default constructor

Bike1()
{
System.out.println("Bike is created");
}

//main method
public static void main(String args[])
{

//calling a default constructor


Bike1 b=new Bike1();
}
}
Output
Bike is created

2) Java Parameterized Constructor


 A constructor which has a specific number of parameters is called a
parameterized constructor.
 The parameterized constructor is used to provide different values to distinct
objects. However, you can provide the same values also.
Example:
In this example, we have created the constructor of Student class that have
two parameters. We can have any number of parameters in the constructor.
/* Here, Box uses a parameterized constructor to
initialize the dimensions of a box.
*/
class Box {
double width;
double height;
double depth;
// This is the constructor for Box.
Box(double w, double h, double d) {
width = w;
height = h;
depth = d;
}
// compute and return volume
double volume() {
return width * height * depth;
}
}
class BoxDemo7 {
public static void main(String args[]) {
// declare, allocate, and initialize Box objects
Box mybox1 = new Box(10, 20, 15);
Box mybox2 = new Box(3, 6, 9);
double vol;
// get volume of first box
vol = mybox1.volume();
System.out.println("Volume is " + vol);
// get volume of second box
vol = mybox2.volume();
System.out.println("Volume is " + vol);
}
}
Output
Volume is 3000.0
Volume is 162.0

Q. Finalize method

 The Java finalize() method of Object class is a method that the Garbage Collector
always calls just before the deletion/destroying the object which is eligible for
Garbage Collection to perform clean-up activity.
 Clean-up activity means closing the resources associated with that object like
Database Connection, Network Connection, or we can say resource de-allocation.
 finalize() method releases system resources before the garbage collector runs for
a specific object. JVM allows finalize() to be invoked only once per object.
 Remember, it is not a reserved keyword.
 Once the finalize() method completes immediately, Garbage Collector destroys
that object.
 Finalization: 
Just before destroying any object, the garbage collector always calls finalize()
method to perform clean-up activities on that object. This process is known as
Finalization in Java.
 Syntax:
The finalize( ) method has this general form:
protected void finalize( )
{
// finalization code here
}
Here,
-the keyword protected is a specifier that prevents access to finalize( ) by code defined
outside its class.
 It is important to understand that finalize( ) is only called just prior to garbage
collection.
 It is not called when an object goes out-of-scope, for example. This means that
you cannot know when—or even if—finalize( ) will be executed.
 Therefore, your program should provide other means of releasing system
resources, etc., used by the object.
 It must not rely on finalize( ) for normal program operation.

Chapter 7
Overloading method
 In Java it is possible to define two or more methods within the same class that
share the same name, as long as their parameter declarations are different. When
this is the case, the methods are said to be overloaded, and the process is
referred to as method overloading.
 Method overloading is one of the ways that Java implements polymorphism.
 When an overloaded method is invoked, Java uses the type and/or number of
arguments as its guide to determine which version of the overloaded method to
actually call.
 Thus, overloaded methods must differ in the type and/or number of their
parameters.
 While overloaded methods may have different return types, the return type alone
is insufficient to distinguish two versions of a method.
 When Java encounters a call to an overloaded method, it simply executes the
version of the method whose parameters match the arguments used in the call.
 Here is a simple example that illustrates method overloading:

// Demonstrate method overloading.


class OverloadDemo
{
void test()
{
System.out.println("No parameters");
}

// Overload test for one integer parameter.


void test(int a)
{
System.out.println("a: " + a);
}

// Overload test for two integer parameters.


void test(int a, int b)
{
System.out.println("a and b: " + a + " " + b);
}

// overload test for a double parameter


double test(double a)
{
System.out.println("double a: " + a);
return a*a;
}
}

class Overload
{
public static void main(String args[])
{
OverloadDemo ob = new OverloadDemo();
double result;

// call all versions of test()


ob.test();
ob.test(10);
ob.test(10, 20);
result = ob.test(123.25);
System.out.println("Result of ob.test(123.25): " + result);
}
}
Output
No parameters
a: 10
a and b: 10 20
double a: 123.25
Result of ob.test(123.25): 15190.5625

Q. Define Recursion with program (MCS Morning, Fall 2022)


 Java supports recursion. Recursion is the process of defining something in terms
of itself.
 As it relates to Java programming, recursion is the attribute that allows a method
to call itself.
 A method that calls itself is said to be recursive method.
Example:
 The classic example of recursion is the computation of the factorial of a number.
 The factorial of a number N is the product of all the whole numbers between 1 and
N.
 For example, 3 factorial is 1 × 2 × 3, or 6. Here is how a factorial can be
computed by use of a recursive method:
// A simple example of recursion.
class Factorial {
// this is a recursive function
int fact(int n) {
int result;
if(n==1) return 1;
result = fact(n-1) * n;
return result;
}
}
class Recursion {
public static void main(String args[]) {
Factorial f = new Factorial();
System.out.println("Factorial of 3 is " + f.fact(3));
System.out.println("Factorial of 4 is " + f.fact(4));
System.out.println("Factorial of 5 is " + f.fact(5));
}
}
Output
Factorial of 3 is 6
Factorial of 4 is 24
Factorial of 5 is 120
class RecTest {
int values[];
RecTest(int i) {
values = new int[i];
}
// display array -- recursively
void printArray(int i) {
if(i==0) return;
else printArray(i-1);
System.out.println("[" + (i-1) + "] " + values[i-1]);
}
}
class Recursion2 {
public static void main(String args[]) {
RecTest ob = new RecTest(10);
int i;
for(i=0; i<10; i++) ob.values[i] = i;
ob.printArray(10);
}
}
Output
[0] 0
[1] 1
[2] 2
[3] 3
[4] 4
[5] 5
[6] 6
Chapter 8
Creating a multilevel hierarchy
 We have been using simple class hierarchies that consist of only a superclass and
a subclass.
 However, you can build hierarchies that contain as many layers of inheritance as
you like.
 As mentioned, it is perfectly acceptable to use a subclass as a superclass of
another.
 For example, given three classes called A, B, and C, C can be a subclass of B,
which is a subclass of A.
 When this type of situation occurs, each subclass inherits all of the traits found in
all of its superclasses.
 In this case, C inherits all aspects of B and A.

 To see how a multilevel hierarchy can be useful, consider the following program.
Example1:
class A {
void funcA() {
System.out.println("This is class A");
}
}
class B extends A {
void funcB() {
System.out.println("This is class B");
}
}
class C extends B {
void funcC() {
System.out.println("This is class C");
}
}
class Demo {
public static void main(String args[]) {
C obj = new C();
obj.funcA();
obj.funcB();
obj.funcC();
}
}
Output
This is class A
This is class B
This is class C

Example2:

class stu
{
int rollno;
String name;

stu(int r, String n)
{
rollno = r;
name = n;
}

void show()
{
System.out.println("Student Roll no - " + rollno);
System.out.println("Student Name - " + name);
}
}

class marks extends stu


{
int s1, s2, s3, s4, s5, sum1;

marks(int r, String n, int m1, int m2, int m3, int m4, int
m5)
{
super(r,n);
s1 = m1;
s2 = m2;
s3 = m3;
s4 = m4;
s5 = m5;
}

void showmarks()
{
show();
sum1 = s1 + s2 + s3 + s4 + s5;
System.out.println("Total marks = " + sum1);
}
}

class percent extends marks


{
float per;

percent(int r, String n, int m1, int m2, int m3, int m4, int
m5, float p)
{
super(r,n,m1,m2,m3,m4,m5);
per=p;
}

void showper()
{
showmarks();
per = sum1 / 5;
System.out.println("Percentage = " + per);
}
}

class multiEg
{
public static void main(String args[])
{
percent p = new percent(101, "Nancy", 90, 75, 85,
90, 80, 0);
p.showper();
}
}
Output
Student Roll no - 101
Student Name - Nancy
Total marks = 420
Percentage = 84.0
Example3:
 In it, the subclass BoxWeight is used as a superclass to create the subclass called
Shipment.
 Shipment inherits all of the traits of BoxWeight and Box, and adds a field called
cost, which holds the cost of shipping such a parcel.
// Extend BoxWeight to include shipping costs.
// Start with Box.
class Box {
private double width;
private double height;
private double depth;
// construct clone of an object
Box(Box ob)
{
// pass object to constructor
width = ob.width;
height = ob.height;
depth = ob.depth;
}
// constructor used when all dimensions specified
Box(double w, double h, double d)
{
width = w;
height = h;
depth = d;
}
// constructor used when no dimensions specified
Box() {
width = -1; // use -1 to indicate
height = -1; // an uninitialized
depth = -1; // box
}
// constructor used when cube is created
Box(double len)
{
width = height = depth = len;
}
// compute and return volume
double volume()
{
return width * height * depth;
}
}
// Add weight.
class BoxWeight extends Box
{
double weight; // weight of box
// construct clone of an object
BoxWeight(BoxWeight ob)
{
// pass object to constructor
super(ob);
weight = ob.weight;
}
// constructor when all parameters are specified
BoxWeight(double w, double h, double d, double m)
{
super(w, h, d); // call superclass constructor
weight = m;
}
// default constructor
BoxWeight()
{
super();
weight = -1;
}
// constructor used when cube is created
BoxWeight(double len, double m)
{
super(len);
weight = m;
}
}
// Add shipping costs
class Shipment extends BoxWeight {
double cost;
// construct clone of an object
Shipment(Shipment ob)
{
// pass object to constructor
super(ob);
cost = ob.cost;
}
// constructor when all parameters are specified
Shipment(double w, double h, double d,
double m, double c)
{
super(w, h, d, m); // call superclass constructor
cost = c;
}
// default constructor
Shipment()
{
super();
cost = -1;
}
// constructor used when cube is created
Shipment(double len, double m, double c)
{
super(len, m);
cost = c;
}
}
class DemoShipment
{
public static void main(String args[])
{
Shipment shipment1 =
new Shipment(10, 20, 15, 10, 3.41);
Shipment shipment2 =
new Shipment(2, 3, 4, 0.76, 1.28);
double vol;
vol = shipment1.volume();
System.out.println("Volume of shipment1 is " + vol);
System.out.println("Weight of shipment1 is "
+ shipment1.weight);
System.out.println("Shipping cost: $" + shipment1.cost);
System.out.println();
vol = shipment2.volume();
System.out.println("Volume of shipment2 is " + vol);
System.out.println("Weight of shipment2 is "
+ shipment2.weight);
System.out.println("Shipping cost: $" + shipment2.cost);
}
}
Output
Volume of shipment1 is 3000.0
Weight of shipment1 is 10.0
Shipping cost: $3.41
Volume of shipment2 is 24.0
Weight of shipment2 is 0.76
Shipping cost: $1.28

Q. Explain using Abstract classes with help of program (MCS Morning, Fall
2022)
 A class which is declared with the abstract keyword is known as an abstract class
in Java.
 It can have abstract and non-abstract methods (method with the body).
 There are situations in which you will want to define a superclass that declares the
structure of a given abstraction without providing a complete implementation of
every method.
 That is, sometimes you will want to create a superclass that only defines a
generalized form that will be shared by all of its subclasses, leaving it to each
subclass to fill in the details. Such a class determines the nature of the methods
that the subclasses must implement.
 One way this situation can occur is when a superclass is unable to create a
meaningful implementation for a method.
 Consider the class Triangle. It has no meaning if area( ) is not defined. In this
case, you
 want some way to ensure that a subclass does, indeed, override all necessary
methods.
 Java’s solution to this problem is the abstract method.
 You can require that certain methods be overridden by subclasses by specifying
the abstract type modifier.
 These methods are sometimes referred to as subclasser responsibility because
they have no implementation specified in the superclass.
 Thus, a subclass must override them—it cannot simply use the version defined in
the superclass.
 To declare an abstract method, use this general form:
abstract type name(parameter-list);
// Using abstract methods and classes.
abstract class Figure
{
double dim1;
double dim2;
Figure(double a, double b)
{
dim1 = a;
dim2 = b;
}

// area is now an abstract method


abstract double area();
}

class Rectangle extends Figure


{
Rectangle(double a, double b)
{
super(a, b);
}
// override area for rectangle
double area()
{
System.out.println("Inside Area for Rectangle.");
return dim1 * dim2;
}
}

class Triangle extends Figure


{
Triangle(double a, double b)
{
super(a, b);
}
// override area for right triangle
double area()
{
System.out.println("Inside Area for Triangle.");
return dim1 * dim2 / 2;
}
}
class AbstractAreas
{
public static void main(String args[])
{
// Figure f = new Figure(10, 10); // illegal now
Rectangle r = new Rectangle(9, 5);
Triangle t = new Triangle(10, 8);
Figure figref; // this is OK, no object is created
figref = r;
System.out.println("Area is " + figref.area());
figref = t;
System.out.println("Area is " + figref.area());
}
}
Output
Inside Area for Rectangle.
Area is 45.0
Inside Area for Triangle.
Area is 40.0
Chapter 9
Access protection
o We know that access to a private member of a class is granted only to other
members of that class.
o Packages add another dimension to access control.
o Java provides many levels of protection to allow fine-grained control over the
visibility of variables and methods within classes, subclasses, and packages.
o Classes and packages are both means of encapsulating and containing the name
space and scope of variables and methods.
o Packages act as containers for classes and other subordinate packages. Classes
act as containers for data and code.
o The class is Java’s smallest unit of abstraction.
o Because of the interplay between classes and packages, Java addresses four
categories of visibility for class members:
■ Subclasses in the same package
■ Non-subclasses in the same package
■ Subclasses in different packages
■ Classes that are neither in the same package nor subclasses
o The three access specifiers, private, public, and protected, provide a variety of
ways to produce the many levels of access required by these categories. Table
sums up the interactions.
Private No modifier Protected Public

Same class Yes Yes Yes Yes

Same package subclass No Yes Yes Yes

Same package non-subclass No Yes Yes Yes

Different package subclass No No Yes Yes

Different package non-subclass No No no Yes

o While Java’s access control mechanism may seem complicated, we can simplify it
as follows.
o Anything declared public can be accessed from anywhere. Anything declared
private cannot be seen outside of its class.
o When a member does not have an explicit access specification, it is visible to
subclasses as well as to other classes in the same package.
o This is the default access.
o If you want to allow an element to be seen outside your current package, but only
to classes that subclass your class directly, then declare that element protected.
o Table applies only to members of classes.
o A class has only two possible access levels: default and public.
o When a class is declared as public, it is accessible by any other code.
o If a class has default access, then it can only be accessed by other code within
its same package.
Q. Interface:
o Using the keyword interface, you can fully abstract a class’ interface from its
implementation.
o That is, using interface, you can specify what a class must do, but not how it does
it.
o Interfaces are syntactically similar to classes, but they lack instance variables, and
their methods are declared without any body.
o In practice, this means that you can define interfaces which don’t make
assumptions about how they are implemented.
o Once it is defined, any number of classes can implement an interface. Also, one
class can implement any number of interfaces.
o To implement an interface, a class must create the complete set of methods
defined by the interface.
o However, each class is free to determine the details of its own implementation.
o By providing the interface keyword, Java allows you to fully utilize the “one
interface, multiple methods” aspect of polymorphism.
o Interfaces are designed to support dynamic method resolution at run time.
o Normally, in order for a method to be called from one class to another, both
classes need to be present at compile time so the Java compiler can check to
ensure that the method signatures are compatible.
o This requirement by itself makes for a static and nonextensible classing
environment.
o Inevitably in a system like this, functionality gets pushed up higher and higher in
the class hierarchy so that the mechanisms will be available to more and more
subclasses.
o Interfaces are designed to avoid this problem.
o They disconnect the definition of a method or set of methods from the inheritance
hierarchy.
o Since interfaces are in a different hierarchy from classes, it is possible for classes
that are unrelated in terms of the class hierarchy to implement the same interface.
o This is where the real power of interfaces is realized.
Defining an Interface
o An interface is defined much like a class. This is the general form of an interface:
access interface name {
return-type method-name1(parameter-list);
return-type method-name2(parameter-list);
type final-varname1 = value;
type final-varname2 = value;
// ...
return-type method-nameN(parameter-list);
type final-varnameN = value;
}
Implementing Interfaces
o Once an interface has been defined, one or more classes can implement that
interface.
o To implement an interface, include the implements clause in a class definition, and
then create the methods defined by the interface.
o The general form of a class that includes the implements clause looks like this:
access class classname [extends superclass]
[implements interface [,interface...]] {
// class-body
}
Remember: When you implement an interface method, it must be declared as public.

Example:
class Client implements Callback {
// Implement Callback's interface
public void callback(int p) {
System.out.println("callback called with " + p);
}
}

You might also like