KEMBAR78
OOPs Concepts in Java With Examples | PDF | Class (Computer Programming) | Method (Computer Programming)
0% found this document useful (0 votes)
22 views35 pages

OOPs Concepts in Java With Examples

The document provides an overview of Object-Oriented Programming (OOP) concepts in Java, emphasizing principles such as abstraction, encapsulation, inheritance, and polymorphism. It explains the significance of classes and objects, how they relate to real-world entities, and includes examples to illustrate these concepts. Additionally, it discusses coupling in Java, highlighting the differences between tight and loose coupling.
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
22 views35 pages

OOPs Concepts in Java With Examples

The document provides an overview of Object-Oriented Programming (OOP) concepts in Java, emphasizing principles such as abstraction, encapsulation, inheritance, and polymorphism. It explains the significance of classes and objects, how they relate to real-world entities, and includes examples to illustrate these concepts. Additionally, it discusses coupling in Java, highlighting the differences between tight and loose coupling.
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 35

OOPs concepts in Java With Examples |

2023
By Great Learning Team Updated on May 19, 2023 274126
Java, renowned for its simplicity, reliability, and portability, has been a cornerstone in the
programming landscape for decades. With OOPs as its guiding principle, Java empowers
developers to think in terms of real-world objects, encapsulating data and behavior into reusable
building blocks. From the tiniest applications to large-scale enterprise systems, OOPs in Java
paves the way for modular, extensible, and robust software solutions that transcend traditional
procedural programming. So, fasten your seatbelts as we embark on a thrilling journey into the
principles, concepts, and techniques that make OOPs in Java a game-changer in the world of
programming.

What is OOPs Concept?


Object-oriented programming is a core of Java Programming, which is used for designing a
program using classes and objects. OOPs, can also be characterized as data controlling for
accessing the code. In this approach, programmers define the data type of a data structure and the
operations that are applied to the data structure.

What is OOPs in java?


OOps in java is to improve code readability and reusability by defining a Java program
efficiently. The main principles of object-oriented programming are abstraction, encapsulation,
inheritance, and polymorphism. These concepts aim to implement real-world entities in
programs.

List of OOPs Concepts in Java


 Objects
 Classes
 Object
 Class
 Abstraction
 Inheritance
 Polymorphism
 Encapsulation
What are Objects?
Objects are always called instances of a class which are created from a class in java or any other
language. They have states and behaviour.

These objects always correspond to things found in the real world, i.e., real entities. So, they are
also called run-time entities of the world. These are self–contained which consists of methods
and properties which make data useful. Objects can be both physical and logical data. It contains
addresses and takes up some space in memory. Some examples of objects are a dog, chair, tree
etc.

When we treat animals as objects, it has states like colour, name, breed etc., and behaviours such
as eating, wagging the tail etc.

Suppose, we have created a class called My book, we specify the class name followed by the
object name, and we use the keyword new.

Object Example 1:
1
Public class Mybook {
2 int x=10;
3 Public static void main (String args []) {
4 Mybook Myobj= new Mybook ();
5 System.out.println(MyObj.x);
}
6 }
7
In the above example, a new object is created, and it returns the value of x which may be the
number of books.

Mybook Myobj= new Mybook ();

This is the statement used for creating objects.

System.out.println(Myobj.x);

This statement is used to return the value of x of an object.

We can also create multiple objects in the same class and we can create in one class and access it
in another class. This method is used for better organization of classes and always remember that
name of the java file and the class name remains the same.

Example 2:

The below example shows how multiple objects are created in the same class and how they are
accessed from another class.

 Mybook.java
1 Public class Mybook {
2 int x=10;
3 int y=8;
4 }
 Count.java
1
2 Class Count {
Public static void main (String [] args)
3 {
4 Mybook myobj1 = new myobj1();
5 Mybook myobj2 = new myobj2();
6 System.out.println (myobj1.x);
System.out.println (myobj2.y);
7 }
8 }
9
When this program is compiled, it gives the result as 10, and 8 respectively.
What are Classes?
Classes are like object constructors for creating objects. The collection of objects is said to be a
class. Classes are said to be logical quantities. Classes don’t consume any space in the memory.
Class is also called a template of an object. Classes have members which can be fields, methods
and constructors. A class has both static and instance initializers.

