空指针指向 addView
Posted
技术标签:
【中文标题】空指针指向 addView【英文标题】:null pointer point addView 【发布时间】:2011-07-10 00:49:30 【问题描述】:我试图以编程方式将文本视图添加到线性布局,但我的线性布局上不断收到一个空指针。它在布局膨胀后被调用,所以我不明白它为什么会发生。这是代码。
tile_layout.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/master"
android:orientation="horizontal"
android:layout_
android:layout_>
<TextView
android:id="@+id/fragment_two_directory"
android:layout_
android:layout_
android:text="Testing Fragment Two" />
</LinearLayout>
fragment_two.java
public class fragment_two extends Fragment
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState)
return inflater.inflate(R.layout.tile_layout,container, false);
public static fragment_two newInstance(String directory, Activity activity)
fragment_two ft = new fragment_two();
TextView text = (TextView)activity.findViewById(R.id.fragment_two_directory);
text.setText(directory);
return ft;
public static void setDirectoryText(String directory, Activity activity)
TextView directoryText = (TextView)activity.findViewById(R.id.fragment_two_directory);
directoryText.setText(directory);
populateDirectory(directory, activity);
public static void populateDirectory(String directory, Activity activity)
LinearLayout masterLinear = (LinearLayout)activity.findViewById(R.id.master);
TextView testText = new TextView(activity);
testText.setText("test");
masterLinear.addView(testText);
//testText.setText("Testing Add View");
//for (int x=0; x < 5; x++)
//FrameLayout container = new FrameLayout(getActivity());
//container.setLayoutParams(new FrameLayout.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));
//ImageView fileImage = new ImageView(getActivity());
//fileImage.setLayoutParams(new FrameLayout.LayoutParams(110, 110));
//fileImage.setImageResource(R.drawable.blank_file);
//container.addView(fileImage);
//TextView fileName = new TextView(getActivity());
//fileName.setLayoutParams(new FrameLayout.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));
//fileName.setText("Filename.txt");
//container.addView(fileName);
//masterLinear.addView(container);
//
最后是主要活动
package com.bv.dual_fragments;
import com.bv.dual_fragments.fragment_one.OnArticleSelectedListener;
import android.app.Activity;
import android.net.Uri;
import android.os.Bundle;
import android.widget.TextView;
public class dual_fragments extends Activity implements OnArticleSelectedListener
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState)
super.onCreate(savedInstanceState);
setContentView(R.layout.test);
//((global_holder)this.getApplication()).setDirectory("test");
@Override
public void onArticleSelected(String directory)
//fragment_two frag_two = (fragment_two)getFragmentManager().findFragmentById(R.id.container);
//TextView containerText = (TextView)findViewById(R.id.fragment_two_directory);
//containerText.setText(directory);
fragment_two.populateDirectory(directory, this);
这是 LogCat
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): FATAL EXCEPTION: main
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): java.lang.NullPointerException
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at com.bv.dual_fragments.fragment_two.populateDirectory(fragment_two.java:36)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at com.bv.dual_fragments.dual_fragments.onArticleSelected(dual_fragments.java:25)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at com.bv.dual_fragments.fragment_one.onListItemClick(fragment_one.java:88)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.app.ListFragment$2.onItemClick(ListFragment.java:160)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.widget.AdapterView.performItemClick(AdapterView.java:282)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.widget.AbsListView.performItemClick(AbsListView.java:1032)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.widget.AbsListView$PerformClick.run(AbsListView.java:2447)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.widget.AbsListView.onTouchEvent(AbsListView.java:3077)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.widget.ListView.onTouchEvent(ListView.java:3566)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.view.View.dispatchTouchEvent(View.java:4600)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:1488)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1256)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:1494)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1269)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:1494)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1269)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:1494)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1269)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:1494)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1269)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:1494)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1269)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:1494)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:1269)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at com.android.internal.policy.impl.PhoneWindow$DecorView.superDispatchTouchEvent(PhoneWindow.java:1700)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at com.android.internal.policy.impl.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1270)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.app.Activity.dispatchTouchEvent(Activity.java:2271)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchTouchEvent(PhoneWindow.java:1680)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.view.ViewRoot.deliverPointerEvent(ViewRoot.java:2272)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.view.ViewRoot.handleMessage(ViewRoot.java:1958)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.os.Handler.dispatchMessage(Handler.java:99)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.os.Looper.loop(Looper.java:126)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at android.app.ActivityThread.main(ActivityThread.java:3997)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at java.lang.reflect.Method.invokeNative(Native Method)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at java.lang.reflect.Method.invoke(Method.java:491)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:841)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:599)
03-06 17:35:47.452: ERROR/AndroidRuntime(3576): at dalvik.system.NativeStart.main(Native Method)
我也在蜂窝模拟器中运行了这个,并查看了层次结构查看器。我在该布局文件中有两个线性布局,它们都没有出现,只有文本视图。
【问题讨论】:
请发布整个回溯。 这里有来自 DDMS 的 logcat,我想这就是你想要的。 是的,就是这样。无论如何,其中一些。它看起来并不完整。我没有看到“由”行。你确定这就是全部吗? 这是另一部分,但这就是它 03-06 17:35:36.332:WARN/ActivityManager(131): ActivityRecord40ca9b98 com.bv.dual_fragments/.dual_fragments 03 的活动空闲超时-06 17:35:46.172: DEBUG/AndroidRuntime(3576): 关闭 VM 03-06 17:35:46.172: WARN/dalvikvm(3576): threadid=1: thread exiting with unaught exception (group=0x40151760)跨度> 我可能需要不同版本的 Eclipse,到目前为止,其中的调试器很糟糕。不能使用断点,因为我只得到 Local Source Not found 错误,并且 logcat 并没有真正告诉我任何事情。 【参考方案1】:好的,问题是布局文件被弄乱了,我有两个水平的线性布局,因此层次结构不会加载它们,从而给出空点异常。对于任何查看 Android 3.0 的 heirarchyviewer 的人来说,这只是一个提示,片段(在布局文件中)将自动获得其膨胀视图中的第一个布局标签的所有权。所以说你有
<fragment android:id="@+id/viewer" />
在你的布局文件中
<LinearLayout android:id="@+id/first_layout" />
在层次结构查看器中,LinearLayout 将显示为查看器,而不是 first_layout,因为片段没有默认布局,它会将其布局文件中的第一个布局容器重新标识为自己的 id。
【讨论】:
如何克服?【参考方案2】:如果您要查找R.id.master
,是否应该将内容视图设置为R.id.tile_layout
?
现在您正在test.xml
中寻找它。
【讨论】:
不,这是一个分片布局,意思是不同的分片调用不同的布局。 Activity 扩展了一个布局,该布局实际上包含其中的其他布局。【参考方案3】:您确定在 OnCreate() 之后调用 OnArticleSelected() 吗?如果 findViewById(id) 在调用 setContentView(layout) 之前被调用,它将返回 null。也尝试改变这一行:
fragment_two.populateDirectory(directory, this);
到这里:
fragment_two.populateDirectory(directory, dual_fragments.this);
如果由于某种原因传入了活动以外的其他内容,则会破坏某些内容。我知道在从 OnClickListener 内部为按钮进行调用时,您需要像这样与众不同,但我不熟悉您正在使用的侦听器,所以我不确定是否有必要。 Matthew 提出了一个很好的观点,确保您指向正确的 .xml 文件。
【讨论】:
是的,它只有在我单击不同片段中的某些内容后才会调用。生病试试你的改变,看看是否有效。它是正确的 xml 文件。该活动使用包含片段的 test.xml。 fragment_two 使用 tile_layout.xml 作为其布局。以上是关于空指针指向 addView的主要内容,如果未能解决你的问题,请参考以下文章