Skip to main content

Object Oriented Programming (OOP) concept in Java | Programming blog

OOPs Concept in java programming

What is object oriented programing (OOP) in Java

OOP :- OOP refers as Object Oriented Programming. OOP is a concept that is based on objects. As a name suggests it is Object oriented. Java is Object oriented programming language. 

There are mainly four concepts in java :-

  1. Abstraction
  2. Encapsulation
  3. Inheritance
  4. Polymorphism

Let's discuss all of above one by one.

1. Abstraction :-

In simple term, Abstraction means hiding complexity and showing essential details to the user. Means using the things without knowing background details about it. 

Abstraction is the technique of hiding implementation.

Like, we use smartphone very efficiently and easy way, we don't need background details how it works. we simply use.

Why should we use Abstraction?

  • Reduce complexity
  • Force users to extend implementation rather than modify
  • Support cross platform by changing the implementation per platform

In Java, we can use abstraction in two ways :-

  1. Using Abstract class
  2. Using Interface
Learn more about Abstract class and Interface
 

2. Encapsulation

Encapsulation means wraps variables or functions into single unit. means we can create private fields in class so any other class can not access its data. 

In encapsulation, data in a class is hidden for another classes, so it is also known as data-hiding.

For use private variables we can use public getter and setter method in that class. so we can access private variables.

Example of encapsulation

Encapsulation in java

Why we should use Getter and Setter methods?

This question confuse every new programmer who learn Encapsulation in oops. 

Why we should use getter and setter methods if we can directly access and use variable using defining public? Why we use getters and setters?

So, simple answer is we set limit in variable access using getter and setter methods. Like if anyone wants to get or set above name variable then there is only one option using getName() and setName() method.

Another main use of getter and setter, that we can put any validation in these methods. like in above example if we want to set name that is not have greater than 10 length. so we can easily add these type of validation in above method. so, anyone who want to set name then they must have to set name in less than 10 length.

3. Inheritance 

Inheritance means use the properties of one class to another class. Inheritance provides ides of reusability of code. 

extends keyword is used for access base or parent class properties in child or sub class.

Subclass defines own unique properties as well as extends another class ( parent class or base class ) and uses its properties. this is done by inheritance.

There is two class Student and Teacher that have common properties like name, DOB, department, etc. Student have some unique properties like student id, college fee, scholarship, etc. and Teacher have salary, teacher id, etc. so we can define another class that have common properties and extends that class into Student and Teacher class.

So, lets see simple example of inheritance.

public class OOPLanguage {

    public void OOP() {
        System.out.println("Object Oriented Programming");
    }  

public class Java extends OOPLanguage {

    public static void main(String[] args) {
       
        Java javaObj = new Java();
        javaObj.OOP();
       
    }
}

Output :-
Object Oriented Programming

4. Polymorphism

Polymorphism means there is two or more method whose name are same but its parameters are different.

Polymorphism means perform more than one action using single unit.

In java, we can perform polymorphism in two ways.

  1. Compile time polymorphism or static binding
  2. Run time polymorphism or dynamic binding

1. Compile time polymorphism

It is also knows as Method Overloading in java. Method overloading means there is same method name but different parameters in same class. 

In compile time polymorphism, which method is call decides at compile time.

public class ClassOne{
       
        public void print() {
            System.out.println("Class one");
        }

        public void print(String str) {
            System.out.println("Class one" + str);
        }

 }
 

2. Run time polymorphism

It is also known as Method Overriding in java. Method overriding means same method name and different parameters in same class.

public class ClassOne{
    
    public void print() {
        System.out.println("Class one");
    }

}

public class ClassTwo {
    
    public void print() {
        System.out.println("Class two");
    }

}

In run time polymorphism, which method is call decide at run time.

Other articles you may like :-

Comments

Popular posts from this blog

Queen's Attack II HackerRank Solution in Java with Explanation

Queen's Attack II Problem's Solution in Java (Chessboard Problem)   Problem Description : You will be given a square chess board with one queen and a number of obstacles placed on it. Determine how many squares the queen can attack.  A queen is standing on an n * n chessboard. The chess board's rows are numbered from 1 to n, going from bottom to top. Its columns are numbered from 1 to n, going from left to right. Each square is referenced by a tuple, (r, c), describing the row r and column c, where the square is located. The queen is standing at position (r_q, c_q). In a single move, queen can attack any square in any of the eight directions The queen can move: Horizontally (left, right) Vertically (up, down) Diagonally (four directions: up-left, up-right, down-left, down-right) The queen can move any number of squares in any of these directions, but it cannot move through obstacles. Input Format : n : The size of the chessboard ( n x n ). k : The number of obstacles...

Sales by Match HackerRank Solution | Java Solution

HackerRank Sales by Match problem solution in Java   Problem Description : Alex works at a clothing store. There is a large pile of socks that must be paired by color for sale. Given an array of integers representing the color of each sock, determine how many pairs of socks with matching colors there are. For example, there are n=7 socks with colors socks = [1,2,1,2,1,3,2]. There is one pair of color 1 and one of color 2 . There are three odd socks left, one of each color. The number of pairs is 2 .   Example 1 : Input : n = 6 arr = [1, 2, 3, 4, 5, 6] Output : 0 Explanation : We have 6 socks with all different colors, So print 0. Example 2 : Input : n = 10 arr = [1, 2, 3, 4, 1, 4, 2, 7, 9, 9] Output : 4 Explanation : We have 10 socks. There is pair of color 1, 2, 4 and 9, So print 4. This problem easily solved by HashMap . Store all pair of socks one by one in Map and check if any pair is present in Map or not. If pair is present then increment ans variable by 1 ...