Headertab

Drop Down MenusCSS Drop Down MenuPure CSS Dropdown Menu

Sunday, 24 November 2019

Android interview questions for experience developers

How to handle async Task on activity/fragment during rotation?.
I have two options for maintain state of activity or fragment during rotation.
v  Use Intent Service and Broadcast Receiver and send data on Intent Service when screen rotate and get data from Broadcast receiver on onRestoreInstantState() method
v  In Fragment we are use two component first is interface that is work as a callback methods and second is android system provided method by name setRetainState(true) on Oncreate() method.

Difference between  Serializable and Parcelable.
Serializable: Serializable is used reflection in background so it’s slow process. This method is created lot of temporary objects that is maintain garbage collection.
Parcelable: Parcelable is much faster than Serializable. Parcelable is take more time to implement compared to Serializable interface. We can pass array via intent in Parcelable. It’s not use reflection.
If u not want to send any variable data to another class throe intent so you can go parcelable  class and don’t write here that variable or remove from here that variable.

Sync Activity and Fragment life cycle?.
Activity: onCreate()
           Fragment: onAttach(), onCreate(),onCreateView(), onViewCreated(), onActivityCreated()

Activity: onStart()
           Fragment: onStart()

Activity: onResume()
           Fragment: onResume()

Activity: onPause()
           Fragment: onPause ()

Activity: onStop()
           Fragment: onStop

Activity: onDestroy()
           Fragment: onDestroyView(), onDestroy(), onDettach()
Types of design pattern
v Factory Pattern : When we have one super class and multiple sub classes and we want to return one sub class then factory design pattern is best options.
v Adapter Design Pattern: In this pattern we are connecting two different component with adapter. In other word the adapter pattern make two incompatible interface compatible without changing existing property. Like Recycler view and Adapter
 
v Abstract Factory Pattern
v Prototype Pattern
v Singleton Pattern
v Builder Pattern

Difference between Service and IntentService ?
Service class run on Main Thread while IntentService is running worker thread.
Service class is base class of IntentService.
IntentService is using queue process and handle on queue is onHandleIntent() this is stop automatically when no intent in queue is empty while service class need to manual stopSelf().
Service class can triggered any thread while IntentService is trigger only from MainThread.
If you are using service there are chance to block main thread bcz service is running main thread while IntentService is running separate thread on the basic first come first serve. If you are using IntentService then you will find difficult to interact with UI of the application.
 Bound Service is used when one or more than one application component bind the service by using  bindService() method. If the application unbind the service then the service will be destroyed.

Looper and Handler?
Android Looper is a wrapper to attach MessageQueue and Thread and it manage queue processing. In other word to say Looper is a class which is used to process message in a queue. Normal thread have no such queue that means simple thread does not contain any queue.
Lopper = Thread + MessageQueue
Handler is a utility class and this is allow to send and process message and runnable object associate with thread and MessageQueue.
    Use

  •         Message creation
  •         Inserting messages into the queue
  •         Processing message on the consumer thread
  •         Managing messages in the queue


class LooperThread extends Thread {
      public Handler mHandler;

      @Override
      public void run() {
          Looper.prepare();
          mHandler = new Handler() {
              @Override
              public void handleMessage(Message msg) {
                  // process incoming messages here
              }
          };
          Looper.loop();
      }
  }

How to send data from service to activity?
Broadcast Receiver that is transfer data from service to activity.

public class TrackWifiService extends IntentService {
    public TrackWifiService() {
        super("wifiService");
    }
    protected void onHandleIntent(@Nullable Intent intent) {
        sendDataToActivity()
    }
   private void sendDataToActivity()
   {
        Intent sendLevel = new Intent();
        sendLevel.setAction("GET_SIGNAL_STRENGTH");
        sendBroadcast(sendLevel);
 
   }
}

public class TrackWifiActivity extends AppCompatActivity {
   WifiLevelReceiver receiver;
 
   @Override
   public void onCreate(Bundle savedInstanceState)
   {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.track_wifi_activity_layout);
      receiver = new WifiLevelReceiver();
      registerReceiver(receiver, new IntentFilter("GET_SIGNAL_STRENGTH"));  //<----Register
   }
   @Override
   public void onStop()
   {
       super.onStop();
       unregisterReceiver(receiver);           //<-- Unregister to avoid memoryleak
   }
   class WifiLevelReceiver extends BroadcastReceiver {
 
       @Override
       public void onReceive(Context context, Intent intent) {
 
           if(intent.getAction().equals("GET_SIGNAL_STRENGTH"))
           {
              int level = intent.getIntExtra("LEVEL_DATA",0);
 
              // Show it in GraphView
           }
       }}}




MVVM

Observer design pattern?
Observer design pattern is a software design pattern that is established one-to-many dependency between objects. The state of one object(Observable or Subject) can change all other objects(Observer) state.

mMutableLiveData.observe(this, new Observer<String>() {
    @Override
    public void onChanged(@Nullable String s) {
        mTextView.setText(s);
    }
});


Repository
1: Repository is fetch data from web or local.
2: This place is developer write own business logic.

ViewModel
ViewModel  is a helper class which is part of Android Architecture Component it helps store, holds and prepare UI related data in lifecycle conscious way. ViewModel is update UI with the data change. The main profit of ViewModel if Activity or Fragment destroyed by the system and recreate this is use same ViewModel and same state. ViewModel maintain the own lifecycle. View Model should not have any reference to Lifecycleowner like Activity or Fragment.

ViewModelFacory
1: ViewModelFactory is create dynamic viewmodel for Activity and Fragment.
2: ViewModelFactory is provide viemodel to Activity or fragment.
3: ViewModelFactory is maintain the status of Activity or Fragment live or dead.

LiveData
LiveData is a observable data holder class. Which is save/hold any object in that property. LiveData is follow Observable Design Pattern. LiveData is aware life cycle.

MutableLiveData
MutableLiveData is a sub-class of LiveData. Its provide setValue and postvalue method. If you are updating value from MainThread then u can use setValue and if you want update value from different thread then you must use postvalue method. MutableLiveData/MediatorLiveData for notifying on each time of changing data. 
mMutableLiveData.observe(this, new Observer<String>() {
    @Override
    public void onChanged(@Nullable String s) {
        mTextView.setText(s);
    }
});



Dagger-2

Dagger2

Dagger is a dependency injection which is simplify developer work and less code.

Component: Component annotation used for connection between module and classes. We define the @Component.Builder interface which will be called from our custom Application class.
Module: Module class are responsible for provide object/class which can be injected.
Provider: Provider annotation is responsible for provide object these method that is available in injection.
Singleton: Singleton annotation is responsible for create single object any class and provide global level.
ViewModelKey: ViewModelKey is help for map your ViewModel with ViewModelFactory.