我正在浏览我的应用程序的一些崩溃日志,堆栈跟踪显示如下:
at MyActivity.formatDouble(MyActivity.java:182)
at MyActivity.access$47(MyActivity.java:196)
at MyActivity$28.onCameraChange(MyActivity.java:167)
“MyActivity”是一项活动,因此不是匿名的内部类。我不能确定第3行(以及第2行中的美元符号)的美元符号
答案 0 :(得分:7)
我怀疑第167行是在 MyActivity
内的匿名类中,access$47
只是一种允许onCameraChange
调用私有的蹦床方法MyActivity
内的方法。 (JVM不允许这样做,因此Java编译器会创建一个允许它的方法。)
使用简单的Java类,即使在Android上也很容易看到这一点:
public class Test {
private static void privateMethod() {
throw new RuntimeException();
}
public static void main(String[] args) throws Exception {
Runnable runnable = new Runnable() {
@Override public void run() {
privateMethod();
}
};
runnable.run();
}
}
这会产生类似于您所示的堆栈跟踪:
Exception in thread "main" java.lang.RuntimeException
at Test.privateMethod(Test.java:4)
at Test.access$000(Test.java:1)
at Test$1.run(Test.java:10)
at Test.main(Test.java:13)
Test$1.run
位于main
内的匿名内部类中,access$000
方法提供对privateMethod
的访问权限。