Thursday, 25 May 2017

28. Guarded Blocks and its types

1. Guarded block.
  1. Threads often have to coordinate their actions or result. The most common coordination idiom is the guarded block.
  2. Such a block begins by polling a condition that must be true before the block can proceed. There are a number of steps to follow in order to do this correctly.
  3. They are two types of guarded blocks
    1. Non Synchronized guarded block
    2. Synchronized guarded block
  4. If specified condition is true/false only the thread will execute further otherwise it resumes its execution.
  5. One thread uses the condition to check current thread need to execute or resume, but another thread update the condition if the specified work is done by second thread.
  6. So both threads will coordinate their actions by shared resource (boolean variable).

2. Non Synchronized Guarded block.
  1. In this case we simply cause the execution to keep executing a blank loop until the condition becomes true.
  2. This approach has an obvious disadvantage of wasting the precious CPU time, which could have been better utilized by some other threads otherwise.
public guardedBlock() {

while(!sharedBooleanFlag) {

   //... empty loop
}

System.out.println("Shared Boolean Flag is true - you may proceed now!");

}


3. Synchronized Guarded block.
  1. In this case if the condition is false then the block (which is a synchronized block) simply calls the Object.wait() method to release the acquired monitors on that object
  2. Thread leaves the processor to be used by other threads (probably more effectively as the current thread would not have done anything significant in this case unless the condition becomes true).

public synchronized guardedBlock() {

while(!sharedBooleanFlag) {
  try {
      wait();
  } catch (InterruptedException e) {}
}

System.out.println("Shared Boolean Flag is true - you may proceed now!");

}



Tuesday, 16 May 2017

1. Search element in rotated sorted array




public class BinarySearch {

public static void main(String[] args) {

int array[] = { 10, 20, 30 };
int ele = 30;
int index = pivotBinarySearch(array, ele, 0, array.length - 1);

System.out.println("index is " + index);
}

public static int pivotBinarySearch(int array[], int ele, int min, int max) {

int pivot = findPivot(array, 0, array.length - 1);

if (pivot == -1 || array[pivot] == ele)
return pivot;

if (array[min] > ele)
return binarySearch(array, ele, pivot + 1, max);

return binarySearch(array, ele, min, pivot - 1);
}

public static int binarySearch(int array[], int ele, int min, int max) {

int middle = (min + max) / 2;

if (ele == array[middle])
return middle;

if (min == max)
return -1;

if (ele < array[middle])
return binarySearch(array, ele, min, middle - 1);

return binarySearch(array, ele, middle + 1, max);

}

public static int findPivot(int array[], int min, int max) {

System.out.println(min + " " + max);
int middle = (min + max) / 2;

if (max - min == 1 && array[min] > array[max])
return min;

if (array[middle] > array[max])
return findPivot(array, middle, max);

if (array[min] > array[middle])
return findPivot(array, min, middle);

return -1;

}
}

Monday, 15 May 2017

2. Binary Search

1. What is Binary Search
  1. Given a sorted array arr[] of n elements, write a function to search a given element x in arr[].
  2. A simple approach is to do Linear search.
  3. The time complexity of above algorithm is O(n). Another approach to perform the same task is using Binary Search.
  4. Binary Search: Search a sorted array by repeatedly dividing the search interval in half.
  5. Begin with an interval covering the whole array.
  6. If the value of the search key is less than the item in the middle of the interval, narrow the interval to the lower half.
  7. Otherwise narrow it to the upper half.
  8. Repeatedly check until the value is found or the interval is empty.
The time complexity of above algorithm is O(log n).

public class BinarySearch {

public static void main(String[] args) {

int array[] = { 0};
int ele = 10;

int index = binarySearch(array, ele, 0, array.length - 1);
System.out.println("index is " + index);
}

public static int binarySearch(int array[], int ele, int min, int max) {

if (max >= min) {

int middle = (min + max) / 2;

if (ele == array[middle])
return middle;

if (ele < array[middle])
return binarySearch(array, ele, min, middle - 1);

return binarySearch(array, ele, middle + 1, max);
}
return -1;
}
}

