几乎所有的android源码实现都有throw new RuntimeException(“Stub!”);这么一段代码,例如:
public boolean startActivityIfNeeded(Intent intent, int requestCode) {
throw new RuntimeException("Stub!");
}
1
“RuntimeException(“Stub!”)”表示实际运行时的逻辑会由Android ROM里面相同的类代替执行。(https://zhuanlan.zhihu.com/p/20564614?columnSlug=kaede)
此外,在IDE里看源码的时候,有时候一些方法或者类会出现报红(找不到)的情况,
这是因为这些方法或者类是被Android SDK隐藏的,出于安全或者某些原因,这些API不能暴露给应用层的开发者,所以编译完成的android.jar包里会把这些API隐藏掉,而我们的Android项目是依赖android.jar的,查看源码的时候,IDE会自动去android.jar找对应的API,自然会找不到。当然,这些API在ROM中是实际存在的,有些开发者发现了一些可以修改系统行为的隐藏API,在应用层通过反射的方式强行调用这些API执行系统功能,这种手段也是一种HACK。
2
Stub顾名思义,就是桩的意思。表示这个方法先写上,但是没有实际的功能。这个函数也不会返回,因为会引发异常。
我们有两种实现软件的方法,一个是先进行顶层设计,然后再具体实现。另一个是先设计细节,然后把它们组合在一起成为整体。桩代码在软件设计的时候很常见,它就是第一种设计方式的体现,函数调用先写出来,同时编写一个桩,这个桩只是为了让编译通过。
丢出异常的目的是当实际要调用它的时候,防止设计者遗忘,丢出异常很明显提醒调用者,这个代码没有实现。(http://ask.csdn.net/questions/228425)
提示调用者该功能尚未实现,Stub只是留了个接口,并未真正实现功能。
RuntimeException属于运行异常,抛出来所以调用它的函数就不需要处理异常了。
抛异常后下面就不执行了,所以不用写返回值