Object reference not set to an instance of an object.一般是什么原因造成?

alanzhou 2005-08-29 04:55:50
Object reference not set to an instance of an object.一般是什么原因造成?
...全文
124990 17 打赏 收藏 转发到动态 举报
写回复
用AI写文章
17 条回复
切换为时间正序
请发表友善的回复…
发表回复
易酷天 2010-05-27
  • 打赏
  • 举报
回复
private string marshalColumn;

public void InitStorage(string sConnectionString,string sTable,string sKey,string sProgID,string sMarshalColumn,string sDateChanged)
{
connectionString = sConnectionString;
tableNamne = sTable;
primaryKey = sKey;
if(!Convert.IsDBNull(sProgID))
progID = sProgID;
else
progID = string.Empty;

if(!Convert.IsDBNull(sMarshalColumn))
marshalColumn = sMarshalColumn;
else
marshalColumn = " ";
if(!Convert.IsDBNull(sDateChanged))
dateChanged = sDateChanged;
else
dateChanged = string.Empty;
}
这个在InsertData之前调用了
3tzjq 2005-08-30
  • 打赏
  • 举报
回复
if(!Convert.IsDBNull(sMarshalColumn))
marshalColumn = sMarshalColumn;
else
marshalColumn = "";

直接改为:marshalColumn = sMarshalColumn;

alanzhou 2005-08-30
  • 打赏
  • 举报
回复
private string marshalColumn;

public void InitStorage(string sConnectionString,string sTable,string sKey,string sProgID,string sMarshalColumn,string sDateChanged)
{
connectionString = sConnectionString;
tableNamne = sTable;
primaryKey = sKey;
if(!Convert.IsDBNull(sProgID))
progID = sProgID;
else
progID = string.Empty;

if(!Convert.IsDBNull(sMarshalColumn))
marshalColumn = sMarshalColumn;
else
marshalColumn = "";
if(!Convert.IsDBNull(sDateChanged))
dateChanged = sDateChanged;
else
dateChanged = string.Empty;
}
这个在InsertData之前调用了
3tzjq 2005-08-30
  • 打赏
  • 举报
回复
贴出你的 marshalColumn 属性看一下。
alanzhou 2005-08-30
  • 打赏
  • 举报
回复
else
{
#if DEBUG
Console.Write("marshalColumn=" + marshalColumn + "!"); //这里没有输出
#endif

这里就没有输出了,到不了下面的代码
3tzjq 2005-08-30
  • 打赏
  • 举报
回复
可疑代码:
OrderForm objOrderF = orderform as OrderForm;

Dictionary objShopper = orderform as Dictionary;

fac.Save(objOrderF|objShopper); 时可能objShopper = null。
if(obj... != null)fac.Save(obj...)
alanzhou 2005-08-30
  • 打赏
  • 举报
回复
这是用C#写COM给asp调。我在工程里用vbs来测。

public void InsertData(object a,object orderform)
{
string sql = string.Format("SELECT * FROM {0} WHERE {1} = @{1} ", tableNamne, primaryKey); //这个我试过输出了正确
#if DEBUG
Console.Write("marshalColumn=" + marshalColumn + "!"); //marshalColumn是private property,这里输出 marshalColumn=!
#endif
if(marshalColumn != "")
{
fac = new OrderFormFac(connectionString, sql,marshalColumn,"^_.*");
OrderForm objOrderF = orderform as OrderForm;
fac.Save(objOrderF);
}
else
{
#if DEBUG
Console.Write("marshalColumn=" + marshalColumn + "!"); //这里没有输出
#endif

fac = new OrderFormFac(connectionString,sql);
Dictionary objShopper = orderform as Dictionary;
#if DEBUG
Console.Write("orderform.shopper_id=" + objShopper["shopper_id"]);
#endif
fac.SaveAs(objShopper);
}

}

然后错误信息Object reference not set to an instance of an object

这么怎么回事?
alanzhou 2005-08-30
  • 打赏
  • 举报
回复
居然还是报这个错!
还要检查。

搞定了就给分
xamaizi 2005-08-30
  • 打赏
  • 举报
回复
变量为初始化造成的
cdo 2005-08-30
  • 打赏
  • 举报
回复
就是该对象为null
3tzjq 2005-08-30
  • 打赏
  • 举报
回复
string 类型应该用 if (marshalColumn != string.Empty) 判断。而marshalColumn = "" 和 marshalColumn = string.Empty 结果是一样的!所以不用判断。
alanzhou 2005-08-30
  • 打赏
  • 举报
回复
ok,搞定了,谢谢3tzjq(永不言弃)。

为什么会这样?
alanzhou 2005-08-29
  • 打赏
  • 举报
回复
谢谢,找到那个未实例化的对象了。
看别人的代码挺累的。
xianggang101 2005-08-29
  • 打赏
  • 举报
回复
或者你用的变量根本就没有!
MyLf 2005-08-29
  • 打赏
  • 举报
回复
就是没有实例化一个对象啦
速马 2005-08-29
  • 打赏
  • 举报
回复
比如:

string GetText()
{
return null;
}

void ParseText()
{
string[] values = GetText().Split(',');
}
linfengcyl 2005-08-29
  • 打赏
  • 举报
回复
译:未将对象引用到对象的实例.
声明了变量,但是没有赋值,仍然为null.用的时候就会报错.

110,534

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