KEMBAR78
Java Tutorial | PDF | Constructor (Object Oriented Programming) | Programming
0% found this document useful (0 votes)
35 views30 pages

Java Tutorial

The document provides a comprehensive Java tutorial covering key concepts such as switch-case statements, looping statements (for, while, do-while), arrays, methods, and object-oriented programming principles. It includes syntax examples, workflows, and sample code for various operations like calculating sums, checking for prime numbers, and creating patterns. Additionally, it discusses dynamic reading of user input using the Scanner class and provides examples of common programming tasks in Java.
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)
35 views30 pages

Java Tutorial

The document provides a comprehensive Java tutorial covering key concepts such as switch-case statements, looping statements (for, while, do-while), arrays, methods, and object-oriented programming principles. It includes syntax examples, workflows, and sample code for various operations like calculating sums, checking for prime numbers, and creating patterns. Additionally, it discusses dynamic reading of user input using the Scanner class and provides examples of common programming tasks in Java.
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/ 30

Java Tutorial

Switch Case:
Syntax:
Switch(variable/value/expression) {
Case lable1: {
//instructions
} Break;
Case lable2: {
//instructions
} break;
……..
Default:
//instructions
}

Workflow:
1. First the value/expression passed inside the switch will be compared written inside the
switch block.
2. Whichever case matches with the value/expression passed, that case will be executed.
3. If no case matches then directly default block will be executed.

Note: In switch we cannot pass float, double or long type of data. In case label we cannot
pass variables.

Ex:
package Tutorial;

public class Switch_case {


public static void main(String[] args) {
int num=20;
switch(num){
case 10:{
System.out.println("10 matched");
break;
}
case 20:{
System.out.println("20 matched");
break;
}
default:
System.out.println("not matched");
}
}
}

Looping Statement:
Looping statement are used to perform some task repeatedly.
These are 4 types of looping statements.
1. For loop
2. Do while
3. While loop
4. For each loop

While loop:
Syntax:
While(condition) {
//instructions
Updation (optional)
}

Workflow:
1.First it will check the condition, if condition is true then the control will go, inside the while
block and it will be executed.
2.It will be executed until the condition is false.
3.Once the condition is false, loop will be terminated.

Ex:
package Tutorial;

public class Whilel_oop {


public static void main(String[] args) {
int i=0;
while(i<5){
System.out.println("Pruthvi");
i++;
}
}
}
Increment Operator (++)
Its is used to increase the value to +1.
Decrement (--)
It’s used to decrease the value by-1.

Do While Loop:
Syntax:
Do {
//instructions
Updation(coptional)
} While (condition);

Workflow:
1. First it will excecute the do block

