我在代码的这一部分继续得到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()
答案 0 :(得分:0)
NullReferenceException告诉您正在尝试访问null对象上的属性或方法。虽然类型兼容(没有编译时错误),因为为对象类型定义了attr /方法,但在运行时,您的对象结果为null。
有两种可能的原因:
this.Ds_Settings1
或
this.Ds_Settings1.Tables["Settings_Environments_Select"]
为空。
以调试模式检查每一个。
异常不是由Rows引起的,因为它应该是一个空列表,而不是null,即使你的表没有行。