systrace抓取到的trace日志中会记录android系统的很多通信过程,其中也包括了binder的通信细节。这里我们以一份trace log进行简单解析:
红框:现场名字及线程号,这里是截图所以没有体现出来,这个线程是system_server中的1102 1546 InputReader线程。
蓝框:表明当前线程的状态是runable, 点击蓝色横条,我们可以看到更多详细信息:
上图红框中的信息表明,线程从sleeping状态切换到了Runable状态,由tid 0唤醒。
点击绿色横条,可以看到这个thread是运行在CPU5上。以及其运行的开始时间&持续时间。
点击binder transaction async这个方块,可以看到更多binder通信的信息
再点击下方slice栏中的信息可以知道binder的通信走向:
从trace中可以看到,1546 InputReader线程通过binder向surfaceflinger(501)的线程发送了消息.