1. Linear Search

1. What is Linear Search
A simple approach is to do linear search, i.e
  1. Start from the leftmost element of arr[] and one by one compare x with each element of arr[]
  2. If x matches with an element, return the index.
  3. If x doesn’t match with any of elements, return -1.
The time complexity of above algorithm is O(n).




public class LinearSearch {

public static void main(String[] args) {
int array[] = {13, 48, 7, 4, 15, 25, 11};
int ele = 25;
int index = linearSearch(array, ele);
System.out.println("index is "+index);
}
public static int linearSearch(int array[], int ele){
for(int i=0; i<array.length; i++){
if(array[i] == ele)
return i;
}
return -1;
}

}

27. Daemon thread and green thread

1. What is Daemon thread.
  1. The threads which are executing on background is called daemon threads
  2. Examples of daemon threads     
    1. Garbage collector
    2. Signal dispatcher
    3. Attach listener
    4. Reference Handler
    5. Finalizer
    6. DestroyJavaVM
  3. The main objective of daemon thread is to provide support for non daemon threads (main-thread).
  4. If main thread runs with low memory then JVM runs garbage collector to destroy useless objects. So that number of bytes of free memory will be improved with this free memory main thread can continue its execution.
  5. Daemon threads are running with low priority normally, but if any need JVM will increase priority.
  6. Usually daemon thread having low priority but based on requirement, daemon threads can run with high priority also.
  7. Methods related to daemon thread in Thread class
    1. Public boolean    isDaemon()
    2. Public   void    setDaemon(Boolean b)
  8. We can check daemon nature of a thread by using isDaemon() of Thread class.
  9. We can change daemon nature of a thread by using setDaemon(..).
  10. Changing daemon nature is possible before starting of a thread only.
  11. After starting a thread if we are trying to change daemon nature then we will De get runtime exception  “IllegalThreadStateException”.
  12. By default main thread is always non daemon and for all remaining threads daemon nature will be inherited from parent to child.
  13. If parent thread is daemon then automatically child thread is also daemon.
  14. If parent thread is non daemon then automatically child thread is also non daemon.
2. Is possible to change daemon nature of Main thread.
  1. No, it is impossible to change daemon nature of main thread because it is already started by JVM at beginning.
  2. We can change daemon nature for threads created by us , before start.

Class X{
  public synchronized void m1(){
        sop(Thread.currentThread().isDaemon());//false
        Thread.currentThread().setPriority(true);//exception
  MyThread t1 = new MyThread();
  Sop(t1.isDaemon());//false
  T1.setDaemon(true);
Sop(t1.isDaemon());//true
  }
}

3. Life of daemon thread.
  1. Whenever last non daemon thread completes its execution, then automatically all daemon threads are terminated its execution irrespective their position.

Class MyThread extends Thread{
  Public void run(){
        For(int i = 0; i<10; i++){
              Sop(“child thread”+i);
              Thread.sleep(2000l);
        }
  }
}
Class MainDemo{
  public static void main(String[] args)throws Exception{
        MyThread thread1 = new MyThread(d,”Rama”);
        thread1.setDaemon(true);
        thread1.start();
        Sop(“main thread end”);
  }
}

Output(based on jvm it will change)
child thread 1
main thread end

Note : In above example, main thread is non daemon and child thread is daemon hence whenever main thread terminates automatically child thread will be terminated, in this case output is end of main thread followed by child thread or end of main thread directly.

4. What is green thread.
  1. Java multithreading concept is implemented by using the following 2 models
      1. Green Thread model
      2. Native OS model
  2. The thread which is managed completely by JVM without taking underlying  OS support is called Green Thread.
  3. Very few operating systems like Sun Salaries provide support for green thread.
  4. Any way Green thread model is deprecated  
5. What is Native OS model in thread.
  1. The thread which is managed by JVM with the help of underlying OS, is called native OS model.
  2. All windows based OS provide support for native OS model.

3. Java Program to create Binary Tree