2013-10-16 108 views
0

我最近增加了一个闪屏到我的Android应用程序,以掩盖一个JSON文件的加载,但整理后分析我的应用程序崩溃。我已经注释掉,并注释掉了代码,直到我发现有问题的片段,但我不知道为什么它不工作。如果我注释掉从该代码段循环无法启动活动ComponentInfo;试图创建启动画面

代码工作。

从MagazinePagesActivity.java:

public void loadItems() { 
    for (Item item : SplashActivity.downloadedItems) { 
     Post post = (Post) item; 
     for (String tag : post.tags) { 
      if (tag.equals(this.tag)) { 
       // loader.loadImage(magazine.imageURL, new 
       // SimpleImageLoadingListener()); 
       Bundle bundle = new Bundle(); 
       bundle.putString("title", post.title); 
       bundle.putString("article", post.article); 
       bundle.putString("imageURL", post.imageURL); 
       MagazineFragment cover = new MagazineFragment(); 
       cover.setArguments(bundle); 
       coverAdapter.addNewItem(cover); 
      } 
     } 
    } 
    setContentView(vp); 
} 

起初,我以为是因为SplashActivity.downloadedItems没有正确定义,但它看起来好像没什么问题:

从SplashActivity.java:

public static ArrayList<Item> downloadedItems = new ArrayList<Item>(); 

public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_splash); 

    new RetreiveJSONTask() { 


     protected void onPostExecute(String JSON) 
     { 
      Log.d("SplashActivity", "Beginning parsingJSON"); 
      downloadedItems = parseJSON (JSON); 
      Log.d("SplashActivity", "Finished parsingJSON"); 
      Log.d("SplashActivity", "" + SplashActivity.downloadedItems.isEmpty()); 
      Intent i = new Intent(SplashActivity.this, MagazinePagesActivity.class); 
      startActivity(i); 

      // Closes the splash screen 
      finish(); 
     } 
    }.execute(sourceURL()); 
} 

从logcat的:

10-16 19:23:12.602: D/AndroidRuntime(828): Shutting down VM 
10-16 19:23:12.602: W/dalvikvm(828): threadid=1: thread exiting with uncaught exception (group=0x41465700) 
10-16 19:23:12.632: E/AndroidRuntime(828): FATAL EXCEPTION: main 
10-16 19:23:12.632: E/AndroidRuntime(828): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.bruinfootball/com.dailybruin.bruinframework.channels.StoryListActivity}: java.lang.NullPointerException 
10-16 19:23:12.632: E/AndroidRuntime(828): at  android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2211) 
10-16 19:23:12.632: E/AndroidRuntime(828): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2261) 
10-16 19:23:12.632: E/AndroidRuntime(828): at android.app.ActivityThread.access$600(ActivityThread.java:141) 
10-16 19:23:12.632: E/AndroidRuntime(828): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256) 
10-16 19:23:12.632: E/AndroidRuntime(828): at android.os.Handler.dispatchMessage(Handler.java:99) 
10-16 19:23:12.632: E/AndroidRuntime(828): at android.os.Looper.loop(Looper.java:137) 
10-16 19:23:12.632: E/AndroidRuntime(828): at android.app.ActivityThread.main(ActivityThread.java:5103) 
10-16 19:23:12.632: E/AndroidRuntime(828): at java.lang.reflect.Method.invokeNative(Native Method) 
10-16 19:23:12.632: E/AndroidRuntime(828): at java.lang.reflect.Method.invoke(Method.java:525) 
10-16 19:23:12.632: E/AndroidRuntime(828): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737) 
10-16 19:23:12.632: E/AndroidRuntime(828): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553) 
10-16 19:23:12.632: E/AndroidRuntime(828): at dalvik.system.NativeStart.main(Native Method) 
10-16 19:23:12.632: E/AndroidRuntime(828): Caused by: java.lang.NullPointerException 
10-16 19:23:12.632: E/AndroidRuntime(828): at com.dailybruin.bruinframework.channels.StoryListActivity.loadItems(StoryListActivity.java:27) 
10-16 19:23:12.632: E/AndroidRuntime(828): at com.dailybruin.bruinframework.channels.JSONItemsActivity.onCreate(JSONItemsActivity.java:20) 
10-16 19:23:12.632: E/AndroidRuntime(828): at com.dailybruin.bruinframework.channels.StoryItemsActivity.onCreate(StoryItemsActivity.java:18) 
10-16 19:23:12.632: E/AndroidRuntime(828): at com.dailybruin.bruinframework.channels.StoryListActivity.onCreate(StoryListActivity.java:18) 
10-16 19:23:12.632: E/AndroidRuntime(828): at android.app.Activity.performCreate(Activity.java:5133) 
10-16 19:23:12.632: E/AndroidRuntime(828): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087) 
10-16 19:23:12.632: E/AndroidRuntime(828): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2175) 
10-16 19:23:12.632: E/AndroidRuntime(828): ... 11 more 

