我是Android开发新手,现在面临致命错误。我想创建一个动态添加TableRows的表。在makeNewRow()的第二行,我得到一个NullPointerException。在其他问题中,我发现在初始化TableRow之前可能没有设置ContentView,但我的onCreate方法正常工作。在手机上测试该应用时,我会在应用崩溃之前在屏幕上看到已经包含一行的TableLayout。 但是,我猜这是我的“这”的任何错误,但我迄今没有找到任何帮助...NPE Android动态初始化TableRows
注意了解代码:AsyncTask JSONDownload返回一个JSONArray并在其调用makeNewRow() postExecute() - 方法。 JSONArray被正确填充。
package com.***;
import org.json.JSONArray;
import org.json.JSONException;
import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.ViewGroup.LayoutParams;
import android.widget.TableLayout;
import android.widget.TableRow;
import android.widget.TextView;
public class Tabelle extends Activity {
url= "***";
JSONDownloader jdown;
TableLayout tl;
@Override
public void onCreate(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_tabelle);
tl = (TableLayout) findViewById(R.id.tabelleLayout);
new JSONDownloader().execute(url);
}
public void makeNewRow(JSONArray platzierung, int row) {
row++;
TableRow tr = new TableRow(this);
tr.setId(100+row);
tr.setLayoutParams(
new LayoutParams(
LayoutParams.MATCH_PARENT,
LayoutParams.WRAP_CONTENT)
);
TextView platz = new TextView(this);
platz.setId(200+row);
platz.setText(row);
platz.setLayoutParams(
new TableRow.LayoutParams(
0,
LayoutParams.WRAP_CONTENT,
1f)
);
tr.addView(platz);
/**other textviews **/
tl.addView(tr);
}
}
的logcat的:
11-04 17:26:59.859: E/AndroidRuntime(5389): FATAL EXCEPTION: main
11-04 17:26:59.859: E/AndroidRuntime(5389): java.lang.NullPointerException
11-04 17:26:59.859: E/AndroidRuntime(5389): at android.content.ContextWrapper.getResources(ContextWrapper.java:81)
11-04 17:26:59.859: E/AndroidRuntime(5389): at android.view.View.<init>(View.java:3228)
11-04 17:26:59.859: E/AndroidRuntime(5389): at android.view.ViewGroup.<init>(ViewGroup.java:416)
11-04 17:26:59.859: E/AndroidRuntime(5389): at android.widget.LinearLayout.<init>(LinearLayout.java:168)
11-04 17:26:59.859: E/AndroidRuntime(5389): at android.widget.TableRow.<init>(TableRow.java:61)
11-04 17:26:59.859: E/AndroidRuntime(5389): at com.***.Tabelle.makeNewRow(Tabelle.java:51)
11-04 17:26:59.859: E/AndroidRuntime(5389): at com.***.Tabelle.showTable(Tabelle.java:37)
11-04 17:26:59.859: E/AndroidRuntime(5389): at com.***.JSONDownloader.onPostExecute(JSONDownloader.java:79)
11-04 17:26:59.859: E/AndroidRuntime(5389): at com.***.JSONDownloader.onPostExecute(JSONDownloader.java:1)
11-04 17:26:59.859: E/AndroidRuntime(5389): at android.os.AsyncTask.finish(AsyncTask.java:631)
11-04 17:26:59.859: E/AndroidRuntime(5389): at android.os.AsyncTask.access$600(AsyncTask.java:177)
11-04 17:26:59.859: E/AndroidRuntime(5389): at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:644)
11-04 17:26:59.859: E/AndroidRuntime(5389): at android.os.Handler.dispatchMessage(Handler.java:99)
11-04 17:26:59.859: E/AndroidRuntime(5389): at android.os.Looper.loop(Looper.java:137)
11-04 17:26:59.859: E/AndroidRuntime(5389): at android.app.ActivityThread.main(ActivityThread.java:4931)
11-04 17:26:59.859: E/AndroidRuntime(5389): at java.lang.reflect.Method.invokeNative(Native Method)
11-04 17:26:59.859: E/AndroidRuntime(5389): at java.lang.reflect.Method.invoke(Method.java:511)
11-04 17:26:59.859: E/AndroidRuntime(5389): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:791)
11-04 17:26:59.859: E/AndroidRuntime(5389): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:558)
11-04 17:26:59.859: E/AndroidRuntime(5389): at dalvik.system.NativeStart.main(Native Method)
希望有人能帮帮我! :)
编辑:这里是我的onPostExecute(代码):
@Override
protected void onPostExecute (JSONArray jarray){
table=new Tabelle();
table.showTable(jarray);
}
请正确格式化您的logcat并为您的onPostExecute添加代码。 – Simon