A class declaration consists of:

1. Modifiers: These can be public or default access.


2. Class name: Initial letter.
3. Superclass: A class can only extend (subclass) one parent.
4. Interfaces: A class can implement more than one interface.
5. Body: Body surrounded by braces, { }.
A class keyword is used to create a class. A simplified general form of the class definition is
given below:

1
2 class classname {
3 type instance variable 1;
4 type instance variable 2;
5 .
.
6
.
7 type instance variable n;
8 type methodname 1 (parameter list) {
9 // body od method
10 }
type methodname 2 (parameter list) {
11 // body od method
12 }
13 type methodnamen (parameter list) {
14 // body od method
15 }
}
16
17
The variables or data defined within a class are called instance variables. Code is always
contained in the methods. Therefore, the methods and variables defined within a class are called
members of the class. All the methods have the same form as the main () these methods are not
specified as static or public.

What is Abstraction?
Abstraction is a process which displays only the information needed and hides the unnecessary
information. We can say that the main purpose of abstraction is data hiding. Abstraction means
selecting data from a large number of data to show the information needed, which helps in
reducing programming complexity and efforts.
There are also abstract classes and abstract methods. An abstract class is a type of class that
declares one or more abstract methods. An abstract method is a method that has a method
definition but not implementation. Once we have modelled our object using data abstraction, the
same sets of data can also be used in different applications—abstract classes, generic types of
behaviours and object-oriented programming hierarchy. Abstract methods are used when two or
more subclasses do the same task in different ways and through different implementations. An
abstract class can have both methods, i.e., abstract methods and regular methods.

Now let us see an example related to abstraction.

Suppose we want to create a student application and ask to collect information about the student.

We collect the following information.

 Name
 Class
 Address
 Dob
 Fathers name
 Mothers’ names and so on.
We may not require every information that we have collected to fill out the application. So, we
select the data that is required to fill out the application. Hence, we have fetched, removed, and
selected the data, the student information from large data. This process is known as abstraction in
the oops concept.

Abstract class example:

1
2 //abstract parent class
3 Abstract class animal {
4 //abstract method
public abstract void sound ( ) ;
5 }
6 Public class lion extends animal {
7 Public void sound ( ) {
8 System.out.println (“ roar “ );
9 }
public Static void main ( String args [ ] ) {
10 animal obj = new lion ( );
11 obj. sound ();
12 }
13 }
14
Output:
Roar
What is Inheritance?
Inheritance is a method in which one object acquires/inherits another object’s properties, and
inheritance also supports hierarchical classification. The idea behind this is that we can create
new classes built on existing classes, i.e., when you inherit from an existing class, we can reuse
methods and fields of the parent class. Inheritance represents the parent-child relationship. To
know more about this concept check the free inheritance in java course.

For example, a whale is a part of the classification of marine animals, which is part of class
mammal, which is under that class of animal. We use hierarchical classification, i.e., top-down
classification. If we want to describe a more specific class of animals such as mammals, they
would have more specific attributes such as teeth; cold-blooded, warm-blooded, etc. This comes
under the subclass of animals whereas animals come under the superclass. The subclass is a class
which inherits properties of the superclass. This is also called a derived class. A superclass is a
base class or parental class from which a subclass inherits properties.

We use inheritance mainly for method overriding and R:

To inherit a class, we use the extend keyword.

There are five types of inheritance single, multilevel, multiple, hybrid and hierarchical.

 Single level
In this one class i.e., the derived class inherits properties from its parental class. This enables
code reusability and also adds new features to the code. Example: class b inherits properties from
class a.

Class A is the base or parental class and class b is the derived class.

Syntax:

1 Class a {
2 …
3 }
4 Class b extends class a {
5 …
}
6
 Multilevel
This one class is derived from another class which is also derived from another class i.e., this
class has more than one parental class, hence it is called multilevel inheritance.

Syntax:
1
Class a {
2
….
3 }
4 Class b extends class a {
5 ….
6 }
Class c extends class b {
7 …
8 }
9
 Hierarchical level
