How do android's Event Listeners work?

前端 未结 2 1325
既然无缘
既然无缘 2021-01-19 10:54

How is an event captured from a View object? There is only one thread running : the UI thread (when we haven\'t implemented any of our own threads). Suppose if I have implem

相关标签:
2条回答
  • 2021-01-19 11:41

    (As posted by the original questioner)

    So is that it? Do they work like interrupts?

    In Summary, it is not based on Interrupt (Main thread can run other code not waiting for event to happen) .. but rather based on Polling or Looping (Main thread continuously loops through to find any events or tasks are added in Message queue..)

    0 讨论(0)
  • 2021-01-19 11:44

    Internally, Android is running an event loop to handle UI events. For a nice diagram, see a third slide of this presentation. This thread is being used to dispatch system calls to the UI elements:

    The system does not create a separate thread for each instance of a component. All components that run in the same process are instantiated in the UI thread, and system calls to each component are dispatched from that thread.

    (source: Processes and Threads)

    Have a look at a Inside the Android Application Framework video from Google I/O 2008. It has the nice explanation of the event loop (consisting of Looper and Message Queue). The interesting stuff starts at around 26m into the video.

    The onClick() method will be called from the same thread from which the original setOnClickListener() was called. If it was a main/UI thread, then you should be vary of performing long-running tasks in the listener - they will block the UI thread and can cause the app to be non-responsive. Use solutions like AsyncTask instead.

    Please look at this blog post for detailed tutorial.

    0 讨论(0)
提交回复
热议问题