1.传入某个属性的set方法的隐含参数的名称是什么?value,它的类型和属性所声名的类型相同。2.如何在C#中实现继承?在类名后加上一个冒号,再加上基类的名称。3.C#支持多重继承么?不支持。可以用接口来实现。4.被protected修饰的属性/方法在何处可以访问?在继承或间接继承与这个类的子类中可以访问。5.私有成员会被继承么?会,但是不能被访问。所以看上去他们似乎是不能被继承的,但实际上确实被继承了。6.请描述一下修饰符protectedinternal。被protectedinternal修饰的属性/方法只能在它的在同一个程序集(Assembly)中的子类被访问。7.C#提供一个默认的无参数构造函数,当我实现了另外一个有一个参数的构造函数时候,还想保留这个无参数的构造函数。这样我应该写几个构造函数?两个,一旦你实现了一个构造函数,C#就不会再提供默认的构造函数了,所以需要手动实现那个无参数构造函数。8.C#中所有对象共同的基类是什么?System.Object.9.重载和覆写有什么区别?重载提供了对一个方法签名的不同参数调用的实现。覆写提供了子类中改变父类方法行为的实现。10.在方法定义中,virtual有什么含意?被virtual修饰的方法可以被子类覆写。11.能够将非静态的方法覆写成静态方法么?不能,覆写方法的签名必须与被覆写方法的签名保持一致,除了将virtual改为override。12.可以覆写私有的虚方法么?不可以,甚至子类中无法访问父类中的私有方法。13.能够阻止某一个类被其他类继承么?可以,使用关键字sealed。14.能够实现允许某个类被继承,但不允许其中的某个方法被覆写么?可以,标记这个类为public,并标记这个方法为sealed。15.什么是抽象类(abstractclass)?一种不可以被实例化的类。抽象类中一般含有抽象方法,当然也可有具体实现。继承类只有实现过所有抽象类的抽象方法后才能被实例化。16.何时必须声明一个类为抽象类?当这个类中包含抽象方法时,或是该类并没有完全实现父类的抽象方法时。17.接口(interface)是什么?只含有共有抽象方法(publicabstractmethod)的类。这些方法必须在子类中被实现。18.为什么不能指定接口中方法的修饰符?接口中的方法用来定义对象之间通信的契约,指定接口中的方法为私有或保护没有意义。他们默认为公有方法。19.可以继承多个接口么?当然。20.那么如果这些接口中有重复的方法名称呢?这种情况中你可以决定如何实现。当然需要特别得小心。但是在编译环节是没有问题的。21.接口和抽象类的区别是什么?接口中所有方法必须是抽象的,并且不能指定方法的访问修饰符。抽象类中可以有方法的实现,也可以指定方法的访问修饰符。22.如何区别重载方法?不同的参数类型,不同的参数个数,不同的参数顺序。23.const和readonly有什么区别?const关键字用来声明编译时常量,readonly用来声明运行时常量。24.System.String和System.StringBuilder有什么区别?System.String是不可变的字符串。System.StringBuilder存放了一个可变的字符串,并提供一些对这个字符串修改的方法。1.静态成员和非静态成员的区别?2.const和staticreadonly区别?3.extern是什么意思?4.abstract是什么意思?5.internal修饰符起什么作用?6.sealed修饰符是干什么的?7.override和overload的区别?8.什么是索引指示器?9.new修饰符是起什么作用?10.this关键字的含义?11.可以使用抽象函数重写基类中的虚函数吗?12.密封类可以有虚函数吗?13.什么是属性访问器?14.abstract可以和virtual一起使用吗?可以和override一起使用吗?15.接口可以包含哪些成员?16.类和结构的区别?17.接口的多继承会带来哪些问题?18.抽象类和接口的区别?19.别名指示符是什么?20.如何手工释放资源?21.P/Invoke是什么?22.StringBuilder和String的区别?23.explicit和implicit的含义?24.params有什么用?25.什么是反射?以下是我做的一份参考答案(C#语言范畴之内),如果有不准确、不全面的,欢迎各位朋友指正!1.静态成员和非静态成员的区别?答:静态变量使用static修饰符进行声明,在类被实例化时创建,通过类进行访问不带有static修饰符声明的变量称做非静态变量,在对象被实例化时创建,通过对象进行访问一个类的所有实例的同一静态变量都是同一个值,同一个类的不同实例的同一非静态变量可以是不同的值静态函数的实现里不能使用非静态成员,如非静态变量、非静态函数等示例:usingSystem;usingSystem.Collections.Generic;usingSystem.Text;namespaceExample01{classProgram{classClass1{publicstaticStringstaticStr=Class;publicStringnotstaticStr=Obj;}staticvoidMain(string[]args){//静态变量通过类进行访问,该类所有实例的同一静态变量都是同一个值Console.WriteLine(Class1'sstaticStr:{0},Class1.staticStr);Class1tmpObj1=newClass1();tmpObj1.notstaticStr=tmpObj1;Class1tmpObj2=newClass1();tmpObj2.notstaticStr=tmpObj2;//非静态变量通过对象进行访问,不同对象的同一非静态变量可以有不同的值Console.WriteLine(tmpObj1'snotstaticStr:{0},tmpObj1.notstaticStr);Console.WriteLine(tmpObj2'snotstaticStr:{0},tmpObj2.notstaticStr);Console.ReadLine();}}}结果:Class1'sstaticStr:ClasstmpObj1'snotstaticStr:tmpObj1tmpObj2'snotstaticStr:tmpObj22.const和staticreadonly区别?答:const用const修饰符声明的成员叫常量,是在编译期初始化并嵌入到客户端程序staticreadonly用staticreadonly修饰符声明的成员依然是变量,只不过具有和常量类似的使用方法:通过类进行访问、初始化后不可以修改。但与常量不同的是这种变量是在运行期初始化示例:测试类:usingSystem;usingSystem.Collections.Generic;usingSystem.Text;namespaceExample02Lib{publicclassClass1{publicconstStringstrConst=Const;publicstaticreadonlyStringstrStaticReadonly=StaticReadonly;//publicconstStringstrConst=ConstChanged;//publicstaticreadonlyStringstrStaticReadonly=StaticReadonlyChanged;}}客户端代码:usingSystem;usingSystem.Collections.Generic;usingSystem.Text;usingExample02Lib;namespaceExample02{classProgram{staticvoidMain(string[]args){//修改Example02中Class1的strConst初始值后,只编译Example02Lib项目//然后到资源管理器里把新编译的Example02Lib.dll拷贝Example02.exe所在的目录,执行Example02.exe//切不可在IDE里直接调试运行因为这会重新编译整个解决方案!!//可以看到strConst的输出没有改变,而strStaticReadonly的输出已经改变//表明Const变量是在编译期初始化并嵌入到客户端程序,而StaticReadonly是在运行时初始化的Console.WriteLine(strConst:{0},Class1.strConst);Console.WriteLine(strStaticReadonly:{0},Class1.strStaticReadonly);Console.ReadLine();}}}结果:strConst:ConststrStaticReadonly:StaticReadonly修改后的示例:测试类:usingSystem;usingSystem.Collections.Generic;usingSystem.Text;namespaceExample02Lib{publicclassClass1{//publicconstStringstrConst=Const;//publicstaticreadonlyStringstrStaticReadonly=StaticReadonly;publicconstStringstrConst=ConstChanged;publicstaticreadonlyStringstrStaticReadonly=StaticReadonlyChanged;}}结果strConst:ConststrStaticReadonly:StaticReadonlyChanged3.extern是什么意思?答:extern修饰符用于声明由程序集外部实现的成员函数经常用于系统API函数的调用(通过DllImport)。注意,和DllImport一起使用时要加上static修饰符也可以用于对于同一程序集不同版本组件的调用(用extern声明别名)不能与abstract修饰符同时使用示例:usingSystem;usingSystem.Collections.Generic;usingSystem.Text;usingSystem.Runtime.InteropServices;namespaceExample03{classProgram{//注意DllImport是一个AttributeProperty,在System.Runtime.InteropServices命名空间中定义//extern与DllImport一起使用时必须再加上一个static修饰符[DllImport(User32.dll)]publicstaticexternintMessageBox(intHandle,stringMessage,stringCaption,intType);staticintMain(){stringmyString;Console.Write(Enteryourmessage:);myString=Console.ReadLine();returnMessageBox(0,myString,MyMessageBox,0);}}}结果:4.abstract是什么意思?答:abstract修饰符可以用于类、方法、属性、事件和索引指示器(indexer),表示其为抽象成员abstract不可以和static、virtual一起使用声明为abstract成员可以不包括实现代码,但只要类中还有未实现的抽象成员(即抽象类),那么它的对象就不能被实例化,通常用于强制继承类必须实现某一成员示例:usingSystem;usingSystem.Collections.Generic;usingSystem.Text;