android 线程问题 关于handler.post

程序段 为(在activity oncreat方法中):
System.out.println("aa");
Runnable r=new Runnable() {

        @Override
        public void run() {
            System.out.println("bb");
        }
    };
    Handler handler =new Handler();
    handler.post(r);

    System.out.println("cc");

    问题:
    为什么执行结果为
    aa
    cc
    bb
    而不是
    aa
    bb
    cc
    runnable对象不是运行在ui线程的吗

main线程从消息泵中取出一个消息,处理(执行相关函数),然后再取一个,处理。所以onCreate是某一消息处理中的执行,其中post一个消息,只是把消息加入队列了,还没执行新消息,什么时候执行?要等前一个消息处理完,再次从消息泵中取消息处理时,它才被执行。

所以先是main的system.out,再是post的system.out

相比之下,sendMessage是同步执行,用handler.sendMessage,那顺序就变了

按顺序执行 但‘bb’是异步的,需要时间来执行