difference between Thread and Handler
Threads are generic processing tasks that can do most things, but one thing they cannot do is update the UI.
Handlers on the other hand are background threads that allow you to communicate with the UI thread (update the UI).
So for example show a toast or a update a progress bar via a message (Runnable) posted to a handler but you can't if you start this runnable as a thread.
With handler you can also have things like MessageQueuing, scheduling and repeating.
I am yet to encounter a situation where I needed a thread in android.
I mostly use a combination of AsyncTasks and Handlers.
Handlers for the aforementioned tasks.
AsyncTasks for download/ data fetching and polling etc.
The same: you can both execute task asynchronously without blocking your current code,
The difference: Imagine you have a Runnable r = new Runnable{...}
When you use
new Thread(r).start()
, you actually created a new thread and run task asynchronously.When you use
new Handler().post(r)
(orMessage
), you added theRunnable
object toLooper
and execute the code later in the same thread.
A Thread
, generally MainThread
or UIThread
contains a Looper
. When MainThread
runs, it will loop the Looper
and execute Runnable
one by one.
When Thread is preferred:
When you're doing a heavy work like network communication, or decoding large bitmap files, a new thread is preferred. If a lot of thread is needed, maybe ExecutorService
is preferred further.
https://developer.android.com/reference/java/util/concurrent/ExecutorService.html
When Handler is preferred:
When you want to update UI objects (like TextView
text) from other thread, it is necessary that UI objects could only be updated in UI Thread.
Also, when you just want to run some light code later (like the delay for 300ms) you can use Handler
because it's lighter and faster.
Please also refer to Handler vs AsyncTask vs Thread
Thread
actually creates new thread - part of job running in background relatively to current thread.
Handler
itself doesn't provide any mechanisms for background job - it is just a tool to access message queue (Looper
) associated with some thread. UI thread have Looper
attached by default, so it is common practice to update UI with Handler.post(Runable)
which means execute some piece of code on thread which is associated with this Handler
.
As soon as Handler
serves Looper
, it can't be created in a thread which have no associated Looper
.