微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

未将对象引用设置到对象的实例未处理NullReferenceException

在敲机房重构的过程中,遇到了各种各样的问题,其中有这样一个问题:“未将对象设置到对象的实例”,如下图:

这个问题真的很常见,也很令人纠结;尤其是这段时间我旁边的好多人都遇到了这个问题,调试了好多天都找不到解决办法,真是折磨人啊。

那么这个错误到底是哪里的问题呢?其实,这个有很多方面的原因,我就我所遇到的情况说一下。

1、 未使用new初始化对象。

在定义实体类或者某个层时,有时候会忘记加new

2、 命名错误

有时候我们会重新给类进行命名,但是忘记重新生成解决方案或者已经生成但是不知道什么原因造成保存的文件与程序中类的名字不一致,这样也会导致这种问题的出现。还有一种命名错误是存在于程序中的,因为重命名,但是代码中的名字并没有重新生成,导致不一致,出现错误

这个错误常见于工厂+反射+配置文件这部分,好多人都出现了这样的问题。在这里提醒大家认真注意:第一,检查自己的类名是否因为自己的重命名而不一致(尤其是D层);第二,工厂中的字符拼接起来与自己的D层中的相关类的名称是一致的;第三,检查自己的保存路径下的文件中的名称与自己的程序中断名称是否一致;第四,如果你使用了配置文件,那么一定要注意D层的类名要包含配置文件你所设定的字符,具体如下:


3、 控件属性未设置。

该问题我是在做导出Excel这部分时遇到的,我将返回的数据在DataGridView控件中显示,一开始的都显示成功,没有出现什么错误,但是在做组合查询的时候就出现了该问题。还好记得之前看过师姐的一篇博客,有记录该问题的解决办法,就是将控件的allowUserToAddRows属性设置为False


这是目前我遇到这个问题的几种类型,当然这样的问题还有很多方面的原因,希望这几种方法能给大家带来思路。也希望有其他问题和解决思路的伙伴们,给出思路,大家一块探讨,共同进步。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Format[$] ( expr [ , fmt ] ) format 返回变体型 format$ 强制返回为文本 -------------------------------- 数字类型的格式化 --------------------------------     固定格式参数:     General Number 普通数字,如可以用来去掉千位分隔号     format$("100,1
VB6或者ASP 格式化时间为 MM/dd/yyyy 格式,竟然没有好的办法, Format 或者FormatDateTime 竟然结果和系统设置的区域语言的日期和时间格式相关。意思是尽管你用诸如 Format(Now, "MM/dd/yyyy"),如果系统的设置格式区域语言的日期和时间格式分隔符是"-",那他还会显示为 MM-dd-yyyy     只有拼凑: <%response.write
在项目中添加如下代码:新建窗口来显示异常信息。 Namespace My ‘全局错误处理,新的解决方案直接添加本ApplicationEvents.vb 到工程即可 ‘添加后还需要一个From用来显示错误。如果到这步还不会则需要先打好基础啦 ‘======================================================== ‘以下事件
转了这一篇文章,原来一直想用C#做k3的插件开发,vb没有C#用的爽呀,这篇文章写与2011年,看来我以前没有认真去找这个方法呀。 https://blog.csdn.net/chzjxgd/article/details/6176325 金蝶K3 BOS的插件官方是用VB6编写的,如果  能用.Net下的语言工具开发BOS插件是一件很愉快的事情,其中缘由不言而喻,而本文则是个人首创,实现在了用V
Sub 分列() ‘以空格为分隔符,连续空格只算1个。对所选中的单元格进行处理 Dim m As Range, tmpStr As String, s As String Dim x As Integer, y As Integer, subStr As String If MsgBox("确定要分列处理吗?请确定分列的数据会覆盖它后面的单元格!", _
  窗体代码 1 Private Sub Text1_OLEDragDrop(Data As DataObject, Effect As Long, Button As Integer, Shift As Integer, X As Single, Y As Single) 2 Dim path As String, hash As String 3 For Each fil
  Imports MySql.Data.MySqlClient Public Class Form1 ‘ GLOBAL DECLARATIONS Dim conString As String = "Server=localhost;Database=net2;Uid=root;Pwd=123456;" Dim con As New MySqlConnection
‘導入命名空間 Imports ADODB Imports Microsoft.Office.Interop   Private Sub A1() Dim Sql As String Dim Cnn As New ADODB.Connection Dim Rs As New ADODB.Recordset Dim S As String   S = "Provider=OraOLEDB.Oracl
Imports System.IO Imports System.Threading Imports System.Diagnostics Public Class Form1 Dim A(254) As String    Function ping(ByVal IP As Integer) As String Dim IPAddress As String IPAddress = "10.0.
VB运行EXE程序,并等待其运行结束 参考:https://blog.csdn.net/useway/article/details/5494084 Private Declare Function WaitForSingleObject Lib "kernel32" (ByVal hHandle As Long, ByVal dwMilliseconds As Long) As Long Pr