前言

我们都知道在机房重构的时候,大多数都在用七层进行重构,每一层都依赖实体。所以不管怎么调用,返回的应该是实体参数,这样才符合大多数的逻辑,这样我们试想一下,如果我们要求在U层返回多个实体值,怎么办,返回一个布尔进行B层的判断,这些问题,根据SQLHelper,增、删、改、查四条线,分为了无参和有参两种类型,查询的时候我们要求返回一个datatable,可是如果单单用这个datatable返回会不会么有实体的事情了。所以这时候泛型就出来了。在我看来它集成了所以实体的集合,方便,简单,减少内存的占用。

泛型

定义

泛型是具有占位符(类型参数)的类、结构、接口和方法,这些占位符是类、结构、接口和方法存储或者使用的一个或多个类型的占位符。泛型集合类可以将类型参数用作它所存储的对象的类型的占位符;类型参数作为其字段的类型或其方法的参数类型出现。泛型的方法还可以将参数类型用作返回值类型或者某个形参的类型。

上面的解释是官方解释,下面是我自己的理解:

  • 泛型就是一种集合,封装了一种类型的转换,让该类型只能转换为一种类型。很好的避免了装箱和拆箱的过程。
  • 泛型是引用类型,分配到堆中,若要将值类型打包到引用类型(object)一个实例中

不用泛型的情况:

装箱C#版

        int i = 123;
object obj = (object)i;//装箱

拆箱C#版

        object obj = 123;
int i;
i=(int )obj;//拆箱

使用泛型:

        IList <T >;//T为集合数据或者指定的数据类型;
List <T>;//T为集合数据或者指定的数据类型;

下面来说我机房重构中,怎么使用泛型的,首先要将SQLHelper中返回的DataTable转换成泛型,需要定义一个转换类,通过调用这个类来实现转换。

ConvertList类

Imports System.Reflection
Module ConvertHelper
Public Class ConvertHelper
'将datatable转换为泛型集合
Public Shared Function ConvertToList(Of turn As {New})(ByVal dt As DataTable) As IList(Of turn)
'这里new是用来约束的; Dim mylist As New List(Of turn) '定义最终返回的集合
Dim myType As Type = GetType(turn) '得到实体类的类型名
Dim dr As DataRow '定义行集
Dim tmpName As String = String.Empty '定义一个临时变量 '遍历datatable表的所有数据行
For Each dr In dt.Rows
Dim myturn As New turn
Dim propertys() As PropertyInfo = myturn.GetType().GetProperties() '定义属性集合
Dim pr As PropertyInfo '遍历该对象的所有属性
For Each pr In propertys
tmpName = pr.Name '将属性名称赋值给临时变量
If (dt.Columns.Contains(tmpName)) Then '将此属性与datatable属性相比较,查看datatable是否包含了此属性;
'判断此属性是否含有setter If (pr.CanWrite = False) Then
Continue For
End If Dim value As Object = dr(tmpName) '定义一个对象型的变量来保存列的值
If (value.ToString <> DBNull.Value.ToString) Then '如果非空则赋给对象属性
pr.SetValue(myturn, value, Nothing) '在运行期间通过反射,动态的访问一个对象的属性
End If
End If
Next
mylist.Add(myturn) '添加到集合
Next
Return mylist
End Function
End Class
End Module

泛型和“DataTable”转换部分:

<span style="font-family:KaiTi_GB2312;font-size:18px;">
</pre><pre code_snippet_id="1597926" snippet_file_name="blog_20160305_5_4092007" name="code" class="html">    Public Function IsExistsLogInfo(BasicInfo As Login.Entity.BasicSetEntity) As List(Of Login.Entity.BasicSetEntity) Implements IBasicSetDAL.IsExistsLogInfo
Dim mylist1 As New List(Of Login.Entity.BasicSetEntity)
Dim table1 As DataTable
Dim sql As String = "Select * from TC_BasicData"
table1 = SQLHelper.sqlhelper.ExecSelectNo(sql, CommandType.Text)
mylist1 = ConvertHelper.ConvertHelper.ConvertToList(Of Login.Entity.BasicSetEntity)(table1)
Return mylist1
End Function</span>

泛型的好处:

1、  优于集合的使用,值类型和引用类型的转换不用进行拆装箱。

2、  泛型在使用或者实例化的时候,指明了内部的对象类型或内部数据,避免了集合类型的不安全。

3、  泛型在内存的处理上大于“DataTable”。

小结

1、  每一次和陌生知识的独处,都意味着一种成长。

2、  每一次的蜕变都意味着梦想的加温。

