01-24 15:18:06.436 15224-15224/com.zx.viewlearn E/MainActivity: MainActivity()
01-24 15:18:06.456 15224-15224/com.zx.viewlearn E/MainActivity: onCreate()
01-24 15:18:07.033 15224-15224/com.zx.viewlearn E/MainActivity: MainActivity()
今天在看activity启动模式的时候想到:activity为什么不用构造函数来new 一个对象,而是用反射呢?
于是就在启动页mainactivity中加了个构造函数,并打印日志。
发现构造函数居然打印了两次:
01-24 15:18:06.436 15224-15224/com.zx.viewlearn E/MainActivity: MainActivity()
01-24 15:18:06.456 15224-15224/com.zx.viewlearn E/MainActivity: onCreate()
01-24 15:18:07.033 15224-15224/com.zx.viewlearn E/MainActivity: MainActivity()
并且一次在onCreate之前,一次在onCreate之后。
我又写了个Activity并在mainactivity中跳转到第二个Activity,发现第二个Activity只执行了一次构造函数。
很困惑为什么启动时首页会执行两次构造函数?
第一次调用很清楚是在Instrumentation类的newActivity里反射调用的,
第二次在哪调用的呢?还不清楚。有人知道的话,可以留言告诉我。