怎么样?
答案是这样的
s1 is a string
s2 is a string
s1 is now anothing string
s2 is now string
看到这个结果大家感觉怎么样!我是很感到意外的。因为根据原来的c实现字符串的方式,
在这里面作为一个指针来说,s1与s2应该指向相同的地址。
另外对于字符串处理还有另一个问题,如下例:
要构建如下一个串:"c:/program file/wom",我想大家明白我的意思了吧!
就是说在这里有 / 但是 / 是做为转义字符来用的。
(嗯,很简单)这样就行了呀:"c://program file//wom",完全正确。而c#又提供了另一
种方式来解决这样的问题。其实是引入了一个@:
上面的可以这样写 string [email protected]"c:/program file/wom",这样c#会把@后的所有字符都做为
所来的形式来处理,并且他还包含换行符。
好了,关于c#最基本的数据类型就是这些了!(噢,好像少了点什么,对对,我下面就要说
了!)
上面是最基本的数据类型,下面我们来谈谈由这些基本的数据类型所构民的复全数据类型。
对于复合的数据类型,还是分两类来简述。
首先要说的还是值类型。在c#提供了两种复合的值类型,结构与枚举。
对于这两种类型大家是不是很熟悉呀?但是大家不要大意,在c#中这两种类型已经有了不小
的变化。
还是看个例子呀,还是例子比较能说明问题。
定义了如下的一个结构:
public struct subscriber
{
public long lngsubscriberid;
public string strfirstname;
public string strmiddlename;
public string strlastname;
public decimal decbalance;
}
是不是和原来的结构有了很大的不同!在c#中结构其实就是一个特殊的类。
再看一下结构的使用:
subscriber subscriber1;
subscriber subscriber2;
subscriber1=new subscriber();
subscriber1.strfilstname="john";
subscriber1.strmiddlename="q";
subscriber1.strlastname="public";
subscriber1.decbalance=100;
subscriber2=subscriber1;
这里定义了两个结构:subscriber1,subscriber2。
然后用new运算符,对subscriber1进行了初始化。关于初始化在这里多说一句。对于结构可
以不用new运算符来进行始化。因为在定义的同时就已经进行了一次初始化,所有字段的默
认值为0。但是这方式还有一个弊端,那就是没办法进行两个结构变量的复制。
再下面的代码就是实现了对新结构的赋值。而最后一行,就是我所说的结构间的复制。
那么结构有什么好处呢。我想最主要的一点就是体现在函数的传递中,可以把多个变量打到
一个结构变量中进行传递。
前面说过了,结构是一个特殊的类,他们俩最主要的不同就是结构不支持继承。
好了,说了这么多,下面来看看枚举。
还是通过一个例子来看看枚举。
public enum timeofday
{
morning=0,
afternoon=1,
evening=2
}
class enumexample
{
public static int main()
{
writegreeting(timeofday.morning);
return 0;
}
static void writegreeting(timeofday timeofday)
{
switch(timeofday)
{
case timeofday.morning:
console.writeline("good morning!");
break;
case timeofday.afternoon:
console.writeline("good afternoon!");
break;
case timeofday.evening:
console.writeline("good evening!");
break;
default:
console.writeline("helo!");
break;
}
}
}
对于这个枚举我想大家一目了然了吧!对于枚举我私人认为呀,就是有点像常数,都是用名
字来打替数据吗!
对于复合的值类型就说到这,下面再看看复合的引用类型(数组、类、接口、委托)。
我首推的当然是大家最熟悉的,那就是数组:
由于在c#中限制了对指针的使用,所以对c#数组的使用也产生了影响。
首先还是看看例子:
int[] a;
int[] a = new int[32]
a[0]=35;
a[31]=322;
int[] b;
b=new int[32];
string[] c={"a","b","c"};
string[] d=new string[]{"a","b","c"};
对于上面的例子,说明了几个要注意的问题。
(1)在c#中数组的起始下标还是为0的。
(2)对数组的初始化要使用new运算符。
(3)在c#中也可以动态定义数组。
(4)对于数组的初始化支持和java一样的{}方式。
(5)在数组的初始化中这种方式是决不不允许的
int len=3;
string d=new string[len]{"a","b","c"};
对应的解决方式:可以这么写:const int len=3;
也就是说不可以给变量来设置数组的长度。
(6)还忘了的一个就是数组定义要使用[]。
(7)再有一点不允许的使用方式如下:
string[] e=new string[3]{"a","b","c","d"};
下面再看个例子:
string[] d=new string[]{"linda","lily","adidas"};
int ff=d.length; //取数据长度
int ee=d.getlength(0); //取出指定数据维的长度
array.sort(d); //对数组排序
array.reverse(d); //把数组反序
由于数组在c#中表示为一种特殊的类型,所以它们有自己的一些方法。这些方法为我们使用数组提供了很大的方便。
上面这些都是对一维数组的使用,同样c#也是支持多维数组的。下面来看看多维数组吧。
还是通过一个例子来认识一下多维数组的定义和操作。
int[,] a=new int[,]{{1,2,3},{1,2,3},{4,5,6}};
int[,,] b;
int[,,] b=new int[,,]{10,20,30};
string[][] arylists=new string[3][];
arylists[0]=new string[]{"a","b","c"};
arylists[1]=new string[]{"d","e","f"};
arylists[2]=new string[]{"g","h","i"};
int i;
for(i=0;i<arylists.getlength(0);i++)
{
int j;
for(j=0;j<arylists[i].getlength(0);j++)
{
console.write(arylists[i][j] + ",");
}
console.write("/n");
}