我在Android应用程序中有以下代码:
/**
* Returns a single customer object based on UUID. */
public static Customer getCustomer(UUID id)
{
try
{
Cursor cursor = CustomApp.data.db.query("Customer", customerCols,
"CustomerId='" + id.toString() + "'", null, null, null, null);
if (cursor != null)
cursor.moveToFirst();
Customer cust = new Customer(id);
// Unrelated code here
if (!cursor.isNull(23))
cust.isDeceased = (cursor.getInt(23) > 0); // EXCEPTION
// More unrelated code here
return cust;
}
catch (Exception ex)
{
ex.printStackTrace(); // This line gets skipped
return null; // Code jumps to here
}
}
我正在尝试调试它。行cust.isDeceased = (cursor.getInt(23) > 0);
上有一个例外(为什么我得到异常完全是另一个问题)。当代码到达该行时,它会跳转到catch
部分。我在第ex.printStackTrace();
行放了一个断点,但代码完全跳过了这一行。它只是直接跳到return null;
行,堆栈跟踪从不打印。因此,调试代码变得非常困难,因为我不得不猜测是什么问题。 (如果您看到该代码有问题,请告诉我,但这不是此问题的目的)。
我很遗憾缺少我提供的信息/代码,但由于我完全不知道为什么会这样,我不知道什么是相关的,什么不是。有没有人遇到过这个问题?
答案 0 :(得分:2)
Log.e(“TAG”,“error”,ex);试试这个而不是ex.printStackTrace(); 也尝试重新启动eclipse。
答案 1 :(得分:0)
删除try catch子句,logcat将显示详细的异常。