经过这几天的学习,真的有点觉得以前C学的太不好现在学C#也不顺畅,虽然很多东西都似曾相识,但是就是还得看好几遍才能记得住,而且现在都是简单的东西,还没有看到重载等稍微难点的地方。应该好好努力了,昨天忙完所有事情都十一点多了,还被学姐骂的不行不行的,就早点休息了,真是应该每天都能看一点的,这样还能记得深刻一点,每天都能学点东西还能有点成就感。据说养成一个习惯需要至少23天,我真的还想试一下是不是真的,其实写博客的目的就是督促一下自己,每天给自己来点压力,不要像大一的时候一样一事无成,成天忙那些所谓的学生工作,付出的太少太少,希望找到高中时的状态,周围的环境都不是理由,时间紧也不是理由,现在唯一让我感到很烦的就是导员的博士论文,我学了好几年的理科,大学学的还是工科,成天还要写思想政治教育的稿子,想想都有点不值得,不过只能在自己的博客里吐槽一下了,毕竟要导员帮忙的地方太多了。这样是不是太势利了呢?我也常常在想,直接撂挑子不干算了,爱咋咋地。但是想想已经付出了那么多,到今年12月份也就解放了,也就忍了,真心希望以后不会有这种奇葩的任务了,自己做点自己想做的、想学的,摞摞代码、学学单片机、搞搞嵌入式就挺好。不说废话了,还是说说今天的学习吧!突然好多感慨。。。但是,我的博客我做主,哈哈哈哈。
今天自己看了点转义字符那块,和C差不多,基本一样,也就不赘述了,就是多了个@的那个功能,变量名的第一个字符必须是字母、下划线或数字。变量的命名方面,主要有两种主流的命名方式,一种是camelCase方式,举几个例子就明白了,age,firstName,timeOfDeath(这个名字咋这么吓人呢),就是第一个字母不大写,其他出现的单词首字母都要大写;还有一种是PascalCase方式,看名字就能看得出来,比上一个命名方法多了首字母大写,好像我们老师以前讲C语言的时候说过一种匈牙利命名法和第二种挺像的,不知道是不是一种。对于这两种命名方式,官方给出的说法是,对于简单的变量,用第一种比较好,对于复杂的,就用第二种,不过个人还是比较倾向第二种。
就下来就说下@的用法了,可以有效的简化代码,减少转义字符的使用,使代码更加简洁。在这里举个例子应该就能很明白的说清楚了,不用@的话对于以下字符串“C:\\MyDir\\Myfile.doc”就可以简化成@“C:\Mydir\Myfile.doc”当然使用这种方法也有意外,比如说在字符串里本身存在双引号的话还是必须要转义,以免结束字符串。接下来再说一下一个基本的东西,数据类型的转换:隐式转换和显式转换,所谓隐式转换,就是悄悄的转换,不需要做任何工作,不需要任何的代码,这里就不多说了,以后应该不会在这地方卡壳。重要的是显式转换,在明确要求编译器把数值类型进行转换时,就是在执行显式转换。简单的显示转换格式是<(destinationType)sourceType>,这样就将sourceVal值的数据类型就变成了前面括号里的情况。代码还是要摞起来
byte destinationVar;
short sourceVar = 7;
destinationVal=(byte)sourceVar ;
Console.WriteLine("sourceVar val:{0}",sourceVar );
Console.WriteLine("destinationVar val:{0}",destinationVar );
就可以得到
sourceVar val:7
destinationVar val::7
虽然代码很简单,还是要敲出来,印象能深刻一些,毕竟在打基础。但是如果数据过大就是有溢出的情况,比如说上例中的short类型值是281,结果就会是25,进行了循环,因为byte类型最多能够表达的数就是255.所以在数据类型转换的时候要注意不同数据类型的范围大小。为了防止溢出,可以添加check函数来进行溢出检查,如果溢出就会有程序崩溃的提示。除了这一种方式,还有另一种稍微复杂一点的转换,运用convert进行转换。不说其他,直接上代码:
static void Main(string[] args) //和java真他妈像
{
short shortResult,shortVal=4;
int integerVal=67;
long longResult;
float floatVal=10.5F;
double doubleResult,doubleVal=99.999;
string stringResult,stringVal="17";
bool boolVal=true;
Console.WriteLine("Variable Conversion Examples\n");
doubleResult=floatVal*shortVal;
Console.WriteLine("Implicit,->double:{0}*{1}->{2}",floatVal,shortVal,doubleResult);
shortResult=(short)floatVal;
Console.WriteLine("Explicit,->short:{0}->{1}",floatVal,shortResult);
stringResult=Convert.ToString(boolVal)+Convert.ToString(doubleVal);
Console.Write("Explicit,->string:\"{0}\"+\"{1}\"->{2}",boolVal,doubleVal,stringResult);
longResult=integerVal+Conver.ToInt64(stringVal);
Console.WriteLine("Mixed, ->long: {0}+{1}->{2}",integerVal,stringVal,longResult);
}
码完这段让人吐血的代码,好无聊,但是该练习的还是要练习,这点逃不了。
接下来就说复杂的变量类型之一:枚举。
直接上代码:
enum<typeName> //定义枚举
{
<value1>
<value2>
...
<valuen>
}
<typeName><varName>; //声明新变量
<varName>=<typeName>.<value>; //赋值
还可以添加类型:
enum<typeName> :<underlyingType> //定义枚举,并且在后面设置存储类型
{
<value1>
<value2>
...
<valuen>
}
在默认情况下,每个值都会根据定义的顺序自动赋给对应的基本类型值。也就是说,value1的值是0,value2的值是1等等。也可以重写这个过程:
enum<typeName> :<underlyingType> //定义枚举,并且在后面设置存储类型
{
<value1>=<actualVal1>
<value2>=<actualVal2>
...
<valuen>=<actualValn>
}
还可以使用一个值作为另一个枚举值的基础值,为多个枚举指定相同的值:
enum<typeName> :<underlyingType> //定义枚举,并且在后面设置存储类型
{
<value1>=<actualVal1>
<value2>=<value1>
...
<valuen>=<actualValn>
}
没有赋值的任何职都会自动获得一个初始值,这里使用的值是从比上一个明确声明的值大1开始的序列。例如上例中<value3>的值是<value1>+1.
以循环的方式赋值可能会产生错误,例如:
enum<typeName> :<underlyingType> //定义枚举,并且在后面设置存储类型
{
<value1>=<value2>
<value2>=<value1>
}
枚举的强制数据类型转换:
directionString=MyDirection.ToString(); 等价于
directionString=Convert.ToString(MyDirection);
其中MyDirection是枚举类型的数据变量,directionString是string类型的数据变量。
把string转换为枚举值,有特定的命令Enum.Parse(),用法如下:
(enumrationType)Enum.Parce(typeof(enumrationType),enumrationValueString);
具体的应用如下
string myString="north";
orientation myDirection=(orientation)Enum.Parse(typeof(orientation),myString); //其中orientation为枚举类型
刚才系统崩溃了,吓死宝宝了,幸亏有自动保存。。。。。