Android日志中的活动类名称后面的美元($)符号(非匿名内部类)

时间:2013-12-26 21:19:17

标签: java android debugging

我正在浏览我的应用程序的一些崩溃日志,堆栈跟踪显示如下:

at MyActivity.formatDouble(MyActivity.java:182)
at MyActivity.access$47(MyActivity.java:196)    
at MyActivity$28.onCameraChange(MyActivity.java:167)

“MyActivity”是一项活动,因此不是匿名的内部类。我不能确定第3行(以及第2行中的美元符号)的美元符号

1 个答案:

答案 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的访问权限。