2014-09-23 155 views
0

我有一个Android运行时致命异常:主,我不知道我必须做什么来解决这个问题。我有以下的代码,这将导致此异常:Android运行时 - 致命异常:主

... @Override 
public void onItemClick(AdapterView<?> parent, View view, int position, 
     long id) { 
    Cursor c = (Cursor) mAdapter.getItem(position); 
    // startActivity(new Intent(Intent.ACTION_VIEW, 
    // Uri.parse(c.getString(c.getColumnIndex("link"))))); 
    // Cursor c = (Cursor) mAdapter.getItem(position); 
    // String urlWebView = 
    // Uri.parse(c.getString(c.getColumnIndex("link"))).toString(); 
    String feedDescription = Uri.parse(
      c.getString(c.getColumnIndex("description"))).toString(); 
    String feedTitle = Uri.parse(c.getString(c.getColumnIndex("title"))) 
      .toString(); 
    String feedLink = Uri.parse(c.getString(c.getColumnIndex("link"))) 
      .toString(); 

    String imageLink = Uri.parse(c.getString(c.getColumnIndex("img_link"))).toString(); 
    Intent in = new Intent(MainActivity.this, ShowNewsSummary.class); 
    in.putExtra("FeedDescription", feedDescription); 
    in.putExtra("FeedTitle", feedTitle); 
    in.putExtra("FeedLink", feedLink); 
    in.putExtra("ImageLink", imageLink); 
    startActivity(in); 
} 

在这段代码中,我得到一个img_link,当没有图像链接在数据库中找到它可以为null。当我点击我开始ShowNewsSummaryActivity一个项目,如果没有img_link在数据库中找到它抛出致命主要的例外,因为的AsyncTask无法下载时没有图像的地址找到图像:

... @Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activty_show_news_summary); 
    String descriptionFeed = getIntent().getStringExtra("FeedDescription"); 
    String titleFeed = getIntent().getStringExtra("FeedTitle"); 
    imageLinkFeed = getIntent().getStringExtra("ImageLink"); 
    title = (TextView) findViewById(R.id.title_feed); 
    description = (TextView) findViewById(R.id.description_feed); 
    imageDescription = (ImageView) findViewById(R.id.descriptionImage); 
    if (imageDescription != null) { 
    imageDescription.setVisibility(View.VISIBLE); 
    new DownloadImageAsyncTask(imageDescription).execute(imageLinkFeed); 

    } 
    title.setText(titleFeed); 
    description.setText(descriptionFeed); 
    title.setOnClickListener(this); 
} 

这是logcat的例外情况:

09-23 22:54:42.210: E/AndroidRuntime(11885): FATAL EXCEPTION: main 
09-23 22:54:42.210: E/AndroidRuntime(11885): java.lang.NullPointerException: uriString 
09-23 22:54:42.210: E/AndroidRuntime(11885): at android.net.Uri$StringUri.<init>(Uri.java:464) 
09-23 22:54:42.210: E/AndroidRuntime(11885): at android.net.Uri$StringUri.<init>(Uri.java:454) 
09-23 22:54:42.210: E/AndroidRuntime(11885): at android.net.Uri.parse(Uri.java:426) 
09-23 22:54:42.210: E/AndroidRuntime(11885): at com.fire147.samplesmartrss.MainActivity.onItemClick(MainActivity.java:176) 
09-23 22:54:42.210: E/AndroidRuntime(11885): at android.widget.AdapterView.performItemClick(AdapterView.java:298) 
09-23 22:54:42.210: E/AndroidRuntime(11885): at android.widget.AbsListView.performItemClick(AbsListView.java:1280) 
09-23 22:54:42.210: E/AndroidRuntime(11885): at android.widget.AbsListView$PerformClick.run(AbsListView.java:3083) 
09-23 22:54:42.210: E/AndroidRuntime(11885): at android.widget.AbsListView$1.run(AbsListView.java:3983) 
09-23 22:54:42.210: E/AndroidRuntime(11885): at android.os.Handler.handleCallback(Handler.java:615) 
09-23 22:54:42.210: E/AndroidRuntime(11885): at android.os.Handler.dispatchMessage(Handler.java:92) 
09-23 22:54:42.210: E/AndroidRuntime(11885): at android.os.Looper.loop(Looper.java:137) 
09-23 22:54:42.210: E/AndroidRuntime(11885): at android.app.ActivityThread.main(ActivityThread.java:4949) 
09-23 22:54:42.210: E/AndroidRuntime(11885): at java.lang.reflect.Method.invokeNative(Native Method) 
09-23 22:54:42.210: E/AndroidRuntime(11885): at java.lang.reflect.Method.invoke(Method.java:511) 
09-23 22:54:42.210: E/AndroidRuntime(11885): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1043) 
09-23 22:54:42.210: E/AndroidRuntime(11885): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:810) 
09-23 22:54:42.210: E/AndroidRuntime(11885): at dalvik.system.NativeStart.main(Native Method) 

我的错误在哪里?

+0

发布异常的logcat – panini 2014-09-23 20:27:11

+0

什么是错误的调用堆栈?您可以使用命令“adb -d logcat”查看所有日志。 – 2014-09-23 20:30:14

回答

2

在下面的Android开发者API Uri.Parse状态:

http://developer.android.com/reference/android/net/Uri.html#parse(java.lang.String)

Throws NullPointerException if uriString is null 

它去在你的MainActivity - onItemClick方法。所以这里的问题是你在Uri.parse()中输入的以下字符串之一是空的。

调试以下代码并检查哪一个为空。

String feedDescription = Uri.parse(
      c.getString(c.getColumnIndex("description"))).toString(); 
    String feedTitle = Uri.parse(c.getString(c.getColumnIndex("title"))) 
      .toString(); 
    String feedLink = Uri.parse(c.getString(c.getColumnIndex("link"))) 
      .toString(); 

    String imageLink = Uri.parse(c.getString(c.getColumnIndex("img_link"))).toString(); 

澄清,下面的代码之一返回空值

c.getString(c.getColumnIndex("description"))).toString(); 
c.getString(c.getColumnIndex("title"))).toString(); 
c.getString(c.getColumnIndex("link"))).toString(); 
c.getString(c.getColumnIndex("img_link"))).toString(); 

的stackstrace跟它线176,但我不能看到这行就是在这里,所以你必须检查了这一点。

编辑

你说这个是返回空字符串。

c.getString(c.getColumnIndex("img_link"))).toString(); 

为了解决这个问题只需要使用下面的代码:

String img_link = c.getString(c.getColumnIndex("img_link")); 
String imageLink = (img_link == null) ? "NULL" : Uri.parse(img_link).toString(); 

它可能是不干净的空检查,但你可以使用下面的网站上找到你最好的空查有

http://howtodoinjava.com/2013/04/05/how-to-effectively-handle-nullpointerexception-in-java/

+0

c.getString(c.getColumnIndex(“img_link”)))。toString();导致此异常。我该如何解决这个问题? – fire147 2014-09-23 20:59:03

+0

@ fire147看到我的编辑答案,告诉我它是否有效。你只需要检查值是否为空 – 2014-09-23 21:08:57

+0

感谢您的这个伟大的答案! – fire147 2014-09-23 21:50:01