C#学习笔记之explicit 和 implicit 的含义?
explicit 和 implicit 属于转换运算符,如用这两者可以让我们自定义的类型支持相互交换,explicti 表示显式转换,如从 A -> B 必须进行强制类型转换(B = (B)A),implicit 表示隐式转换,如从 B -> A 只需直接赋值(A = B)
隐式转换可以让我们的代码看上去更漂亮、更简洁易懂,所以***多使用 implicit 运算符。不过!如果对象本身在转换时会损失一些信息(如精度),那么我们只能使用 explicit 运算符,以便在编译期就能警告客户调用端
C#学习笔记之params 有什么用?
params 关键字在方法成员的参数列表中使用,为该方法提供了参数个数可变的能力,它在只能出现一次并且不能在其后再有参数定义,之前可以
示例:
- using System;
- using System.Collections.Generic;
- using System.Text;
- namespace ConsoleApplication1 {
- class App {
- //***个参数必须是整型,但后面的参数个数是可变的。
- //而且由于定的是object数组,所有的数据类型都可以做为参数传入
- public static void UseParams(int id, params object[] list){
- Console.WriteLine(id);for (int i = 0; i < list.Length; i++){
- Console.WriteLine(list[i]);
- }
- static void Main(){
- //可变参数部分传入了三个参数,都是字符串类型UseParams(1, "a", "b", "c");
- //可变参数部分传入了四个参数,分别为字符串、整数、浮点数和双精度浮点数数组
- UseParams(2, "d", 100, 33.33, new double[] { 1.1, 2.2 });
- Console.ReadLine();
- }
C#学习笔记之什么是反射?
反射,Reflection,通过它我们可以在运行时获得各种信息,如程序集、模块、类型、字段、属性、方法和事件,通过对类型动态实例化后,还可以对其执行操作
一般用于插件式框架程序和设计模式的实现,当然反射是一种手段可以充分发挥其能量来完成你想做的任何事情(前面好象见过一位高人用反射调用一个官方类库中未说明的函数……)
示例:
- using System;
- using System.Collections.Generic;
- using System.Text;
- namespace Example25Lib {
- public class Class1 {
- private string name;private int age;
- //如果显式的声明了无参数构造函数,客户端只需要用程序集的CreateInstance即可实例化该类
- //在此特意不实现,以便在客户调用端体现构造函数的反射实现//public Class1()
- }
- public Class1(string Name, int Age)
- { name = Name;age = Age;} public void ChangeName(string NewName)
- { name = NewName;} public void ChangeAge(int NewAge)
- { age = NewAge;} public override string ToString()
- { return string.Format("Name: {0}, Age: {1}", name, age);
- }
- using System;
- using System.Collections.Generic;
- using System.Text;
- //注意添加该反射的命名空间using System.Reflection;
- namespace Example25 { class Program { static void Main(string[] args)
- { //加载程序集Assembly tmpAss = Assembly.LoadFile
(AppDomain.CurrentDomain.BaseDirectory + "Example25Lib.dll");- //遍历程序集内所有的类型,并实例化Type[] tmpTypes = tmpAss.GetTypes();
- foreach (Type tmpType in tmpTypes)
- { //获取***个类型的构造函数信息ConstructorInfo[]
tmpConsInfos = tmpType.GetConstructors();- foreach (ConstructorInfo tmpConsInfo in tmpConsInfos)
- { //为构造函数生成调用的参数集合ParameterInfo[]
tmpParamInfos = tmpConsInfo.GetParameters();- object[] tmpParams = new object[tmpParamInfos.Length];
- for (int i = 0; i < tmpParamInfos.Length; i++)
- { tmpParams[i] = tmpAss.CreateInstance(tmpParamInfos[i].ParameterType.FullName);
- if (tmpParamInfos[i].ParameterType.FullName == "System.String")
- { tmpParams[i] = "Clark";}
- //实例化对象object tmpObj = tmpConsInfo.Invoke(tmpParams);Console.WriteLine(tmpObj);
- //获取所有方法并执行foreach (MethodInfo tmpMethod in tmpType.GetMethods())
- { //为方法的调用创建参数集合tmpParamInfos = tmpMethod.GetParameters();
- tmpParams = new object[tmpParamInfos.Length];
- for (int i = 0; i < tmpParamInfos.Length; i++)
- { tmpParams[i] = tmpAss.CreateInstance(tmpParamInfos[i].ParameterType.FullName);
- if (tmpParamInfos[i].ParameterType.FullName == "System.String")
- { tmpParams[i] = "Clark Zheng";
- } if (tmpParamInfos[i].ParameterType.FullName == "System.Int32")
- { tmpParams[i] = 27;} tmpMethod.Invoke(tmpObj, tmpParams);}
- //调用完方法后再次打印对象,比较结果Console.WriteLine(tmpObj);}
- Console.ReadLine();}
【编辑推荐】