In this one parental class has two or more derived classes or we can say that two or more child
classes have one parental class.

Syntax:

1
Class a {
2

3 }
4 Class b extends class a {
5 ..
6 }
Class c extends class a {
7 ..
8 }
9
 Hybrid inheritance
This is the combination of multiple and multilevel inheritances and in java, multiple inheritances
are not supported as it leads to ambiguity and this type of inheritance can only be achieved
through interfaces.

Consider that class a is the parental or base class of class b and class c and in turn, class b and
class c are parental or a base class of class d. Class b and class c are derived classes from class a
and class d is derived class from class b and class c.

The following program creates a superclass called add and a subclass called sub, using extend
keyword to create a subclass add.

1 // a simple example of inheritance


//create a superclass
2
Class Add {
3 int my;
4 int by;
5 void setmyby (int xy, int hy) {
6 my=xy;
by=hy;
7 }
8 }
9 /create a sub class
10 class b extends add {
11 int total;
void sum () {
12 public Static void main (String args [ ] ) {
13 b subOb= new b ( );
14 subOb. Setmyby (10, 12);
15 subOb. Sum ( ) ;
16 System.out.println(“total
}
=” + subOb. Total);
17 }
18
19
20
21
It gives output as – total = 22

What is Polymorphism?
Polymorphism refers to many forms, or it is a process that performs a single action in different
ways. It occurs when we have many classes related to each other by inheritance. Polymorphism
is of two different types, i.e., compile-time polymorphism and runtime polymorphism. One of
the examples of Compile time polymorphism is that when we overload a static method in java.
Run time polymorphism also called a dynamic method dispatch is a method in which a call to an
overridden method is resolved at run time rather than compile time. In this method, the
overridden method is always called through the reference variable. By using method overloading
and method overriding, we can perform polymorphism. Generally, the concept of polymorphism
is often expressed as one interface, and multiple methods. This reduces complexity by allowing
the same interface to be used as a general class of action.

Example:

1 public class Bird {


2 …
3 Public void sound ( ) {
System.out.println ( “ birds sounds “ );
4 }
5 }
6 public class pigeon extends Bird {
7 …
@override
8 public void sound ( ) {
9 System.out.println( “ cooing ” ) ;
10 }
11 }
12 public class sparrow extends Bird ( ) {
….
13 @override
14 Public void sound ( ){
15 System.out.println( “ chip ” ) ;
16 }
17 }
18
19
20
In the above example, we can see common action sound () but there are different ways to do the
same action. This is one of the examples which shows polymorphism.

Polymorphism in java can be classified into two types:

1. Static / Compile-Time Polymorphism


2. Dynamic / Runtime Polymorphism
What is Compile-Time Polymorphism in Java?

Compile-Time polymorphism in java is also known as Static Polymorphism. to resolved at


compile-time which is achieved through the Method Overloading.

What is Runtime Polymorphism in Java?

Runtime polymorphism in java is also known as Dynamic Binding which is used to call an
overridden method that is resolved dynamically at runtime rather than at compile time.

What is Encapsulation?
Encapsulation is one of the concepts in OOPs concepts; it is the process that binds together the
data and code into a single unit and keeps both from being safe from outside interference and
misuse. In this process, the data is hidden from other classes and can be accessed only through
the current class’s methods. Hence, it is also known as data hiding. Encapsulation acts as a
protective wrapper that prevents the code and data from being accessed by outsiders. These are
controlled through a well-defined interface.

Encapsulation is achieved by declaring the variables as private and providing public setter and
getter methods to modify and view the variable values. In encapsulation, the fields of a class are
made read-only or write-only. This method also improves reusability. Encapsulated code is also
easy to test for unit testing.

Example:

class animal {
1 // private field
2 private int age;
3 //getter method
4 Public int getage ( ) {
5 return age;
}
6 //setter method
7 public void setAge ( int age ) {
8 this. Age = age;
}
9 }
10 class Main {
11 public static void main (String args []);
12 //create an object of person
13 Animal a1= new Animal ();
//change age using setter
14 A1. setAge (12);
15 // access age using getter
16 System.out.println(“ animal age is ” + a1. getage ( ) );
17 }
}
18
19
20
21
22
Output: Animal age is 12