For Loop:
Syntax: For (initilaization;condition;updation){
//statements}

Workflow:
1.initilaization of the variable
2.It will check the condition, if the condition is true it will execute the instructions written
inside the block.
3.It will go for updating after the updating again it will check the condition.
4.If the condition is true, it will execute the block.
5Once the condition is false it will terminate the block.
Print numbers in reverse order
package Tutorial;

public class Even_odd {


public static void main(String[] args) {
for (int i = 10; i>=1; i--) {
System.out.println(i);
}
}
}
Print sum of numbers from 1 to 5
public class New {
public static void main(String[] args) {
int start = 1, end = 5;
int sum = 0;

// Loop from start to end and add numbers


for (int i = start; i <= end; i++) {
sum += i;
}

// Print the sum of numbers


System.out.println(sum);
}
}
Print sum of odd and even numbers from 1 to 10

public class Sum_odd_even {


public static void main(String[] args) {
int a=1, b=10, sume=0, sumo=0;
for(int i=1;i<=10;i++){
if(i%2==0){
sume=sume+i;
}else{
sumo=sumo+i;
}
}
System.out.println(sume);
System.out.println(sumo);
}
}
Extracting and Removing last digit for given number
public class Last_digit {
public static void main(String[] args) {
int a=268,b=586;
System.out.println(a%10);
System.out.println(a/10);

}
}
Assessment:
1.Count total number of digits present in number
public class Count_digit {
public static void main(String[] args) {
String num="7522566";
System.out.println(num.length());
}
}

2.Check whether the given alphabet is in upper case or lower case


public class Upper_lower {
public static void main(String[] args) {
char ch = 'P'; // Initialize ch correctly

if (ch >= 'a' && ch <= 'z') { // Corrected if condition


System.out.println("Lower Case "+ch);
}
if (ch >= 'A' && ch <= 'Z') { // Corrected if condition
System.out.println("Upper Case "+ch);
}
}
}

3.Reverse the number.


4.Check whether the number is palindrome or not.
Dynamic read Class:
The process of accepting the data from the user at the time of execution of the program is
known as dynamic read.
Scanner Class:
It is predefined class present in java.util package.
It provides several methods to accept the data.
Data Type Method Signature Description
Byte nextByte() It returns Byte type of data.
Short nextShort() It returns Short type of data.
Int nexrtInt() It returns Int type of data.
Long nextLong() It returns Long type of data.
Float nextFloat() It returns Float type of data.
Double nextDouble() It returns Double type of data.
Char Next().CharAt(0) It returns Char type of data.
Boolean nextBoolean() It returns Boolean type of data.
String Next() It accepts Single String/up to space.
String nextLine() It accepts whole line of String.

Steps to achieve dynamic read.


1.Import scanner Class
Import Scanner.util.Scanner();
2.Create object of Scanner Class
Scanner name=new Scanner(Systen.in);
3.Cell Scanner class method as per the type of data
Ex-Sacanner sc=new Scanner(System.in);
Int num=nextInt();

Ex: For Scanner Class


import java.util.*;
public class Scanner_class {
public static void main(String[] args) {
int sum;
Scanner sc=new Scanner (System.in);
System.out.println("enter 1st operand");
int x =sc.nextInt();
System.out.println("enter 2nd operand");
int y =sc.nextInt();
sum=x+y;
System.out.println("addition of two operand is "+sum);
}
}

Palindrome Number:
import java.util.*;
public class Num_reverse {
public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
System.out.println("enter a number ");
int num=sc.nextInt();
int num2=num;
int reverse=0;
while(num>0) {
int rem= num%10;
reverse= reverse * 10 + rem;
num = num / 10;
}
if(reverse==num2){
System.out.println("Palindrome");
}
else{
System.out.println("Not a Palindrome");
}
}
}

Array:
Array is a continuous block of memory which can be logically divided into multiple parts to
store the multiple data.
Array is homogeneous  Inside array we can store only same type of data.
The size of array will be fixed and it cannot be changed during the time of execution.
Array Creation:
Syntax: data_type[] name=new data_type[size];
Ex: int arr[]=new int[5];
Array Initialization:
To initialize the array ,it needs the index of the element.
Index is an integer value which starts from 0 and it ends on size 1.
Int[] arr=new int[5];
Arr[0]=10;
Arr[1]=11;
Arr[2]=12;
Arr[3]=13;
Ar[4]=14;
Ex:
package Array_Programs;

public class Array_demo {


public static void main(String[] args) {
int[] arr = new int[5];
arr[0] = 10;
arr[1] = 11;
arr[2] = 12;
arr[3] = 13;
arr[4] = 14;
for (int i=0;i<arr.length;i++){
System.out.println(arr[i]);
}
}
}
Array Syntax for values:
Data_type[] name={val1,val2,val3,…..,val n};
Int [] arr={10,11,12,13,14};

Ex for Array:
package Array_Programs;
import java.util.*;
public class Array_Scanner {
public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
System.out.println("enter size of array");
int size=sc.nextInt();
int [] arr=new int[size];
for(int i=0;i<arr.length;i++){
System.out.println("enter "+i+"Index element");
arr[i]=sc.nextInt();
}
for(int i=0;i<arr.length;i++){
System.out.println("array elements are "+arr[i]);
}
}
}

Factors of the number:


package Array_Programs;

import java.util.Scanner;

public class Factor_num {


public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.println("Enter a number:");
int num = sc.nextInt();
System.out.println("Factors of " + num + " are:");
for (int i = 1; i <= num; i++) {
if (num % i == 0) {
System.out.println(i);
}
}
}
}

