C#学习第三天

经过这几天的学习,真的有点觉得以前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为枚举类型

刚才系统崩溃了,吓死宝宝了,幸亏有自动保存。。。。。

上一篇:Android 检测是否连接蓝牙耳机


下一篇:JS控制文本框内键盘上下左右键的焦点