机房重构——泛型和“DataTable”的更多相关文章

  1. 泛型转Datatable

    //自定义扩展方法 public static class ExtMethod { //泛型转为DataTable public static DataTable AsDataTable<T&g ...

  2. 机房重构包图(从三层+实体到三层+实体+外观+工厂+接口+SQLHelper)

    刚刚开始接触三层的时候,我只做了两个登录小窗体的例子.画了简单的包图,可以说,为后面机房重构留下了大量的工作(因为三层理解没有深度,也没有理解出自己的东西).不过,欠下的总要还的.在做机房重构的时候, ...

  3. .NET重构(九):机房重构验收总结

    导读:机房收费系统个人重构版,在寒假前,已经结束了.嗯,这一路的过程,也挺心酸的.结合师傅验收时的指导.建议,对这一段时间的学习,进行一个总结. 一.学习过程 这一阶段的学习,按照师傅给的建议是:由浅 ...

  4. 【机房重构】—上机&amp;订餐

    前几天通过UML图中的时序图.让我对于机房重构中的每一条线理解的更加清晰.曾经认为上机特别的乱,在一次偶遇中,得知了原来它能够转化成我们平时订餐.以下就听我说一说上机&订餐的故事吧! 又是发生 ...

  5. 【C#】万事开头难(二)&lt;机房重构&gt;

    前言 机房将要进行完了,之所以仍然使用这个题目,是由于我想告诉自己.无论面对多么未知的事物.不要害怕,去做就好.在这么多天的机房重构中,发现了好多问题,也攻克了好多问题,今天,就把我解决的问题分享给大 ...

  6. 机房重构所遇问题&quot;未能载入文件或程序集“DAL”或它的某一个依赖项。系统找不到指定的文件&quot;的解决的方法集锦

    敲七层登录的时候.忽然间认为敲三层搞清的思路瞬间又凌乱了.花了一天的时间边敲边梳理,最终整完了,执行的时候弹出了这种错误:未能载入文件或程序集"DAL"或它的某一个依赖项. 系统找 ...

  7. 【机房重构】SQL之视图

    近期在重构机房收费系统,越往后就会越感觉到这里很多其它的是对之前学过知识(数据库,设计模式)的一种应用和回想.比方在登录功能中用到了抽象加反射,在学生下机中,我们能够用触发器来同一时候更新两个表.这里 ...

  8. List泛型与DataTable相互转换

    public static class ExtensionMethods{/// <summary>/// 将List转换成DataTable/// </summary>/// ...

  9. 机房重构——UML图最终版本

    刚开始画图时确实很纠结,那时候是在师父的逼迫下不得不画,不过这样也是有好处的,在师父的强烈要求下,我学会了如何使用EA,也对一个学习一个新的软件有了一个更好的方法,可以去找一些视频,或者文字资料来帮助 ...

随机推荐

  1. Delpih - Format

    Format是一个很常用,却又似乎很烦的方法,本人试图对这个方法的帮助进行一些翻译,让它有一个完整的概貌,以供大家查询之用: 首先看它的声明:function Format(const Format: ...

  2. KbmMW-及相关

    KbmMW框架是收费的,不在此提供下载,如需购买,请自行联系作者Kim Madsen. 网址资源: 官网主页:http://www.components4programmers.com/product ...

  3. 分享知识-快乐自己:关于 String 小案例

    单个字符出现的次数: /*** * 验证是否符合拆分条件 * * @param text * 原字符串 * @param sub * 判断条件 * @return */ public static i ...

  4. vuex使用mapActions报错解决办法

    先贴上报错: vuex2增加了mapGetters和mapActions的方法,借助stage2的Object Rest Operator 所在通过 methods:{ ...mapActions([ ...

  5. json-lib简单处理json和对json的简单介绍

    JSON 1.json是什么? *它是js提供的一种数据交换格式 2.json的语法 *{}:是对象! >属性名必须使用双引号括起来!单引号不行!!! >属性值: *null *数值 *数 ...

  6. 【前端】【javascript】es6中的遍历器接口Iterator

    好久没发文章啦-.-为了证明我还活着,我决定从笔记里面抓一篇还算不乱比较像文章的发出来... 这些笔记是我在学es6的时候断断续续记录的,最近会一份一份整理陆陆续续发出来,顺便也自己再看一遍.我学习e ...

  7. tensorflow中常量(constant)、变量(Variable)、占位符(placeholder)和张量类型转换reshape()

    常量 constant tf.constant()函数定义: def constant(value, dtype=None, shape=None, name="Const", v ...

  8. 强烈建议使用国外DNS解析域名,解决访问速度和某些访问故障!

    域名解析的基本原理是把域名翻译成IP地址,以便计算机能够进一步通信,传递网址和内容等. 域名劫持就是在劫持的网络范围内拦截域名解析的请求,分析请求的域名,把审查范围以外的请求放行,否则直接返回假的IP ...

  9. MongoDB优化之二:常见优化方法

    四个方面进行 cpu/io 方面的优化处理: 1.集群架构上进行读写分离.所有查询优先考虑在从库上读取,写操作在主库上执行.避免主库混合读写压力过大,也减少主库上读写记录的锁冲突. connectio ...

  10. kafka之一:Windows上搭建Kafka运行环境

    搭建环境 1. 安装JDK 1.1 安装文件:http://www.oracle.com/technetwork/java/javase/downloads/jre8-downloads-213315 ...