网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 软件工程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
本月文章推荐
.谈谈软件项目管理的重要性(2).
.Mozilla开发组的开发策略(中文).
.Visual Studio.net令人赞赏的结构.
.SOA成熟度模型为SOA 护航.
.UML组件图详解(1).
.软件测试组织与方法.
.实施UML九项注意.
.中间件技术研究(1).
.UML建模工具UMLGraph 4.3 发布.
.JavaCard开发教程之生存周期.
.语音识别在家电遥控器中的应用.
.深入浅出.NET泛型编程.
.XMI与UML合力推动产品开发(1).
.CMMI模型对软件测试技术的扩充.
.软件开发的未来中程序员与客户的.
.软件项目质量管理经验谈.
.解析UML的要点与应用.
.项目管理系列之-质量管理.
.IBM的MARS加密算法实现(7).
.单元测试和事先测试开发.

.NET2.0泛型的“近距离”实践

发表日期:2008-3-23



  早闻.NET 2.0中泛型的大名,但一直未在实际开发中使用。最近在开发公司项目程序的过程中体验了一下。

  应用场景:

  在配置文件中通过反序列化读取相应的邮件设置。

  配置文件示例:

<BlogConfigurationSettings>
<MailSettings>
<MailSetting Name="ApproveEmail" SmtpServer="smtp.126.com" EmailFrom="" UserName="" PassWord=""></MailSetting>
<MailSetting Name="ContactEmail" SmtpServer="smtp.163.com" EmailFrom="" UserName="" PassWord=""></MailSetting>
</MailSettings>
</BlogConfigurationSettings>
  功能说明:

  通过该配置文件,反序列化得到BlogConfigurationSettings实例的属性MailSettings,然后根据要害字得到相应的MailSetting,比如:名为ApproveEmail的MailSetting。

  MailSetting的定义:

MailSetting
[Serializable]
public class MailSetting
{
 private string _name;
 [XMLAttribute("Name")]
 public string Name
 {
  get { return _name; }
  set { _name = value; }
 }

 private string _smtpServer;
 [XmlAttribute("SmtpServer")]
 public string SmtpServer
 {
  get { return _smtpServer; }
  set { _smtpServer = value; }
 }

 private string _mailFrom;
 [XmlAttribute("MailFrom")]
 public string MailFrom
 {
  get { return _mailFrom; }
  set { _mailFrom = value; }
 }

 private string _username;
 [XmlAttribute("UserName")]
 public string UserName
 {
  get { return _username; }
  set { _username = value; }
 }

 private string _password;
 [XmlAttribute("Password")]
 public string Password
 {
  get { return _password; }
  set { _password = value; }
 }

 public string Key
 {
  get { return this.Name; }
 }

}
  假如不使用泛型,我们可以通过数组或者集合类来实现。对于数组,我们需要在BlogConfigurationSettings进行这样的定义:

private MailSetting [] __mailSettings;
[XmlArray("MailSettings")]
public MailSetting [] MailSettings
{
 get { return this._mailSettings; }
 set { this._mailSettings = value; }
}
  我们还需要写一个方法去枚举数组元素,根据要害字返回相应的MailSetting。

  对于集合类,需要在BlogConfigurationSettings进行这样的定义:

private MailSettingColletion _mailSettings;
[XmlArray("MailSettings")]
public MailSettingColletion MailSettings
{
 get { return this._mailSettings; }
 set { this._mailSettings = value; }
}
  接下来我们需要写一个MailSettingColletion类, 并且在MailSettingColletion中实现一个方法去根据要害字查找相应的MailSetting。

  对于泛型,我们只要在BlogConfigurationSettings进行如下的定义:

private List<MailSetting> _mailSettings;
[XmlArray("MailSettings")]
public List<MailSetting> MailSettings
{
 get { return _mailSettings; }
 set { _mailSettings = value;}
}
  然后只需下面的一行代码就能根据要害字得到相应的MailSetting:


BlogConfigurationSettings.MailSettings.Find(delegate(MailSetting mailSetting) { return mailSetting.Key == "ApproveEmail"; })
  Find方法的参数类型是Predicate<T>,它的定义是:

public delegate bool Predicate<T>(T obj)
  也就是一个参数为泛型,返回值为bool的委托类型。

  Find的功能就是枚举List<T>中的元素,并以每个元素作为委托的参数调用委托,实际的委托方法是通过Find参数传递过来的,当调用的委托返回true时,返回当前元素。

  你也可以将上面的Find参数中的代码写为一个单独的方法,然后将方法名作为Find的参数。

BlogConfigurationSettings.MailSettings.Find(IsMe);
public bool IsMe(MailSetting mailSetting)
{
return mailSetting.Key == "ApproveEmail";
}
  对于这样的代码,你立即会感到不舒适,这样岂不要为每个要害字写一个方法,你想应该这样写:

public bool IsMe(MailSetting mailSetting,string key)
{
return mailSetting.Key == key;
}
  这样写当然好啊,可是Find却不同意,它的参数只答应是带有一个参数的方法。

  那如何解决这个问题呢?

  我想到的一个解决方法,写一个MailSettingPredicate类:

public class MailSettingPredicate
{
private string key;

public string Key
{
get { return key; }
set { key = value; }
}

public bool IsMe(MailSetting mailSetting)
{
return mailSetting.Key == this.key;
}
}
  在调用IsMe之前,先设置MailSettingManager.Key的值,代码如下:

MailSettingPredicate predicate= new MailSettingPredicate();
predicate.Key = "ApproveEmail";
Config.Settings.MailSettings.Find(predicate.IsMe);
predicate.Key = "ContactEmail";
Config.Settings.MailSettings.Find(predicate.IsMe);
  我在实际开发中刚刚使用.NET 2.0的泛型,写这篇文章是想加深自己的理解,同时希望给不熟悉.NET 2.0泛型的朋友提供一点参考,不足之处,欢迎您指出。
上一篇:使用软件工程学来开发软件 人气:434
下一篇:实施UML九项注意 人气:682
浏览全部软件工程的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