不知道是否有帮助,但SplashActivity和MagazinePagesActivity都扩展JSONItemsActivity,分别。

在此先感谢您的帮助!我对Android非常陌生,请耐心等待。

编辑:这是奇怪,调试语句,我把检查ArrayList中为空返回true,但内parseJSON另一个调试声明显示,被添加的东西。我的parseJSON方法:

public ArrayList<Item> parseJSON(String jsonString) { 
    ArrayList<Item> magazines = new ArrayList<Item>(); 
    JSONArray jArray; 
    try { 
     jArray = new JSONArray(jsonString); 

     JSONObject jObject; 
     JSONObject image; 
     String img; 
     String title; 
     String subtitle; 
     int commentCount; 
     String content; 
     String date; 
     String ID; 
     String slug; 
     JSONArray array; 
     String[] tags; 
     for (int i = 0; i < jArray.length(); i++) { 
      jObject = jArray.getJSONObject(i); 
      img = jObject.getString("tall_image_url"); 
      if (img.equals("")) 
       img = jObject.getString("image_url"); 
      if (img.equals("") && !jObject.isNull("poster_image")) { 
       image = jObject.getJSONObject("poster_image"); 
       img = image.getString("name"); 
      } 
      title = jObject.getString("title"); 
      subtitle = jObject.getString("subtitle"); 
      commentCount = jObject.getInt("comment_count"); 
      content = jObject.getString("content_html"); 
      date = jObject.getString("creation_date"); 
      ID = jObject.getString("id"); 
      slug = jObject.getString("slug"); 
      array = jObject.getJSONArray("tags_list"); 
      tags = new String[array.length()]; 
      for (int j = 0; j < array.length(); j++) { 
       tags[j] = array.getString(j); 
      } 

      for (String tag : tags) { 
       if (tag.equals(this.tag)) 
       { 
        Post additive = new Post(img, title, subtitle, 
          commentCount, content, date, ID, slug, tags); 
        magazines.add(additive); 
        Log.d("SplashActivity", additive.toString()); 
       } 
      } 

     } 

    } catch (JSONException e) { 
     // TODO Auto-generated catch block 
     e.printStackTrace(); 
    } 
    return magazines; 
} 

StoryListActivity线27:

public void loadItems() { 
    (findViewById(R.id.progress_bar)).setVisibility(View.GONE); 
    getSupportFragmentManager().beginTransaction() 
    .replace(R.id.loading, new StoryListFragment()).commit(); 
} 

StoryItemsActivity(MagazinePagesActivity和StoryListActivity扩展此类;这类扩展JSONItemsActivity,这SplashActivity也延伸):

package com.dailybruin.bruinframework.channels; 

import java.util.ArrayList; 

import org.json.JSONArray; 
import org.json.JSONException; 
import org.json.JSONObject; 

import com.dailybruin.bruinframework.R; 
import com.dailybruin.bruinframework.base.BaseActivity; 
import com.dailybruin.bruinframework.base.URLBuilder; 
import android.os.Bundle; 

public abstract class StoryItemsActivity extends JSONItemsActivity { 

@Override 
public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
} 

public String sourceURL() 
{ 
    return URLBuilder.getPostsURL(getString(R.string.slug)); 
} 

public ArrayList<Item> parseJSON(String jsonString) { 
    // Using pre-downloaded and parsed JSON 
    return SplashActivity.downloadedItems; 
} 
} 

回答

0

检查这部分代码。第27行。这是空的,因此导致NPE。

Caused by: java.lang.NullPointerException 10-16 19:23:12.632: E/AndroidRuntime(828): at com.dailybruin.bruinframework.channels.StoryListActivity.loadItems(StoryListActivity.java:27)

+0

感谢您的回应!当我评论它时,仍然有错误;如果你想看看它,我会将它更新到主文章中。 StoryListActivity扩展了MagazinePagesActivity也扩展的StoryItemsActivity;也许它可能是那个班级?我还用该类的代码更新了主帖。 – user2884505

相关问题