asp.net2.0中泛型的使用

泛型的使用

前段时间在研究Petshop4.0的代码时,发现微软在业务逻辑层调用的实体类全部用的是泛型,由于没有时间一直没有发表这篇文章,这会正好有点困不愿意写代码只好把上次没有发表的东西整理一下发表了!

至于泛型的用处还有优点什么的我就不说,因为我也没有完全理解,只是知道泛型是类型安全的免除了拆箱装箱的操作,性能会好点;还有就是泛型其实就是将类参数化(一家之言)

下面就介绍一下petshop中用到的泛型吧!

微软主要是在业务逻辑层进行操作数据库的时候用到了泛型,将实体类传过去进行操作而不是对实体类的每个属性单独操作。

下面就贴一段代码(语文水平太差,写着太费劲)

1.实体类的代码就不贴了吧(就是一些getter,setter)(微软推荐:实体类要可以序列化)

2.只是一般的测试也没有分层,把逻辑层放在表现层中间了啊

private IList<CustomersM> GetAllCustomers()

{

    IList<CustomersM> customer = new List<CustomersM>();

    using (SqlConnection connection = new SqlConnection(ConfigurationManager.ConnectionStrings["cc_2005"].ConnectionString))

    {

        connection.Open();

        SqlCommand command = new SqlCommand("SELECT  [CompanyName], [ContactName], [ContactTitle], [Address], [City] FROM [Customers]", connection);

        SqlDataReader sdr=command.ExecuteReader(CommandBehavior.CloseConnection);

        while (sdr.Read())

        {

            //实体类中没有初始化属性的构造函数

            /*CustomersM m = new CustomersM();

            m.CompanyName = sdr[0].ToString();

            m.ContactName = sdr[1].ToString();

            m.ContactTitle = sdr[2].ToString();

            m.Address = sdr[3].ToString();

            m.City = sdr[4].ToString();

             *

             */

            //实体类中有初始化属性的构造函数

            CustomersM m = new CustomersM(sdr[0].ToString(), sdr[1].ToString(), sdr[2].ToString(), sdr[3].ToString(), sdr[4].ToString());

            customer.Add(m);

        }

        return customer;

    }

}

 

3.这样GetAllCustomers就可以绑定到GridView,DropDownList等控件上了。

注意:IList是不能序列化的,因此当需要序列化的时候(如:webservice,由于webservice中传递的对象都是可以序列化的)必须使用System.Collections.ObjectModel.Collection< >

 

代码如下:

private System.Collections.ObjectModel.Collection<CustomersM> GetCustomers()

{

    System.Collections.ObjectModel.Collection<CustomersM> customer = new System.Collections.ObjectModel.Collection<CustomersM>();

    using (SqlConnection connection = new SqlConnection(ConfigurationManager.ConnectionStrings["cc_2005"].ConnectionString))

    {

        connection.Open();

        SqlCommand command = new SqlCommand("SELECT  [CompanyName], [ContactName], [ContactTitle], [Address], [City] FROM [Customers]", connection);

        SqlDataReader sdr = command.ExecuteReader(CommandBehavior.CloseConnection);

        while (sdr.Read())

        {

            CustomersM m = new CustomersM(sdr[0].ToString(), sdr[1].ToString(), sdr[2].ToString(), sdr[3].ToString(), sdr[4].ToString());

            customer.Add(m);

        }

        return customer;

    }

}

 

友情提示:

webservice中如果把上面两个调用数据库的方法搬过去(好多命名空间要添加),使用IList<>类型的就会报错,“IList不能序列化接口”,而使用Collection<>的就可以正常使用,这一点要记住了!

我总结的不对的地方请指出,谢谢!

 

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值