C#2.0经典读书笔记

阅读更多

1,可以为类或者命名空间指定别名
例如(命名空间别名):using myAlias = myNameSpace1.myNameSpace2.Space3

 

2, C#的另外几种开发工具:SharpDevelop / Snippet Compiler
C#返编译软件:.NET Reflector
C#单元测试工具:NUnit
C#代码生成工具:CodeSmith
C#代码标准检测工具:FxCop

 

3, 编程风格建议
A,代码块之间空一行
B,左大括号占一行
C,括号的嵌套层次要缩进(4个空格)
D,变量命名规则(就是名首字母小字,后面出现单词的首字母大写,如myData)

 

4, C#的四种数值类型不被.net平台上其他语言支持,这四种数值类型是(Sbyte,ushort,uint,ulong)

 

5, 数据类型显式转换的两种方式:
A,System.Convert 类提供多种类型的数据相互转换
B,括号形式,如(int)

6,C#中全局变量的解决方法
用静态类和静态变量来实现,如:private static string name = "wang";

 

7, a++ 和 ++a的区别
a++ 先参与运算再自加 ++a 先自加再参与运算

 

8,^运算符号
用在两个bool型运算中表示异或(只有一个操作数为 true 时,其结果才为 true)
用在两个int型运算中表示二进制按位异或(5^6 = 101^110=011(3))

 

9, C#语言中数据类型检测
检测数据类型:int a=5; a is int?返回true
检测类型的容量:sizeof(int);

 

10,C#中逻辑运算符
“&”表示“与”,两者都为真结果才为真
“&&”表示“与”,与&不同的是它仅在必要时才计算第二个操作数
“|”表示“或”,两者中有一方为真结果就为真
“||”表示“或”,与|不同的是它仅在必要时才计算第二个操作数
“^”表示“异或”,两者中只有一方为真结果才为真
“!”表示“非”,参与变量取反

 

11,switch语句中的Case部分的内容为空时,直接执行Case的下一个Case中的内容

 

12,switch语句支持对枚举型的分支处理

 

13,三元运算符代替简单的if else 语句
例如:
if (a>b)
{c=a-b }
else {c=a+b} 写为 c = a>b?a-b:a+b

 

14,四种循环语句
A:for(){} 执行次数已知,可正向步进,逆向步进,步长不一定为1
B:foreach(){} 对集合实体进行遍历操作
C: while(){};执行0次或0次以上,在循环体中改变循环判断条件
D: do{} while(); 至少执行一次,在循环体中改变循环判断条件

 

15,改变循环体执行的4种关键字:
A:goto 从循环体中跳到标签位置,不建议从循环体外跳向循环体内
B: return 跳出当前过程,而不是循环体
C:break 跳出当前循环体(跳到当前循环体外闻)
D:continue 跳过当前循环体中的当次循环,进入下一次循环

 

16,关于冒泡排序算法的一个经典例子

static void Main(string[] args)
{

int[] myArray = new int[5] { 12,9,35,68,51};
int a = 0;

for (int i = 0; i < myArray.Length; i++)
{
Console.WriteLine(myArray[i]);
}
Console.ReadLine();

//外层循环用来控制内层循环终值,因为每运行一次数组中的最大数会推动到数组最后
for (int i = myArray.Length - 1; i >= 0; i--)
{
for (int j = 0; j < i; j++) //内层循环用来比较相临两数,把大数向后推动
{
if (myArray[j] > myArray[j + 1])
{
a = myArray[j];
myArray[j] = myArray[j + 1];
myArray[j + 1] = a;
}
}
}

for (int i = 0; i < myArray.Length; i++)
{
Console.WriteLine(myArray[i]);
}
Console.ReadLine();

}

 

17,方法中的return意思是把控制权交给方法调用者,在方法上面一行使用///注释可以自动生成关于方法的说明,调用者使用此方法时,VS2005会显示出这些注释(智能提示功能)。

 

18,方法中传入参数中ref的用法(使参数按引用传递,ref参数必须初始化)

 

19,方法中传入参数中out的用法同ref,不同之处是out的传入参数不用初始化

 

