C#中new一个对象的过程说明

在代码中我们经常能看到下面这样的语句。

A a = new A();(1)
B b = null;(2)
C c;(3)

代码(1

创建A的对象并对其进行初始化。

A:类;

new A():创建A的对象并对其初始化;

a:引用,指向new A()这个对象的引用。

注意:a不是A的对象,new A()才是A的对象。

 

代码(2

声明引用b,并指向null

B:类;

b:引用,指向的对象为null(空)。

 

代码(3

与代码(2)一样,声明一个引用

与代码(2)的区别是:代码(3)中声明的引用c不指向任何对象。

提示:变量本质上是引用的一个别名而已


由上面的分析可以了解到,在C#中实例化一个对象时,需要经历下面这几步:

  • 声明引用;
  • 使用new关键字创建类的对象并对其初始化;(分配内存空间)
  • 将引用指向类的对象。

若没有使用new关键字创建类的实例,则仅仅创建引用,指向的对象为null

 

实例说明

public class ExampleModel
{
    public int C1 { get; set; }
    public string C2 { get; set; }
}
 
ExampleModel e1 = new ExampleModel();
ExampleModel e2 = null;
ExampleModel e3;
 
if (e1 == null)
{
    Console.WriteLine("e1 == null");
}
else
{
    Console.WriteLine("{ C1 = " + e1.C1 + ", C2 = " + e1.C2 + " }");
}
 
if (e2 == null)
{
    Console.WriteLine("e2 == null");
}
else
{
    Console.WriteLine("{ C1 = " + e2.C1 + ", C2 = " + e2.C2 + " }");
}
 
if (e3 == null)
{
    Console.WriteLine("e3 == null");
}
else
{
     Console.WriteLine("{ C1 = " + e3.C1 + ", C2 = " + e3.C2 + " }");
}
编译代码,会出现编译错误,提示“使用了未赋值的局部变量 e3 ”,原因是并未对 e3 进行初始化,但是使用 e2 变量时并不会产生编译错误,因为 e2 已经被初始化了,只是初始化的值为 null 而已,这并不影响编译的通过。

注释掉e3 部分的代码,运行程序得到下图所示的结果。

 

在开发过程中,我们还是尽量不要让一个引用指向null,否则在运行过程中很容易出现空引用的异常。

修改e2部分的代码,去掉e2是否为空引用的条件判断,并运行程序。

运行中,会产生“未将对象引用设置到对象的实例。”的异常。(原因你懂的。)

同样去掉e1部分中是否为空引用的条件判断语句,再次执行程序,一切正常。(因为e1指向了不为null的对象)

 

 

 

  • 10
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
C# EF ,我们可以通过自动生成的模型对象(Model)来将业务对象和数据对象绑定。下面给出一个简单的例子来说明如何实现这一过程: 假设我们有一个简单的业务场景:我们需要对学生信息进行管理,包括添加、删除、修改和查询等操作。为了实现这一功能,我们需要在数据库创建一个名为“Student”的表,包含“ID”、“Name”和“Age”三个字段。 首先,我们需要创建一个 EF 的实体模型,可以通过 Visual Studio 的“添加新项”功能来创建。在“添加新项”对话框,选择“数据”分,然后选择“ADO.NET 实体数据模型”选项,按照提示一步步完成模型的创建。 接下来,我们需要在模型定义实体。在本例,我们可以定义一个名为“Student”的实体,代码如下: ``` public class Student { public int ID { get; set; } public string Name { get; set; } public int Age { get; set; } } ``` 在实体,我们需要指定每个属性对应的数据库字段。这可以通过在实体属性上使用“[Column]”特性来实现。 ``` public class Student { [Column("id")] public int ID { get; set; } [Column("name")] public string Name { get; set; } [Column("age")] public int Age { get; set; } } ``` 接下来,我们可以在业务逻辑层使用实体来进行业务处理。假设我们需要添加一个学生信息到数据库,可以通过以下代码实现: ``` using (var db = new MyDbContext()) { var student = new Student { Name = "Tom", Age = 18 }; db.Students.Add(student); db.SaveChanges(); } ``` 在这段代码,我们首先创建了一个名为“Tom”的学生对象,然后将其添加到 EF 的上下文,最后调用“SaveChanges()”方法将数据保存到数据库。 通过以上步骤,我们就可以将业务对象和数据对象绑定起来,并且实现了学生信息的添加功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值