Factorial of the number.


package Array_Programs;

import java.util.Scanner;

public class Fact_num {


public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
int num=sc.nextInt();
int fact=1;
if(num==0||num==1){
System.out.println("factorial is"+fact);
}
else{
for (int i=1;i<=num;i++)
fact*=i;
System.out.println("Factorial is "+fact);
}
}
}
Method Returning Data:
Steps:
1.We have to provide return statements.
2.The return type should be same as the type of the data mentioned in the return statement.

To consume the data returned by the method


1.Either to store the data returned by the method in a variable and use it for further
operations.

Or
2.Call the method directly inside the printing statement.
Ex:
package Array_Programs;

import java.util.Scanner;

public class Method_Class {


static int add(int num1,int num2){
int res=num1+num2;
return res;
}
public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
int num1=sc.nextInt();
int num2=sc.nextInt();
int sum=num1+num2;
System.out.println(sum);
}
}
Check weather the number is strong or not.
If the summation of the factorial of the digits =original

Ex:
package Array_Programs;

import java.util.Scanner;

public class Strong_num {


static int factorial(int num){
int fact=1;
for (int i=1;i<=num;i++)
fact*=i;
System.out.println(fact);
return fact;
}

public static void main(String[] args) {


Scanner sc =new Scanner(System.in);
System.out.println("enter a number ");
int num=sc.nextInt();
int temp=num;
int sum=0;
while(num>0){
int rem=num%10;
sum=sum+factorial(rem);
num=num/10;
}
if(sum==temp){
System.out.println("Strong num");
}
else {
System.out.println("Not a Strong num");
}

}
}

Prime Number or not:


package Number_Programs;

import java.util.Scanner;

public class Prime_num {


public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.print("Enter a number: ");
int num = sc.nextInt();
int count=0;
for (int i=1;i<=num;i++){
if(num%i==0){
count++;
}
}
if(count==2){
System.out.println("Prime num");
}
else{
System.out.println("not a prime num");
}
}
}

Check the Power and Base


package Number_Programs;

import java.util.Scanner;

public class Base_Power {


public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.print("Enter base: ");
int base = sc.nextInt();
System.out.print("Enter power: ");
int power = sc.nextInt();
int res = 1;
for (int i = 1; i <= power; i++) {
res *= base;
}
System.out.println("result is "+res);
}
}

Check weather the given number is a strong or not


Num=153
1*1*1=1
5*5*5=125
3*3*3=27
1+125+27=153

package Number_Programs;

import java.util.Scanner;

public class Amstrong_num {


static int countDigits(int num) {
int count = 0;
while (num > 0) {
count++;
num /= 10;
}
return count;
}
static int power(int base, int exp) {
int pow = 1;
for (int i = 1; i <= exp; i++) {
pow *= base;
}
return pow;
}

public static void main(String[] args) {


Scanner sc = new Scanner(System.in);
System.out.println("Enter a number:");
int num = sc.nextInt();
int count = countDigits(num);
int temp = num;
int sum = 0;

while (temp > 0) {


int rem = temp % 10;
sum += power(rem, count);
temp /= 10;
}
if (sum == num) {
System.out.println(num + " is an Armstrong number.");
} else {
System.out.println(num + " is not an Armstrong number.");
}
}
}

Arrays class:
It is pre-defined class and it is present in java.util package.
It contains several methods to perform operations on array.

toString[]method:
It is a parameterized method which accepts array reference variable and returns the elements
present in the array in string format.
The return type of toString method is String.
Sort[]method:
It is a parameterized static method which accepts array reference variable and sorts the passed
array elements in ascending order.
The return type of sort method is void.

Patterns:
Hallow Square:
package Patterns;

import java.util.Scanner;

public class Hallo_Square {


public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
int n=sc.nextInt();
for (int i=1;i<=n;i++){
for (int j=1;j<=n;j++){
if(i==1 || i==n||j==1 ||j==n){
System.out.print("CSK ");
}
else {
System.out.print(" ");
}
}
System.out.println();
}
}
}
Right Angle Triangle Pattern
package Number_Programs;