20,方法重载的三种形式
A:参数个数不同
B:参数类型不同
C:参数类型相同,但参数引用和非引用 也是重载(比如:static int add(ref int a,ref int b) 和 static int add(int a, int b))

 

21,System.Environment 此类获取当前运行环境下的很多信息.

------------------------------------------------------------------------------------


第二部分 C#提高

1,VS2005中类设计图的使用(ClassDiagram)用图形界面设计类,能自动生成类代码

 

2,类的构成(类的成员):
A:构造函数(可重载)
B:析构函数(一个类只能有一个析构函数,并且不能被调用),当程度封闭窗口,文件,网络连接这类非托管资源的时候,应当使用析构函数来释放这些资源。
C:字段(在类内部使用)
D:属性,(用来获取,修改类中字段的值,用get set实现,get set)
E:方法。

 

3,类成员的访问控制修饰符(private(默认) public protected internal)
其中,protected 只能在类内部访问和被它的派生类中访问,介于private 和 public 之间
internal是类型和类型成员的访问修饰符,用来限制类成员,以便只有在当前命名空间或程度集中的类可以访问它

 

4,枚举类型是轻量级的值类型,用enum来声明,枚举用来表达一组特定值的集合行为,如windows窗体的可选状态等

 

5, 结构用struct来声明,结构与类的区别:
A:结构是值类型,在堆栈上分配地址。缺点是资源有限,不适合处理大的逻辑复杂对象,结构不支持继承,但可以实现接口。

B:类是引用类型,在堆上分配地址。
C:结构执行效率要比类高,但只适合小对象。

 

6,注意多维数组和交错数组(数组的数组/锯齿数组)的区别。
多维数组:int[,] intArray = new int[2,2]{{10,11},{12,13}}
交错数组(元素为数组的数组,维度和大小可以不同):写法如下
int[][] intArray = new int[3]
int[0] = new int[]{10,20};
int[1] = new int[]{15,30,33};
int[2] = new int[]{15,22,25,29,65};
或者:
int[][] intArray = new int[][]
{
new int[] {10,20},
new int[] {15,30,33},
new int[] {15,22,25,29,65}
}

 

7, A:数组的遍历foreach,
B:数组的清除System.Array(myArray,index,length),
C:数组的查找Array.IndexOf(myArray, Object) 和4个参数的高级查找缩小查找范围
D:数组的排序Array.Sort(myArray) 顺序排序 / Array.Reverse(myArray) 注意此为反转数组并不是倒序

 

8, ArrayList ,同数组最大的区别是arrayList的容量是自动扩充的,
注意arraylist.capacity 显示容量,arraylist.count显示元素个数。
两种增加元素的方式ADD,insert
三种删除元素的方式clear,Remove,RemoveAt
ArrayList向Array的转换
myArrayList.TrimToSize(),缩小capacity到当前实际容量,减少内存浪费.

 

9, HashTable 键值对集合的字典,不能通过其index来访问,只能通过key来访问表中值,也就是hashTable[key]
增加元素方式:add(key,value)
删除元素方式: clear() / remove(key)
遍历:foreach (DictionaryEntry d in h1)
查找: HashTable.Contains / HashTable.ContainsKey 是否包含指定key的项
HashTable.ContainsValue 是否包含指定value的项

 

10,Queue 队列类是先进先出集合
Queue的三个主要操作
Enqueue 将一个元素增加到Queue的尾部
Dequeue 从Queue的开始处取出最旧元素并移除此元素
Peek 从Queue处返回最旧元素但不删除

 

11,Stock 堆栈类是后进先出集合
Stock的三个主要操作
Push 在Stock的顶部加入元素
Pop 从Stock顶部取出最新元素并移除此元素
Peek 从Stock顶部返回最新元素但不删除

 

12,SortedList 是ArrayList 和 HashTable的结合体 ,当同时需要键值对和顺序索引时,使用SortedList


13,Dictionary字典类(泛型类)

 

你可能感兴趣的:(C++,C,C#,读书,数据结构)