空引用异常树视图

时间:2014-01-06 20:39:10

标签: c# view tree null

我在代码的这一部分继续得到Null Reference Exception:

  enumerator = this.Ds_Settings1.Tables["Settings_RefreshForm_ScriptMgmt_SelectALL"].Rows.GetEnumerator();

非常感谢任何帮助。

这是整个代码。这是创建一个树视图,使用带有存储过程的数据集列出所有脚本。

    private void Refresh_Form()
    {
        IEnumerator enumerator = null;
        IEnumerator enumerator1 = null;
        IEnumerator enumerator2 = null;
        try
        {
            this.tv_Scripts.Nodes.Clear();
            this.tv_Scripts.Nodes.Add(Conversions.ToString(0), "Standard Fixes");
            this.tv_Scripts.Nodes.Add(Conversions.ToString(0), "SQL Agent Updates");
            this.tv_Scripts.Nodes.Add(Conversions.ToString(0), "Other");
            try
            {

                enumerator = this.Ds_Settings1.Tables["Settings_RefreshForm_ScriptMgmt_SelectALL"].Rows.GetEnumerator();
                while (enumerator.MoveNext())
                {
                    DataRow script = (DataRow)enumerator.Current;
                    try
                    {
                        enumerator1 = this.tv_Scripts.Nodes.GetEnumerator();
                        while (enumerator1.MoveNext())
                        {
                            TreeNode ParentNode = (TreeNode)enumerator1.Current;
                            if (Microsoft.VisualBasic.CompilerServices.Operators.CompareString(ParentNode.Text, script[4].ToString(), false) != 0)
                            {
                                continue;
                            }
                            ParentNode.Nodes.Add(script[1].ToString(), script[1].ToString(), 1, 1);
                            int index = ParentNode.Index;
                            this.TreeNode_SetStateImageIndex(ParentNode, Conversions.ToInteger(index.ToString()));
                        }
                    }
                    finally
                    {
                        if (enumerator1 is IDisposable)
                        {
                            (enumerator1 as IDisposable).Dispose();
                        }
                    }
                }
            }
            finally
            {
                if (enumerator is IDisposable)
                {
                    (enumerator as IDisposable).Dispose();
                }
            }
            this.cmb_Environment.Items.Clear();
            try
            {
                enumerator2 = this.Ds_Settings1.Tables["Settings_Environments_Select"].Rows.GetEnumerator();
                while (enumerator2.MoveNext())
                {
                    object env = RuntimeHelpers.GetObjectValue(enumerator2.Current);
                    object[] objArray = new object[] { 5 };
                    if (!Microsoft.VisualBasic.CompilerServices.Operators.ConditionalCompareObjectEqual(NewLateBinding.LateIndexGet(env, objArray, null), true, false))
                    {
                        continue;
                    }
                    ComboBox.ObjectCollection items = this.cmb_Environment.Items;
                    object[] objArray1 = new object[] { 1 };
                    items.Add(NewLateBinding.LateIndexGet(env, objArray1, null).ToString());
                }
            }
            finally
            {
                if (enumerator2 is IDisposable)
                {
                    (enumerator2 as IDisposable).Dispose();
                }
            }
            this.tv_Scripts.ExpandAll();
        }
        catch (Exception exception)
        {
            ProjectData.SetProjectError(exception);
            this.DisplayOnly_ErrorHandler("ERROR REFRESHING FORM DATA: ", exception.Message, MsgBoxStyle.Critical);
            ProjectData.ClearProjectError();
        }
    }

这是堆栈跟踪:

  

位于C:\ Users \ BSantiago \ Documents \ Visual Studio 2010 \ Projects \ SQLRefreshTool \ SQLRefreshTool \ Form1.cs中的SQLRefreshTool.SQLRefreshTool.Refresh_Form():第179行      在C:\ Users \ BSantiago \ Documents \ Visual Studio 2010 \ Projects \ SQLRefreshTool \ SQLRefreshTool \ Form1.cs:line 123中的SQLRefreshTool.SQLRefreshTool..ctor()      在C:\ Users \ BSantiago \ documents \ visual studio 2010 \ Projects \ SQLRefreshTool \ SQLRefreshTool \ Program.cs中的SQLRefreshTool.Program.Main():第18行      在System.AppDomain._nExecuteAssembly(Assembly assembly,String [] args)      在System.AppDomain.ExecuteAssembly(String assemblyFile,Evidence assemblySecurity,String [] args)      在Microsoft.VisualStudio.HostingProcess.HostProc.RunUsersAssembly()      在System.Threading.ThreadHelper.ThreadStart_Context(对象状态)      在System.Threading.ExecutionContext.Run(ExecutionContext executionContext,ContextCallback回调,对象状态)      在System.Threading.ThreadHelper.ThreadStart()

1 个答案:

答案 0 :(得分:0)

NullReferenceException告诉您正在尝试访问null对象上的属性或方法。虽然类型兼容(没有编译时错误),因为为对象类型定义了attr /方法,但在运行时,您的对象结果为null。

有两种可能的原因:

this.Ds_Settings1

this.Ds_Settings1.Tables["Settings_Environments_Select"]

为空。

以调试模式检查每一个。

异常不是由Rows引起的,因为它应该是一个空列表,而不是null,即使你的表没有行。