import java.util.Scanner;

public class Right_tri {


public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
System.out.println("enter num of rows");
int n= sc.nextInt();
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
if(j<=i){
System.out.print(" *");
}
}
System.out.println();
}
}
}

Pyramid Pattern
package Patterns;

import java.util.Scanner;

public class Pyramid {


public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
System.out.println("Enter the num of rows");
int n=sc.nextInt();
for(int i=1;i<=n;i++){
for (int j=1;j<=2*n-1;j++){
if(i+j>=n+1 && j-i<=n-1){
System.out.print("*");
}
else {
System.out.print(" ");
}
}
System.out.println();
}
}
}

Object in Java:
In java object is a block of memory which can store multiple variables as well as methods.
Steps to create Objects.
1.Create blueprint/class for an object, class is already present than use the existing class to
create an object.
2.Syntax: new Constructor();
new ClassName();
Class: it is a blueprint of an object which is used to specify the properties and behaviour of
an object.
New keyword:
 It is a keyword as well as unary operator.
 It is used to create the block of memory in heap area.
 After the object creation, new keyword returns address/reference of the object.
Constructor:
 It is a special member of class whose name is same as class name.
 It is used to load the non-static members inside the object.
 As it initializes the object, it is also known as initializer.

Ex:
Class Demo{
} --> new Demo();

Reference Variable:
 It is a variable which used to store the reference of the object is known as variable.
 In java every class name is a non-primitive datatype and we can use it to create non
primitive variables/reference variables.
 Ex: class Book{
}
Book b1;
Inside a reference variable we can store reference of the object as well as null value.
b1=new Book();
b1=null;
Constructor:
There are 3 types of constructors.
1. Default Constructor
2. No argument constructor
3. Parameterized constructor.
Syntax: [Mondifers] classname(){
//Construcor body
}
Default Constructor:
If a programmer fails to create constructor in the class, then compiler will add a no-argument
default constructor
No argument Constructor:
A constructor declared without the formal arguments is known as no argument constructor.
Parameterized Constructor:
The constructor declared with formal arguments is known as Parameterized Constructor.
It is used to initialize the data members of an object during the object creation/instantiation.
Rules to call parameterized constructor:
1.We need to pass the actual arguments while calling the parameterized constructor.
2.The formal arguments and the actual arguments should be same in datatype, length, order.
This Keyword:
It is a keyword which is used to differentiate between the non-static variable local variable.
It holds the reference/address of the current invoking object.
Constructor Overloading:
 A class more than 1 constructor with different formal arguments is known as
constructor overloading.
 The formal arguments must differ by data type or by length or by the order.
 It is used to avoid flexibility to the user to initialize the object data members as per the
requirements.
Constructor Chaining:
A constructor calling another constructor is known as constructor chaining.
There are 2 ways to achieve constructor chaining.
1.this call statement
2.super call statement
This call statement:
It is used to achieve constructor chaining.
To call no argument constructor we use this()
To call parameterized constructor statement we use this (parameters/actual arguments)
Rules to call/use this()
1.It can be used only inside constructor body.
2.It should be the first statement in the constructor body.
3.If a class having ‘n’ number of constructors there could be at max ‘n-1‘ number of this call
statement.

Static Members:
A class member which is pre-fixed with static modifiers is known as a static member.
There are 3 types of static members:
1.Static Variable
2.Static method
3.static initializer

Static Variable
A variable declared inside class block and which is pre-fixed with static modifier is known as
static variable.
Characteristics of static variable
1. A static variable will be initialized with a default value.
2. It will be allocated in class static area.
3. Inside same class we can access the static variable anywhere.
4. Outside the class if we want to access/fetch the static variable then we have to use
class as reference.
5. If we have static variable and local variable with the same name then the priority will
be given to the local variable but still if you want to get the static variable then we
have to use class name as reference.
Static Method
A method declared in class block and which is pre-fixed with static modifier is known as
static method.

