C#语法相比其它语言比较独特的地方(一)
C#语法相比其它语言比较独特的地方(一)
发布时间:2016-12-28 来源:查字典编辑
摘要:由于c#是由设计.net本身的人设计出来的,所以c#才是.net上最一流的语言。实际上,已经有一百多万行c#代码用于实现.Netclassf...

由于c#是由设计.net本身的人设计出来的,所以c#才是.net上最一流的语言。

实际上,已经有一百多万行c#代码用于实现.Net class framework。

要发挥出.net平台全部的效能,只有c#才是首选。

1,switch语句可以用来测试string型的对象

这在c,c++,java等其他各主流语言中都是不可以的,唯独c#可以。

例如string a="haha";

复制代码 代码如下:

switch(a)

{

case "dfj":

...

break;

case "djkfdjkf":

....

break;

case "haha":

.....

break;

default:

....

}

2、多维数组

这也是c#的特色,像java也没有多维数组,只有数组的数组。

c#中不但有数组的数组,也有多维数组。

数组的数组的特点是(拿二维为例),每一行的元素个数可以不同。

比如int [][] c=new int[2][];

复制代码 代码如下:

c[0]={3,4,5,6};

c[1]={1};

c#中的多维数组的形式是这样定义

复制代码 代码如下:

int [,] c=new int[3,4];

这样的c就是一个三行四列的二维数组。

3,as与is

java中也有类似于is的语法,用于在运行时判断一个对象的类型,叫做instanceof。

c#中就是一个is,判断o是不是一个string: o is string

as则是一个很窝心的功能,它首先对这个对象进行判断是否是某种类型,如果是就进行类

型转换,如果不是,就返回null。

如: o as string

4,foreach语句

java5以后for语句就多了foreach功能,这也许就是因为之前没有,而c#有,使得自己非常嫉妒,所以马上给添上了。

c#中的foreach功能是非常方便的。

例如遍历一个数组

复制代码 代码如下:

string[] sentences=...;

foreach(string st in sentences)

{

....

}

5,索引器和Property

不得不承认,我的偶像Anders实现出来的c#确实非常优秀。

我把索引器和Property归为一类。

都是从Class中读取某种属性,如果知道java的POJO的人肯定知道,java bean的标准形式

就是一堆private属性,然后一个getter,一个setter,这是标准,但实现确实使用的普通成员方法。

c#则更绝,它直接在Class中声明一个单独的field,然后在语法中直接设计了getter和setter的简化写法,这就是我们熟知的Property。

如:

复制代码 代码如下:

public class WordCount

{

private string m_string;

public string OutFile

{

get{...}

set{...value...}

}

}

这样真正做到了封闭改动,开放扩展。

然后就是索引器,我觉得java中只有EL才有点做出了类似索引器的功能,这也只是方便了写jsp的人,而且很多厂商居然不在自己的容器中包含EL解析,这不得不让sun很无奈。

索引器就是给几个参数,返回一个属性。

如:

复制代码 代码如下:

public int this[string index]

{

get{...}

set{..value}

}

public int this[int x,int y]

{

get{}

set{..value}

}

6,const和readonly

这点c#让我有点失望,对于非Ref型就是const,对于Ref型就是readonly。

而在java中,一个final就行了。当然对于不可继承的类,c#又有一个关键字sealed,虽然这让程序的含义更明确,但确实也多记了好几个关键字。

7,delegate型别

说实话,这种奇怪的语法还是第一次见到,说跟C++中重载operator()的功能像吧,又不是太像。

总而言之,觉得它实现可能就是记下一堆同类型的函数指针,然后可以依次调用而已。

首先需要声明一个delegate型别,注意是型别而不是对象。

如public delegate void Action();

注意既然是型别,那就跟enum,class是同等的,注意型别能够出现的位置。

然后我们就可以定义这种型别的对象来使用了。

复制代码 代码如下:

Action aaa=new Action(...);

这个...代表的是符合这种函数原形的函数名字,注意使用delegate机制来调用,和直接调用函数本质上没有什么不同,就是说,当你调用成员函数的时候,当然你需要有一个对象,而调用静态函数的时候,你可以直接使用类名了。

这种delegate型别对象还有点特殊,它可以使用运算符+=和-=来增加或者减少本对象所代

理的函数集,当然还有更多的方法用来看当前我代理了多少个函数之类的。

复制代码 代码如下:

aaa+=new Action(xxx);

aaa+=new Action(ooo);

然后aaa(),意味着顺序调用xxx和ooo。

aaa.GetInvocationList().length可以看到当前代理了多少个函数。

你不用担心代理的普通成员函数的所属对象会被垃圾回收器回收,直到此代理对象不再引用这个函数,当然这个也是坏消息,说不定你都忘了还有某个代理对象代理着要死的对象的函数,让这个对象老不死。

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新C#教程学习
热门C#教程学习
编程开发子分类