In this example, we declared a private field called age that cannot be accessed outside of the
class.

To access age, we used public methods. These methods are called getter and setter methods.
Making age private allows us to restrict unauthorized access from outside the class. Hence this is
called data hiding.

Coupling in Java
Coupling refers to the relationship between two classes. It indicates the knowledge one object or
class has of another. That means that if one class changes its properties or behaviour, it will
affect the dependent changes in the other class. Therefore, these changes will depend upon the
level of interdependence the two classes have between them. There are two types of coupling,
namely tight coupling, and loose coupling.

 Tight coupling: If one class is strongly interrelated to another class, it is said to have a tight coupling with that class.
public class College{

public void status() {

System.out.println("College is open today");

}
public class Student{

College obj = new College();

public void goToCollege() {

obj.status();

In the above code example, the student class is dependent on the college class. That is, any
change in the college class requires student classes to change. Here, therefore, student class and
college class are tightly coupled with each other.

 Loose coupling: If one class is weakly interrelated to another class, it is said to have loose coupling with that class. Loose
coupling is preferred over tight coupling. A class can achieve this with the help of interfaces, as shown below.
public interface College{

void status();

class CollegeStatus1 implements College{

public void status() {

System.out.println("College is open monday to friday");

class CollegeStatus2 implements College{

public void status() {

System.out.println("College is open on saturday");

}
}

public class Student{

College obj = new CollegeStatus1();

public void goToCollege() {

obj.status();

In the above code example, CollegeStatus1 and CollegeStatus2 are loosely coupled. Here,
student class is not directly or tightly coupled with a CollegeStatus1 or CollegeStatus2 class. By
applying a dependency injection mechanism, the loose coupling implementation is achieved to
allow a student to go to college with any class which has implemented a college interface. In
addition, it means we can use CollegeStatus2 whenever the college is open on Saturday.

Cohesion in Java
Java Cohesion measures how the methods and the attributes of a class are meaningfully and
strongly related to each other and how focused they are on performing a single well-defined task
for the system. This is used to indicate the degree to which a class has a single, well-focused
responsibility. More cohesive classes are good to keep them for code reusability. Low cohesive
classes are difficult to maintain as they have a less logical relationship between their methods
and properties. It is always better to have highly cohesive classes to keep them well focused for a
single work.

 Low Cohesion: In the following code, we have a class called Book. But it is less cohesive because it comprises less focussed
and independent attributes and methods to the class. This class should contain information related to the Book. Therefore, the
person’s name and age method are making this classless cohesive.
class Book{

int price = 299; //related attribute

String name = "Sam"; //unrelated attribute

//related methods to Book class

public String author(String name) {


return name;

public String title(String subject) {

return subject;

public int id(int number) {

return number;

//unrelated methods to Book class

public int age(int age) {

return age;

 High Cohesion: When the class has a single well-defined purpose or task, it is said to be highly cohesive. So, in the above
example code, if we remove the information related to the person, then the class becomes highly cohesive, as shown below.
class Book{

int price = 299; //related attribute

//related methods to Book class

public String author(String name) {

return name;

}
public String title(String subject) {

return subject;

public int id(int number) {

return number;

Association in Java
Association is a relation between two separate classes that establishes with the help of their
Objects. It specifies the relationship between two or more Objects. Association can be one-to-
one, one-to-many, many-to-one, and many-to-many. Let us understand this with real-world
examples, suppose the relationship between the bus and the passengers. A bus can have only one
driver(one-to-one). Many passengers can associate with the single bus(many-to-one). A single
passenger can associate with many different buses(one-to-many). Also, many passengers can
associate with the many different buses(many-to-many). One object is associated with another
object to use the functionality and services provided by another object.

Consider the following code below:

//class bus

class Bus

private String name;

// bus name

Bus(String name)

{
this.name = name;

public String getBusName()

return this.name;

//passenger class

class Passenger

// passenger name

private String name;

// passenger seat id number

private int seatId;

Passenger(String name, int seatId)

this.name = name;

this.seatId = seatId;

}
public String getPassengerName()

return this.name;

public int getPassengerId()

return this.seatId;

//Association between both the

//classes in the main method

class Demo

public static void main (String[] args)

Bus bus = new Bus("Shree Travels");

Passenger psg = new Passenger("Sneha", 52);

System.out.println(psg.getPassengerName() + " with seat number " + psg.getPassengerId()

+ " is a passenger of " + bus.getBusName());


}

Output:

Sneha with seat number 52 is a passenger of Shree Travels

Explanation:

In the above example, two separate classes Bus and Passenger, are associated through their
Objects inside the class Demo. In this way, we can establish the relationship between two
different classes by using the concept of association. A bus can have many passengers, So it is a
one-to-many relationship.

Association is of two types, they are:


1. Aggregation
2. Composition

Let’s discuss the two in detail.

Aggregation
Java Aggregation is a weak association and represents a relationship between an object
containing other objects. This represents a part of a whole relationship where a part can exist
without a whole. Let’s take an example of the relationship between Group and Person. A Person
may belong to multiple Groups. Hence a Group can have multiple Persons. But if we delete a
Group, the Person object will not destroy. Aggregation represents the Has-A relationship,
unidirectional association, i.e., a one-way relationship. For instance, the group can have persons,
but vice versa is not possible and thus unidirectional. In this section, both entries can survive
individually, which means ending one entity will not affect the other entity. Hence, both objects
are independent in aggregation.

Considering the following code example:

import java.util.*;

//person class
class Person

private String name;

private int age ;

Person(String name, int age)

this.name = name;

this.age = age;

public String getName() {

return name;

public int getAge() {

return age;

/* Group class contains the list of person

Objects. It is associated with the person

class through its Object(s). */


//group class

class Group

private String groupName;

private List<Person> persons;

Group(String groupName, List<Person> persons)

this.groupName = groupName;

this.persons = persons;

//main method

class Demo

public static void main (String[] args)

//creating objects of person class

Person a = new Person("Tanmay", 17);


Person b = new Person("Sam", 18);

Person c = new Person("Pitu", 19);

Person d = new Person("Khushi", 20);

//making a list of persons belongs to social welfare group

List<Person> p1 = new ArrayList<>();

p1.add(a);

p1.add(c);

//making a list of persons belongs to drama fest group

List<Person> p2 = new ArrayList<>();

p2.add(b);

p2.add(d);

//creating objects of group class

Group swGrp = new Group("Social Welfare", p1);

Group dfGrp = new Group("Drama Fest", p2);

//before deleting drama fest group

System.out.println("List of persons in Drama Fest group:");

for(Person p : p2) {

System.out.println("Person name: " + p.getName() + ", Age:" + p.getAge() + ", Group: Drama
Fest");

//deleting drama fest group


dfGrp = null;

//after deleting drama fest group

//person list will not destroy

System.out.println("List of persons after deleting Drama Fest group:");

for(Person p : p2) {

System.out.println("Person name: " + p.getName() + ", Age: " + p.getAge());

Output:

List of persons in Drama Fest group:

Person name: Sam, Age:18, Group: Drama Fest

Person name: Khushi, Age:20, Group: Drama Fest

List of persons after deleting Drama Fest group:

Person name: Sam, Age: 18

Person name: Khushi, Age: 20

Explanation:

Here, we can see that the two classes Person and Group, are associated with each other with the
help of objects. There are two groups social welfare and drama fest. We created these groups by
using the person class. The group has a list of persons. We have two people Sam and Khushi, in
the Drama Fest group as shown in the output. Afterwards, we deleted this group by setting the
instance of group equals to null. But, our list of persons remains undestroyed due to the weak
association, i.e., aggregation, even after the group was deleted.
Composition in Java
Java Composition is an association that represents a part of a whole relationship where a part
cannot exist without a whole. Let’s take an example of the relationship between School and
Room. The school object consists of several rooms. Whenever the school object destroys
automatically, all the room objects will be destroyed, i.e., without the existing school object,
there is no chance of an existing dependent object. So these are strongly associated, and this
relationship is called composition. If a whole is deleted, then all parts are deleted. So
composition represents the part-of relationship.

Whenever there is a composition between two entities, the created object cannot exist without
the other object. Thus, in composition, both entities are dependent on each other.

Consider the following code example:

import java.util.*;

// activity room class

class ActivityRoom {

public String subject;

public int id;

ActivityRoom(String subject, int id)

this.subject = subject;

this.id = id;

}
// department class

class Department {

private String name;

//list of activity rooms in a department.

private List<ActivityRoom> ar;

Department(List<ActivityRoom> ar)

this.ar = ar;

// Getting total number of colleges

public List<ActivityRoom> getActivityRoomsInDepartment()

return ar;

class Demo {

public static void main(String[] args)

// Creating the Objects of activity room class.


ActivityRoom a1 = new ActivityRoom("Technical", 601);

ActivityRoom a2 = new ActivityRoom("Business", 602);

ActivityRoom a3 = new ActivityRoom("Economics", 603);

// making the list of activity rooms.

List<ActivityRoom> act = new ArrayList<ActivityRoom>();

act.add(a1);

act.add(a2);

act.add(a3);

// Creating the Object of department class.

Department d = new Department(act);

// making the list of activity rooms in department.

List<ActivityRoom> arlist = d.getActivityRoomsInDepartment();

for (ActivityRoom a : arlist) {

System.out.println(a.subject + " activity room with id " + a.id);

}
}

Output:

Technical activity room with id 601

Business activity room with id 602

Economics activity room with id 603

Explanation:

Here we have two classes Activity room and Department. A department composed of different
subject activity rooms. So, If the department gets destroyed, then All activity rooms within that
department will be destroyed, i.e., the activity room can not exist without the department. That’s
why it is composition.

Methods in Java
Java method is a block of code or collection of statements grouped together to complete a certain
job or operation. This is used to achieve the reusability of code and can be utilized many times. It
also gives easy modification and readability of code. A method is executed only when we call or
invoke it. We have two categories of methods in java, i.e., pre-defined and user-defined.
Predefined methods are the methods that are already defined in the Java class libraries. When a
particular method is written by the user or programmer, it is known as a user-defined method.
User-defined methods can be modified according to the requirement.

Let’s discuss:

 Static method in Java


 The abstract method in Java
 Finalize method in Java
 Equals method in Java
Static Method in Java

A method that has the static keyword in the declaration is known as the static method. In other
words, a method that belongs to a class rather than an instance of a class is known as a static
method. We can also create a static method by using the keyword static before the method name.
The main benefit of a static method is that we can invoke the static method without even creating
an object. It can access static data members and also change their values and is also used to
create an instance method. The main() method is a common example of the static method.
Example:

public class Demo

public static void main(String[] args)

displaymethod();

static void displaymethod()

System.out.println("It is an example of static method.");

Output:

It is an example of a static method.

Abstract Method in Java

A method that is declared with keyword abstract is called an abstract method. The abstract
method does not have an implementation or body, or block of code. The abstract method must
always be declared in an abstract class, or we can say that if a class has an abstract method, it
should be declared abstract. If a class has an abstract method, it should be declared abstract, but
vice versa is not true, which means that an abstract class doesn’t need to have an abstract method
compulsory. Also, If a normal class extends an abstract class, then the class must have to
implement all the abstract parent class’s abstract methods, or it has to be declared abstract.

Example:

//abstract class area


abstract class Area{

/* These two are abstract methods, the child class

* must implement these methods

*/

public abstract int areaSquare(int s);

public abstract int areaRectangle(int l, int b);

//Normal method

public void display(){

System.out.println("Normal method in abstract class Area");

//Normal class extends the abstract class

class Demo extends Area{

/* If we don't provide the implementation of these two methods, the

* program will throw compilation error.

*/

public int areaSquare(int s){

return s*s;

}
public int areaRectangle(int l, int b){

return l*b;

public static void main(String args[]){

Area a = new Demo();

System.out.println("Area of square " + a.areaSquare(9));

System.out.println("Area of rectangle " + a.areaRectangle(3,4));

a.display();

Output:

Area of square 81

Area of rectangle 12

The normal method in abstract class Area

Final Method in Java

A method that is declared final is called a final method. We cannot override a final method. This
means the child class can still call the final method of the parent class without any problem, but
it cannot override it. This is because the main purpose of making a method final is to stop the
modification of the method by the sub-class.

Example:

class DemoParent{

final void method(){


System.out.println("Parent class final method");

class Demo extends DemoParent{

//error

void method(){

System.out.println("final method modified inside child class");

public static void main(String args[]){

Demo d = new Demo();

d.method();

The above code will throw an error as we are trying to modify the final method inside the child
class(demo) of the parent class(demoParent).

Instead of modifying the method, we can use it as shown below:

class DemoParent{

final void method(){

System.out.println("Parent class final method");


}

class Demo extends DemoParent{

public static void main(String args[]){

Demo d = new Demo();

d.method();

Output:

Parent class final method

Equals Method in Java

As the name suggests in java, .equals() is a method used to compare two objects for equality. The
.equals() method in java is used to check if the two strings have similar values. It checks them
character by character. One should not confuse .equals() method with == operator. The String
equals() method compares the two given strings based on the content of the string, whereas the
== operator is used for address comparison. If all the contents of both the strings are the same,
then .equals() returns true otherwise, it returns false. If all characters are not matched, then it
returns false.

Let us understand this with the help of an example:

public class Demo {

public static void main(String[] args)

String s1 = "GreatLearning";
String s2 = "GreatLearning";

String s3 = new String("GreatLearning");

System.out.println(s1 == s2); // true

System.out.println(s1 == s3); // false

System.out.println(s1.equals(s2)); // true

System.out.println(s1.equals(s3)); // true

Even though s1 and s3 are created with the same field(content), they are pointing to two different
objects in memory. Hence at different addresses. Therefore == operator gives false and .equals()
method gives true as both contain similar content greatLearning.

Message Passing in Java


Message Passing in terms of computers is a communication phenomenon between the processes.
It is a kind of communication used in object-oriented programming. Message passing in Java is
the same as sending an object, i.e., a message from one thread to another thread. It is utilized
when threads do not have shared memory and are not able to share monitors or any other shared
variables to communicate. In message passing calling program sends a message to a process and
relies on that process to run its own functionality or code. Message passing is easy to implement,
has faster performance, and we can build massive parallel models by using it.

There are two types of it: Synchronous and Asynchronous.

 Synchronous message passing occurs when the objects run at the same time.
 In the case of an Asynchronous message passing, the receiving object can be down or busy when the requesting object sends
the message.

Can Polymorphism, Encapsulation and Inheritance work


together?
When we combine inheritance, polymorphism and encapsulation to produce a programming
environment, this environment supports the development of far more robust and scalable
programs that do the program-oriented model. A well-designed or model of the hierarchy of
classes is the basis for reusing the code in which we have spent our time and effort developing
and testing. Encapsulation allows us to migrate our implementations over time without breaking
that code which depends on our classes’ public interfaces. Polymorphism allows us to create
readable, clean, sensible code.

As we know, it is through the applications of encapsulation, polymorphism and inheritance that


individual parts are transformed into an object; for example, it may be a car, mobile phone etc.
This is true in the case of computer programs. Through object-oriented principles, the various
parts of complex programs are brought together to form a cohesive, robust, maintainable whole.

Many of the features supplied by java are part of its built-in class libraries which do use
encapsulation, polymorphism, and inheritance extensively.

Let us consider a real-world example. Humans are a form of inheritance from one standpoint,
whereas cars are more like programs we write. All drivers rely on inheritance to drive different
types of vehicles. People interface with the features of cars of all types as we have many
different types of vehicles, and some have differences. The implementation of engines, brakes
etc., comes under encapsulation and finally comes to polymorphism. We get a wide area of
options on the same vehicle as to the anti-lock braking system, traditional braking system or
power braking system. The same vehicle as many forms of the braking system is called
polymorphism. This example shows us how encapsulation, inheritance and polymorphism are
combined.

Advantages of OOPs Concept


Some of the advantages are:

 Re-usability
When we say re-usability, it means that “write once, use it multiple times” i.e., reusing some
facilities rather than building it again and again, which can be achieved by using class. We can
use it n number of times whenever required.

 Data redundancy
It is one of the greatest advantages in oops. This is the condition which is created at the data
storage when the same piece of data is held at two different places. If we want to use similar
functionality in multiple classes, we can just write common class definitions for similar
functionalities by inheriting them.

 Code maintenance
It is easy to modify or maintain existing code as new objects which can be created with small
differences from the existing ones. This helps users from doing rework many times and
modifying the existing codes by incorporating new changes to it.
 Security
Data hiding and abstraction are used to filter out limited exposure which means we are providing
only necessary data to view as we maintain security.

 Design benefits
The designers will have a long and more extensive design phase, which results in better designs.
At a point of time when the program has reached critical limits, it will be easier to program all
non-oops separately.

 Easy troubleshooting
Using encapsulation objects is self-constrained. So, if developers face any problem easily it can
be solved. And there will be no possibility of code duplicity.

 Flexibility
 Problem-solving

Disadvantages of OOPs Concept


 Effort – A lot of work is put into creating these programs.
 Speed – These programs are slower compared to other programs.
 Size – OOPs programs are bigger when compared to other programs.

Differences between Object-Oriented Programming,


Procedural Oriented Programming?

Object-oriented programming Procedure oriented programming

It is object-oriented. It is structured and oriented.

It follows a bottom-up approach. It is divided into small parts called functions.

These are divided into small parts called objects. It follows a top-down approach.

These have specifiers like public, private, and protected. There are no access specifiers.

Adding new functions or data is easy. Adding new data and functions is not easy.
It provides data hiding and it is more secure. This is less secure.

Overloading is possible. Overloading is not possible.

Examples are c++, java, python etc. Examples FORTRAN, Cobol etc.

You can learn more about oops concepts by taking a free course in oops concepts in C++.

Difference between an object-oriented programming language and an object-


based programming language?

An object-based programming language is a An object-oriented programming language is a


language that allows the creation of objects but language that supports the programming paradigm
does not support the full range of features of an of object-oriented programming, which is based
object-oriented programming language. on the concept of objects.

OOps in Java FAQ


What are the OOPS concepts in Java?
OOPs stands for Object-oriented programming. OOPs in Java organizes a program around the
various objects and well-defined interfaces. The OOPs Concepts in Java are abstraction,
encapsulation, inheritance, and polymorphism. These concepts aim to implement real-world
entities in programs.

What are the 4 basics of OOP?


The four basics of OOP are abstraction, encapsulation, inheritance, and polymorphism. These are
the main ideas behind Java’s Object-Oriented Programming.

What are the OOPS concepts in Java with examples?


OOPs, concepts in Java is known as object-oriented programming System. The following is a list
of the OOPs concepts in Java with examples:
1. Class
2. Object
3. Inheritance
4. Polymorphism
5. Abstraction
6. Encapsulation
7. association
8. Aggression
9. Composition
What explains the concept of Oops?
OOPs, help in creating a working method and variable that can be reused without compromising
on security. The emphasis of OOPs concepts is on data rather than on functions and is mainly
used in different object-oriented programming languages such as Java, C#, C++, Python, Perl,
Ruby, etc.

What are the main features of OOPs?


The main features of OOPs concepts in Java are Classes, Objects, Encapsulation, Data
Abstraction, Polymorphism, and Inheritance.

Why are OOPs concepts used?


The reason for using OOPs concepts in Java is to implement various real-world entities such as
polymorphism, abstraction, inheritance, etc., into programming. Another reason to use this is to
ensure the security of code by binding together the data and functions.

What are the advantages of OOPs?


There are several benefits of implementing OOPs Concepts in Java. A few of the major
advantages are as follows: Reusability, Code maintenance, Data Redundancy, Security, Easy
troubleshooting, Problem-Solving, Flexibility and Design Benefits. Java OOPs Concepts are one
of the core development approaches that is widely accepted.

What is polymorphism in OOPs?


In OOPs, Polymorphism is the process that allows us to perform a single action in multiple ways.
This occurs when there are several classes related to each other through inheritance. In
polymorphism, there are two types. Namely, compile-time polymorphism and runtime
polymorphism. It helps us in reducing complexity.

You might also like