摘要: 为了更好的利用泛型,现将泛型的一些高级特性总结一下。主要内容:泛型的协变和逆变泛型的参数的约束1. 泛型的协变和逆变对于泛型参数(一般用T表示),指定了类型之后。就只能识别此类型,面向对象中的继承并不适用泛型参数,比如T指定为ClassA,尽管ClassB是ClassA的子类,也不能代替ClassA来作为泛型参数。但是,利用泛型的协变和逆变之后,我们可以写出更加灵活的泛型代码,避免不必要的强制转型操作。首先看下面的示例代码:using System;class CLRviaCSharp_14{ // 泛型委托,其中委托的参数和返回值都是泛型 public delegate TResult Pr 阅读全文
posted @ 2011-07-25 14:09 wang_yb 阅读(802) 评论(0) 推荐(0) 编辑
摘要: .net2.0开始就引入了泛型的机制,泛型有助于我们实现“算法重用”。借助于泛型机制,我们可以少定义一些重载函数,同时还能保证类型安全性。泛型的语法非常简单,下面通过例子来演示泛型的一些应用。主要内容:减少装箱/拆箱(提高性能)限制泛型参数的类型节点类型不同的链表1. 减少装箱/拆箱(提高性能)我们都知道,.net中的额装箱/拆箱操作非常损害性能,通过使用泛型,可以有效的减少我们代码中的装箱拆箱操作,从而提高代码的性能。实例代码如下:using System;using System.Collections.Generic;using System.Collections;class CLRv 阅读全文
posted @ 2011-07-19 17:00 wang_yb 阅读(734) 评论(0) 推荐(0) 编辑
摘要: 偶尔在园子里看到.net的轻量级ORM框架Petapoco的介绍,觉得很有趣。相关介绍:PetaPoco:适用于.NET的微型ORM正好最近有个C#+Oracle11g的项目,想趁此机会试试用petapoco来做数据层的框架。在配置步骤和遇到的问题,记录如下。1. 首先配置ODP.net,使得可以通过C#来连接Oracle。配置ODP.net的方法请参考我之前的博客:C# 连接Oracle(利用ODP.net,不安装oracle客户端)2. 安装Petapoco安装Petapoco,首先得安装Nuget,可以通过VisualStudio2010的Extention Manager来搜索,并安装 阅读全文
posted @ 2011-07-12 23:46 wang_yb 阅读(5905) 评论(12) 推荐(1) 编辑
摘要: 为了方便部署连接oracle的.net程序,oracle官方提供了一个简化版的client,即instant client。通过instant client和ODP.net中的Oracle.DataAccess.dll,我们就可以方便的部署.net应用程序或者站点。1. ODAC的安装在oracle的官方网站上下载与你安装的oracle对应版本的ODAC。下载地址:ODAC Download下载好后解压安装,安装时不用安装全部的组件。主要安装以下组件:Oracle Instant ClientOracle Data Provider For .net2.0Oracle rovider For 阅读全文
posted @ 2011-07-11 20:31 wang_yb 阅读(33955) 评论(15) 推荐(4) 编辑
摘要: 熟悉C#中的事件机制,使得我们可以编写出更加贴近于实际情况的程序。主要内容:本例中事件的场景介绍事件的构造注册/注销事件事件在编译器中的实现显式实现事件1. 本例中事件的场景介绍为了更好的介绍事件的机制,首先我们构造一个使用事件的场景(是我以前面试时遇到的一个编程题)。具体场景大概是这样的:某工厂有个设备,当这个设备的温度达到90摄氏度时,触发警报器报警,同时发送短信通知相关工作人员。当时我就简单的构造3个类:设备(Equipment),警报器(Alert),短信装置(Message)。传统的实现方法:1. 警报器类(Alert)中编写一个报警的方法(StartAlert),短信装置类(Mes 阅读全文
posted @ 2011-07-11 15:06 wang_yb 阅读(817) 评论(0) 推荐(0) 编辑
摘要: 匿名类型使得C#更具动态性。而元组则是以前看python时就了解的一个类型,与List类型类似,只是它里面的元素是不可变的。主要内容:匿名类型介绍元组的介绍1. 匿名类型介绍匿名类型其实也像元组一样,定义了以后就不能更改里面元素的名称和个数。使用匿名类型的代码非常简单:using System;namespace cnblog_bowen{ public sealed class CLRviaCSharp_11 { static void Main(string[] args) { var v = new { Name="my name", Age=100 }; Conso 阅读全文
posted @ 2011-07-08 10:58 wang_yb 阅读(922) 评论(0) 推荐(0) 编辑
摘要: C#中也可以像动态语言那样,定义可选参数和可变数量参数。通过使用可选参数和可变数量参数可以构建更加灵活的函数。主要内容:可选参数可变数量参数1. 可选参数可选参数即调用函数时,传递参数的个数和顺序和定义的不一致。这样不用重载,也可以实现类似重载的多个版本的函数定义。示例代码如下:using System;namespace cnblog_bowen{ public class CLRviaCSharp_10 { static void Main(string[] args) { /* 输出结果 * i=1, s=Z, dt=00010101 00:00:00, g=00000000-0000- 阅读全文
posted @ 2011-07-04 15:53 wang_yb 阅读(878) 评论(0) 推荐(0) 编辑
摘要: 主要内容:扩展方法分部方法1. 扩展方法C#中的扩展方法实现起来非常简单,园子里也有很多写的很好的介绍扩展方法的文章。这里就不在举例说明扩展方法了,只记录一下在实现扩展方法时应注意的原则和规则。1)C#目前只支持扩展方法,不支持扩展属性,扩展事件等2)扩展方法必须在非泛型的静态类中声明3)定义扩展方法的静态类必须有文件作用域,即不能嵌套在某个类中4)多个静态类中如果包含相同的扩展方法,编译时出错(error CS0121)5)用扩展方法扩展了一个类型的同时,也扩展此类型的派生类型6)扩展方法有潜在的版本控制问题。 原因:类型在调用方法时,总是先找类型本身定义的方法,如果没找到对应的方法,再去找 阅读全文
posted @ 2011-07-01 10:19 wang_yb 阅读(641) 评论(0) 推荐(0) 编辑
摘要: 主要内容类型的转换构造器显式/隐式的转换操作符1. 类型的转换构造器类型转换构造器是指 通过一种类型(比如Type1)的实例来构造另一种类型(比如Type2)的实例。一般用于:1) Type1和Type2之间没有继承关系,但是仍然希望从Type1转换到Type22) Type1和Type2是完全不同的两种类型使用方法如下:using System;namespace cnblog_bowen{ public class CLRviaCSharp_8 { static void Main(string[] args) { Type1 t1 = new Type1(10); t1.Show(); 阅读全文
posted @ 2011-06-30 09:42 wang_yb 阅读(558) 评论(0) 推荐(1) 编辑
摘要: C#中经常用const或者readonly来定义不可改变常量,那么如何使用它们呢?主要内容:const和readonly的区别 readonly的补充说明 1. const和readonly的区别主要的区别在于 const是在编译时确定值的,readonly是在运行时确定值的。因此,用const修饰的字段,必须在定义的时候就赋值,否则编译器报错。而readonly修饰的字段除了可以在定义时赋值以外,还可以在构造函数中赋值。验证的代码如下:using System;namespace Test7{ public class CLRviaCSharp_7 { const string cValue 阅读全文
posted @ 2011-06-29 08:59 wang_yb 阅读(653) 评论(0) 推荐(2) 编辑