Characteristics
1. It will be allocated in class static area.
2. Inside same class if we want to access static method then we can call it directly using
the method signature.
3. If we want to access/call the static method outside the class then we have to use the
class name as reference.
Static Initializer
It is used to execute the startup instructions of program.
The static initializers will execute before the actual execution of the program.
There are 2 types of static initializers
1. Single line static initializer
2. Multi line static initializer
Single line: Syntax: static data_type var_name=value;
Multi line: Syntax: static {
//instructions
}
 If a class contain more than 1 initializer then they will be executed in top to
bottom order.

Non-Static Members
The members declared in class block which are not pre-fixed with static modifiers are known
as non-static modifiers.
Ther are types of non-static members
1. Non static variable
2. Non static method
3. Non static initializer
4. Constructor
Non static variable
A variable declared inside class block and which is not pre-fixed with static modifiers is
known as non-static variable.
Characteristics
1. Non static variables will be allocated inside the object.
2. Non static variables will be initialized with default values.
3. It will be allocated inside each and every object created.
4. Without creating object, we cannot use/access the non-static variable.
5. We can access it with the help of reference of the object.

Non static method:


A method declared inside class block and which is not pre-fixed with static modifier is
known as non-static method.
Characteristics
1. It will be allocated inside the object.
2. It will be allocated inside each and every object created.
3. Without creating the object, we cannot access the non-static method
4. We can access it with the help of object reference.
Non-Static Initializer
It is used to execute the startup instructions of an object.
It will be loaded inside method area and it will execute during the object creation.
There are 2 types of non-static initializers
1. Single line non-static initializer
Syntax: data_type var_name=value;
2. Multi line non-static initializer
Syntax: {
//instructions
}
Non-Static initializers will execute for each object created for the class.
Note
1. A block which is pre-fixed with static modifier is known as static context.
Ex: static methods, static initializers
2. A block which is not pre-fixed with static modifier is known as non-static context.
Ex: non static methods, non-static initializers, constructors.
To find Greatest among the array
package Array_Programs;

public class Greatest_num {


public static void main(String[] args) {
int [] arr={7,4,25,27,33,45,58,75};
int max=arr[0];
for(int i=0;i<arr.length;i++){
if(arr[i]>max){
max=arr[i];
}
}
System.out.println("Greatest num is "+max);
}
}
1. Find the 2nd largest element present in array
2. Fint an element presents in array or not.

Encapsulation
The process of binding the properties/states and the behaviour of an object together is known
as encapsulation.
We represent the properties/states with the help of non-static variables and behaviour of an
object with the help of non-static methods.
Data Hiding
The process of restricting the direct access and providing the secured indirect access to the
data members of the object is known as data hiding.
To achieve data hiding we use private access modifier.
When we prefix any data member with private access modifier then it can be accessible
only inside the same class.
To access/modify the hidden data outside the class we have to use getter and setter method.
Getter and setter methods will be public and non-static in nature.
Getter Method
It is used to access the private data members outside the class
The return type of getter method will be same as the data type of private/hidden data
member/variable.
By default it will be no argument method but we can modify and make it as parameterized
method to provide verification or as per requirement.

Object Class:
It is the supermost parent class of all the classes in java.
It has 11 non-static methods to be operated on the objects.
1. toString()
2. equals()
3. hashCode()
4. clone()
5. finalize()
6. wait()
7. wait(int i)
8. wait(int I,long l)
9. notify()
10. notifyAll()
11. getClass()

1. toString()
It returns the reference/address of the object.
The return type of to String method is String.
Whenever we try to print the reference variable, internally the tostring method will be
called and it returns the temporary duplicate object.
Overriding toString method
If we want to print the data of an object instead of the reference then we need to override the
tostring method as per our requirement.
Syntax: public String toString{
//new implementation
}
Equals() Method
It is used to compare the reference of the current object with the object passed.
The return type of equals method is Boolean.
hashCode method()
It is used to create and return a unique integer value based on the reference of an object.
The return type of hashCode method is int.
Overriding hashCode method
Instead of generating unique integer value based on the reference, if we want to generate the
unique integer value based on the data/states of an object then we need to override hashCode
method.
Syntax: public int hashCode(){
Return objects.hash(data1,data2,….,datan);
}
Exception:
Finally Block
It is a part of exception handling mechanism which is created with the help of finally
keyword.
Its is used to close the costly resources.
It will excecute even if the exception is handled or not.
It will be followed by the catch or directly after try block If catch is not accepected.

