Android開發之onActivityResult()中的resultCode為0,intent為null的解決辦法


BUG:昨天在使用activity之間傳值的時候,遇到了一個bug,該bug為:Activity A啟動Activity B,然后在Activity B中取到一個值,並通過back鍵返回到Activity A,但是在onActivityResult()中,發現requestCode正確,resultCode為0,intent為null。

log:

 1 java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=198007, result=0, data=null} to activity {com.example.xxx.testactivity/com.example.xxx.testactivity.MainActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String android.content.Intent.toString()' on a null object reference
 2                                                                                      at android.app.ActivityThread.deliverResults(ActivityThread.java:4058)
 3                                                                                      at android.app.ActivityThread.handleSendResult(ActivityThread.java:4101)
 4                                                                                      at android.app.ActivityThread.access$1400(ActivityThread.java:177)
 5                                                                                      at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1497)
 6                                                                                      at android.os.Handler.dispatchMessage(Handler.java:102)
 7                                                                                      at android.os.Looper.loop(Looper.java:145)
 8                                                                                      at android.app.ActivityThread.main(ActivityThread.java:5942)
 9                                                                                      at java.lang.reflect.Method.invoke(Native Method)
10                                                                                      at java.lang.reflect.Method.invoke(Method.java:372)
11                                                                                      at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1399)
12                                                                                      at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1194)
13                                                                                   Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String android.content.Intent.toString()' on a null object reference
14                                                                                      at com.example.lijingbo.testactivity.MainActivity.onActivityResult(MainActivity.java:37)
15                                                                                      at android.app.Activity.dispatchActivityResult(Activity.java:6549)
16                                                                                      at android.app.ActivityThread.deliverResults(ActivityThread.java:4054)
17                                                                                      at android.app.ActivityThread.handleSendResult(ActivityThread.java:4101) 
18                                                                                      at android.app.ActivityThread.access$1400(ActivityThread.java:177) 
19                                                                                      at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1497) 
20                                                                                      at android.os.Handler.dispatchMessage(Handler.java:102) 
21                                                                                      at android.os.Looper.loop(Looper.java:145) 
22                                                                                      at android.app.ActivityThread.main(ActivityThread.java:5942) 
23                                                                                      at java.lang.reflect.Method.invoke(Native Method) 
24                                                                                      at java.lang.reflect.Method.invoke(Method.java:372) 
25                                                                                      at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1399) 
26                                                                                      at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1194) 

查看到: java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=198807, result=0, data=null}

返回的結果碼和數據都不對,只有請求碼正確。

經過嘗試后,發現,復寫onBackPressed()方法的時候,把自己寫的代碼放在super.onBackPressed()上面,就可以正確的執行。

放在super.onBackPressed()的下面,雖然debug的時候也執行了,但是並沒有把值傳遞給Activity A。

解決辦法:復寫onBackPressed()的時候,把自己的代碼放在super.onBackPressed()上面。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM