Caught Throwable or Exception is null

后端 未结 5 1113
后悔当初
后悔当初 2021-01-19 01:45

A similar question was asked here for two times and never there was any answer. Or the answer was: \"it is impossible!\" Sorry, it is possible too much:

         


        
相关标签:
5条回答
  • 2021-01-19 02:09

    I am unsure of what causes this -- it could be an Eclipse bug as stated earlier. Regardless of the cause, I did find a workaround that seems to work. I hope it is useful to others as well.

    After the exception is caught, assign it to another variable. The assigned variable should contain the correct Exception in the debugger.

    SpecificException assignedVar = null;
    try {
        ...
    }
    catch (SpecificException exc) {
        assignedVar = exc; // <-- exc comes up null in the debugger, but assignedVar will be the correct object.
    }
    

    Hope this works for others as a workaround.

    0 讨论(0)
  • 2021-01-19 02:17

    Android does not always throws exception in a Throwable. It actually drives all the exceptions to the catLog. There you will find details of your exceptions even if in the catch block your exception is null.

    You can easily access the catlog console from eclipse and filter to view the errors only

    UPDATE:

    Your breakpoint should be inside the catch block

    0 讨论(0)
  • 2021-01-19 02:19

    I know this question was posted a while ago, and many times too! I fell into this trap yesterday and I thought I'll post what I found.

    Problem definition: I used the following code

    public class myAppActivity extends Activity
    {
       /** Called when the activity is first created. */
       @Override
       public void onCreate(Bundle savedInstanceState)
       {
          super.onCreate(savedInstanceState);
          setContentView(R.layout.main);
          try { -- lots of code -- }
          catch (Exception ex) {
              Log.e ("eTutorPrism Error", "Caught this exception " + ex);
              ex.printStackTrace();
          }
       }
    }
    
    Symptom was that 'ex' was always null and resume will give NullPointerException, although the actual exception was an IllegalArgumentException in a call made into another class from the code above.
    

    ISSUE: onCreate() code does not display the exception caught. instead it shows exception = null.

    Solution: do NOT use too much processing in onCreate(). Move as much as possible to another thread. So I changed the code to look like the following. voila, it works!!! I can see the actual exception displayed in the Logcat.

    public class eTutorPrismAppActivity extends Activity
    {
       /** Called when the activity is first created. */
       @Override
       public void onCreate(Bundle savedInstanceState)
       {
           super.onCreate(savedInstanceState);
           setContentView(R.layout.main);
    
           eTutorPrismTest myTest = new eTutorPrismTest (getApplicationContext());
           myTest.start();
       }
    }
    
    class eTutorPrismTest extends Thread
    {
       private Context m_AppContext = null;
    
       public eTutorPrismTest (Context appContext)
       {
          m_AppContext = appContext;
       }
    
       public void run ()
       {   
          -- lots of code that needs appContext --
       }
    }
    
    0 讨论(0)
  • 2021-01-19 02:27

    Have you verified whether e is actually null or not? I.e. by adding something like if (e == null) Log.d("Exception is null"). I would then check if the log statement gets triggered both during normal execution and while debugging. If the results are different between the two, it would indicate a VM bug (unlikely, but possible). If the message doesn't get triggered in either case, then it's likely a debugger issue.

    A few thoughts on further things you can try to debug the issue:

    • Try something like jdb and see if you get the same behaviour

    • You could get a dump of the jdwp communications between the debugger and the device, and see what's going on at that level. Maybe use wireshark or tcpdump and grab the data going over the usb bus to the device.

    • You could try adding some debug statements to dalvik itself. E.g. grab a copy of AOSP and build an emulator image, and then add some debugging statements to dalvik to try and track down what's going on.

    • You could attempt to do some sort of scripted jdwp session with the device

    • You could look at the bytecode (baksmali/dexdump/dedexer), to see if anything looks funny

    0 讨论(0)
  • 2021-01-19 02:30

    If the exception you caught was a NullPointerException, the getMessage() method returns "null" which may be confusing. I know that this has sometimes confused me!

    In the debugger, you should be able to select e and see a type and its fields. Also, another way to debug when things get really confusing is to go

     e.printStackTrace();
    

    (note - I'm not an Android guru so if this works differently on Android somebody please comment!)

    0 讨论(0)
提交回复
热议问题