Exception Handling Propagation


When the object of exception type is being propagated from the called method to the caller
method then it is known as exception object propagation.
Unchecked exceptions will be propagated implicitly.
To propagate the checked exception object, we need to use throws keyword in the method
signature to declare and propagate the exception object.
Exception Declaration
To declare the exception, we use throws keyword in method signature followed by the name
of the exception of class.
If we declare any checked exception in main method then it will be handled by the default
exception handler.
If we declare any unchecked exception in main method then it will not be handled and the
program will stop abruptly.
Throw Keyword
It is used to throw an exception manually.
Syntax: 1. throw new Exception();
2. throw exception_reference
Custom Exception
Steps to create a custom exception
1. Create a blueprint/class for the exception
2. We have to extend/inherit the exception class as per the requirement
2.1 if we want to create checked exception then we should inherit any unchecked
exception class or the parent class exception.
2.2 If we want to create unchecked exception then we should inherit
RuntimeException class or any child class of RuntimeException class.
3. Override getMessage method to provide the reason of the exception (optional).
Type Casting
The process of conversion of data from one type to another is known as typecasting.
There are 2 types of type casting.
1. Primitive typecasting
2. Non-primitive typecasting
Primitive Typecasting
The process of conversion of primitive type of data from one type or another is known as
primitive typecasting.
Boolean-1 bit
Byte-2 byte
Short-2 bytes
Char-2 bytes
Int-4 bytes
Float-4 bytes
Long-8 bytes
Double-8 bytes

There are 2 types of primitive typecasting


1. Widening process
2. Narrowing process
Widening
When we convert lower type of primitive data to higher than it is called widening.
Widening is a implicit process, we don’t need to use typecast operator for the conversion.
Narrowing
When we convert higher type primitive data into lower type then it is known as narrowing.
Narrowing is an explicit process, we have to force the compiler for the conversion with the
help of type cast operator.
Typecast operator
Syntax: (target type) variable
Note: Boolean type of data cannot be converted to any other type of data and vice versa.
Non-primitive typecasting
The process of converting the reference from one type to another is known as non-primitive
typecasting.
To achieve non-primitive typecasting it is necessary to have a relationship between the
classes.
There are 2 types of non-primitive typecasting
1. Upcasting
2. Downcasting
Upcasting
The process of converting child type reference to parent type is known as Upcasting.
When the child type reference is present in parent type of container then it is known as
upcasted scenario.
Once in upcasted scenario then we cannot access the members of child class
Upcasting is implicit process, then we don’t use typecast operator for the conversion.
Downcasting
The process of converting a parent type of reference to child type is known as Downcasting.
Downcasting is a explicit process we need to use typecast operator to achieve downcasting.
Syntax: (Child_class_name) parent_variable;
Note: without perform upcasting if we try to achieve upcasting then we will get
ClassCastException.
Instance of operator
It is used to check whether the instance of the child is present inside the parent type of object
or not.
The return type of instance operator is Boolean.
If the instance of the child is present in parent variable, then it returns true else it returns
false.
Syntax: parent_variable instanceof Child_class_name
ClassCastException
While performing downcasting if the instance of the child class is not present in the parent
reference/container then we will get ClassCastException.

Java FrameWorks
Adding Custom object into ArrayList

Note:
1. ArrayList internally uses dynamic/growable array to store the elements.
3. The default size of ArrayList is 10.
4. Remove and contains method internally calls equals method.
5. Whenever we want to create collection of custom objects, we should override toString
equals and hashCode method.
Collection Class
It is a pre-defined class which is present in java.util package.
Collections is a utility class which has several static methods to perform different operations
on the passed collection object.
Ex: sort() it is used in sort the passed collection in ascending order
Linked List
It is child implementation class of list interface
It supports indexing
It maintains the order of insertion
Null values are allowed
Duplicate values are allowed
Homogeneous and heterogeneous elements are allowed.
It also presents in java.util package.
Linked list internally uses nodes to add/store the elements.
Nodes
Nodes are the block of memory which is divided into 3 parts.
1. Reference of previous object
2. The actual element/object
3. Reference of next object
Note
1. With respect to adding and removing the elements using linkedlist will be more
efficient as it uses nodes to store the elements.
2. If we want to search or access any element then arraylist will be more efficient as it
uses dynamic array to store the elements.
Vector
It is child implementation class of list interface
It is present in java.util package

