当前位置: 首页 > 知识库问答 >
问题:

为什么堆栈跟踪行号与源代码行号不匹配?

姬国安
2023-03-14

我的应用程序崩溃了,我的设备上有一个NPE。在使用ACRA接收的堆栈跟踪中,行号引用了两个源代码类SQLiteStatementSQLiteDatabase。对于SQLiteDatabase,没有一个行号与任何源代码版本中的行号匹配。我的设备没有自定义ROM。这是一款运行Android4.03的Galaxy S2。

下面是堆栈跟踪:

java.lang.NullPointerException
at android.database.sqlite.SQLiteStatement.releaseAndUnlock(SQLiteStatement.java:290)
at android.database.sqlite.SQLiteStatement.executeUpdateDelete(SQLiteStatement.java:96)
at android.database.sqlite.SQLiteDatabase.executeSql(SQLiteDatabase.java:2025)
at android.database.sqlite.SQLiteDatabase.execSQL(SQLiteDatabase.java:1965)
at android.database.sqlite.SQLiteDatabase.beginTransaction(SQLiteDatabase.java:690)
at android.database.sqlite.SQLiteDatabase.beginTransactionNonExclusive(SQLiteDatabase.java:605)
at android.database.sqlite.SQLiteStatement.acquireAndLock(SQLiteStatement.java:247)
at android.database.sqlite.SQLiteStatement.executeInsert(SQLiteStatement.java:112)
at android.database.sqlite.SQLiteDatabase.insertWithOnConflict(SQLiteDatabase.java:1844)
at com.mydomain.myapp.albums.AlbumsData.insertOrIgnore(AlbumsData.java:89)

如果查看SQLiteDatabase不同版本的源代码,您可以自己检查数字是否匹配。

例如,在Android4.03的SQLiteDatabase源代码中,executesql(...)位于第1892行,而我的堆栈跟踪显示它位于第2025行。

这怎么可能?

(请注意,我询问NPE的来源)

共有1个答案

凤晨朗
2023-03-14

我不确定官方的android源码与你手机上的android版本相匹配。我认为三星可能是为了自己的目的而改变android的:三星的人拿了android 4.0.3的源代码,修改了它们,给不同的类添加了一些东西(SQLiteDatabase似乎就是其中之一),然后构建它,得到自己的android版本。他们没有修改显示android版本的常量,所以你可以看到它仍然是4.0.3。

 类似资料:
  • 我试图在Google Play Store中调试我的应用程序的几个崩溃,但是Play Store中显示的堆栈跟踪显示的是Java文件名和行号,而不是直接引用我的Kotlin代码。我在Android Studio中查看了Java代码,但是行号不匹配。 为了查看Java代码,我转换成字节代码,然后反编译成Java。在Android Studio中还有一个更直接的选项“将Kotlin反编译为Java”,

  • 问题内容: 我编写了一个超简单的Java类,该类应按需抛出异常。但是我得到的堆栈跟踪看起来像这样: 注意:堆栈跟踪中没有行号,我希望有。 搜索此问题时找到的答案都是关于在编译时添加正确的参数,以确保行号确实进入了类文件。但是,我不认为这是我的问题,因为在我的ant build.xml中有此问题 而且,根据javap,看起来行号确实在: 那有什么呢?运行代码时,是否需要在jvm中设置参数? 谢谢!

  • 我正在使用ant在Eclipse中构建我的项目的一个jar。我在Tomcat上部署了jar。但是,每当我的代码(在jar中)中发生异常时,错误堆栈跟踪就会出现,但行号不会出现--相反,它会显示未知源。 如何获取错误堆栈跟踪中的行号?

  • 当Xdebug被激活时,只要PHP决定显示通知,警告,错误等,就会显示堆栈跟踪。堆栈跟踪显示的信息以及显示方式可以根据您的需要进行配置。 Xdebug在错误情况下显示的堆栈跟踪信息量相当保守(如果display.errors 在php.ini中设置为On)。这是因为大量的信息会减慢脚本的执行速度和浏览器中堆栈跟踪本身的渲染速度。但是,可以使堆栈轨迹以不同的设置显示更详细的信息。 堆栈跟踪中的变量

  • 问题内容: 当我从标准库中获得运行时异常时,这几乎总是我的代码而不是库代码中的问题。有没有一种方法可以截断异常堆栈跟踪,以使其不显示库包的内容? 例如,我想得到这个: 而不是这样: 问题答案: 感谢Alex的指导,以下是代码: 产生以下堆栈跟踪:

  • 问题内容: 有什么方法可以将堆栈跟踪作为字符串获取? 查看调试包(https://golang.org/pkg/runtime/debug/),它只能打印到标准输出。 问题答案: 将格式化的堆栈跟踪放到提供的中。然后,您可以将其转换为字符串。 您还可以使用,分配足够大的缓冲区来容纳整个堆栈跟踪,并使用将该跟踪放入其中,并返回缓冲区()。