代码不是打印堆栈跟踪

时间:2013-08-05 11:17:13

标签: java android

我在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;行,堆栈跟踪从不打印。因此,调试代码变得非常困难,因为我不得不猜测是什么问题。 (如果您看到该代码有问题,请告诉我,但这不是此问题的目的)。

我很遗憾缺少我提供的信息/代码,但由于我完全不知道为什么会这样,我不知道什么是相关的,什么不是。有没有人遇到过这个问题?

2 个答案:

答案 0 :(得分:2)

Log.e(“TAG”,“error”,ex);试试这个而不是ex.printStackTrace(); 也尝试重新启动eclipse。

答案 1 :(得分:0)

删除try catch子句,logcat将显示详细的异常。