Stack
It is child class of vector class
It is present in java.util package
Stack internally uses stack data structure to store the elements
Stack follows first in last out FILO.
Method of stack
1. Push(object o) -it is used to add the element in to the stack
2. Pop()- it is used to remove the last/recent added element from the stack
3. Peek()- it returns the head of the stack
4. isEmpty()- it returns true if the stack is empty else returns false
5. search(object o)- it is used to return the position of the element present in the stack.
Set Interface
It is child of collection interface
It is present in java.util package

Characteristics of interface
1. it doses not maintain the order of insertion
2. duplicate elements are not allowed
3. it does not support indexing
4. only one value is allowed
5. homogenous as well as heterogenous elements are allowed
HashSet
It is child implementation class of set interface
It does not maintain the order of insertion
Duplicate elements are not allowed
It does not support indexing
It is present in java.util package

LinkedHashSet
It is child class of hashset
It is present in java.util package
It maintains the order of insertions
Duplicate elements are not allowed and only one null value is allowed
It does not support indexing

TreeSet
It is child implementation class of set interface
It is present in java.util package
It does not maintain order of insertion
Only homogeneous type of elements are allowed if we try to add different type of
elements/objects then we will get ClassCastException.
Null is not allowed ,if we try to add null then we will get NullPointerException
Treeset internally sorts the elements in ascending order
Map Interface
In map we store the data in key and value pair
It is present in java.util package
The key and value pair is known as entry in map
Characteristics of key
1. we can add homogeneous and heterogeneous keys
2. key cannot be duplicate
3. if we want to add custom object as key then we need to override toString and equals
method in the custom object class.
4. One key will be associated with only one value
5. If we associate the new value to the old/existing key then old value will be overridden
by the new value
Characteristics of value
1. Homogenous and heterogeneous value are allowed.
2. Duplicate values are allowed
3. If we want to add any custom object as value then we need to override toString and
equals method in custom object in class.
4. Multiple null values are allowed

Methods of map interface


1. Put(key,value)it is used to add a key and value pair in the map
2. putAll(map m)it is used to copy all the key and value pairs into the current map
object from the passed map object.
3. Remove(key k)it is used to remove the key and pair associated with the passed key
4. Remove(key k,value v)it is used to remove the key and value pair mentioned in the
remove method
5. containsKey(key k)it returns true if the key is present in the map else returns the
false
6. containsValue(value v)it returns true if the value is present in the map else returns
false
7. get(key k)it returns the value associated with the passed key
8. getOrDefault(key k,default_value)if the key is present in the map then it returns the
value associated with the key, if the key is not present in the map then it returns the
default value mentioned.
9. KeySet()it returns the set of keys present int the map.
10. Value()it returns the set of values present in the map.
11. entrySet()it returns the set of all key and value pairs present in the map.
12. Size()it returns the size/number of key and value pairs present in the map
13. Clear()it removes all the key and value pairs from the map
HashMap
It is child implementation class of map interface
It is present in java.util package
It does not support indexing
Insertion order will not be maintained
Only one null key is allowed
Duplicate keys are not allowed but values can be duplicate
Homogeneous as well as heterogeneous keys and values are allowed
LinkedHashMap
It is child class of HashMap
It is present in java.util package
It maintains the order of insertion
Duplicate keys are not allowed but values can be duplicate
Only one null key is allowed but multiple null values are allowed
Homogeneous and heterogeneous key and values are allowed

HashTable
It is child implementation class of map interface
It is preset in java.util package
The insertion order will not be maintained
It does not allow null key or null value and if we try to add then we will get
NullPointerException.
It is a homogeneous and as well as heterogeneous key and values are allowed
Key cannot be duplicate but values can be duplicate

You might also like