|
Java
|
C#
|
主类名与文件名
|
必须一致
|
可以不一致
|
命名空间导入方式
|
import关键字
|
using关键字
|
常量
|
final关键字
|
Const关键字
|
基本数据类型
|
C#中有无符号数,Java没有。
C#中有值类型,且可自己定义值类型的结构体(struct)。 Java中的基本类型(或叫基元类型)即为值类型,但Java没有结构体,所以不能自定义值类型。 C#中的值类型(包括所有基本类型)间接继承自Object,有自己的方法可以调用;Java中的值类型(即基本类型)不继承自Object,只是简单的数据,没有方法可以调用。
C#中int等同于System.Int32,是值类型;bool等同于System.Boolean;等。 Java中int是基本类型,是值类型,而Integer是引用类型,Integer是int的包装器,int自身没有方法,Integer有一些方法;int与Integer之间可隐式转换(导致装箱和拆箱),但当Integer值为null的时候会在运行时抛出异常。boolean等类似。
Java中的int与Integer的对应在C#中类似int和Nullable<int>的对应,它们的后者都是前者的包装,且后者可以等于null。但Nullable<int>实际上仍然是值类型的(所以仍然很轻量级),所以从内存上讲C#中int和Object的对应更接近Java的对应一些。C#中Nullable<int>到int的转换必须显式进行,因为Nullable<int>中的值为null时会引发运行时异常。 其他基本类型与之类似。
注:
可以为 null 的类型是 System.Nullable<T> 结构的实例。 可以为 null 的类型可以表示其基础值类型正常范围内的值,再加上一个 null 值。 例如,Nullable<Int32> 读作“可以为 null 的 Int32”,可以将其赋值为 -2147483648 到 2147483647 之间的任意值,也可以将其赋值为 null 值。 可以赋给 Nullable<bool> 的值包括 true、false 或 null。 在处理数据库和其他包含不可赋值的元素的数据类型时,将 null 赋值给数值类型或布尔型的功能特别有用。
|
初始化
|
调用基类构造函数:
SubClass(){
super();
}
|
调用基类构造函数:
SubClass():base(){}
或者代码中使用base();
|
Switch语句
|
(1)只能处理int类型或者字符型
(2)每个case块后写break语句,不然会有穿透问题。
注:无Goto语句。
|
(1)一样
(2)要求每一个case块或者在块的末尾提供一个break语句,或者用goto转到switch内的其他case标签。
注:最好不用,不易控制。
|
声明数组
|
灵活。
Int[] x={1,2,3};//正确
Int x[]={1,2,3};//正确
|
Int[] x={1,2,3};//正确
Int x[]={1,2,3};//错误
|
面向对象
|
完全面向对象
|
相同
|
继承
|
类的单继承;
可以实现多个接口;
|
相同
|
多态
|
支持某些形式的多态性机制
|
相同
|
重写
|
默认方法都可被重写,派生类和子类方法签名一样时被认为是重写。要声明不能被重写的方法需在方法前加final关键字。重写时可以在方法前添加标注(即C#中的定制特性)@Override,这样一旦此方法找不到被重写的方法时编译器会报错,以防止拼写错误。
|
被重写的方法必须添加virtual关键字声明为虚方法,派生类重写子类方法时添加override关键字。
|
访问修饰符
|
4类
Public:成员可以从任何代码访问;
Protected:成员只能从派生类访问;
Default:默认
Private:
|
Public公有访问。不受任何限制。
Private私有访问。只限于本类成员访问,子类,实例都不能访问
Protected保护访问。只限于本类和子类访问,实例不能访问。
Internal内部访问。只限于本项目内访问,其他不能访问。
protected internal内部保护访问。只限于本项目或是子类访问,其他不能访问
|
内部类
|
内部类可以直接访问外部类的实例成员
|
C#的内部类不可以直接访问外部类的实例成员;C#的内部类等同于java的静态内部类
|
最终类
|
final关键字定义的类不能再被派生
|
Seale关键字定义的类不能再被派生
|
接口
|
(1)关键字:interface;
(2)接口内允许有内部类、静态字段等;
|
(1)关键字:interface;
(2)接口内不允许有内部类、静态字段等;
|
内存管理
|
由运行时环境管理,使用垃圾收集器
|
由运行时环境管理,使用垃圾收集器
|
指针
|
完全不支持。代之以引用
|
支持,你只在很少使用的非安全模式下才支持。通常以引用取代指针
|
泛型
|
Java中泛型实现使用的擦除机制,为类型参数传入类型并不导致新类型出现,即传入了类型参数后在运行时仍然完全不知道类型参数的具体类型,它的目的是为了兼容非泛型(所以可以在泛型和非泛型之间隐式转换,会有编译警告但不会有编译错误,这当然其实并不安全);这同时衍生了一系列问题:不能定义泛型类型参数的数组如T[],不能通过new T()的方式实例化泛型,等。 Java的泛型不支持值类型(使用的话会被自动包装成引用类型)。
|
C#的泛型在类型参数传入类型后会产生一个新类型(虽然CLR的优化机制会使引用类型共享同样的代码),可以在运行时得到类型参数的类型信息。可以定义泛型数组,可以添加约束使其可以new。C#的泛型可以使用值类型(不会被装箱)。
|
参数引用传递
|
只有值传递
|
使用关键字ref:迫使值参数通过引用传递给方法;
使用关键字out:在参数未初始化的情况下,在一个函数中输出多个值;
使用关键字params:自动把参数转为数组;
|
|
|
Ref:
当控制权传递回调用方法时,在方法中对参数的任何更改都将反映在该变量中。若要使用 ref 参数,则方法定义和调用方法都必须显式使用 ref 关键字。
Out:
out 关键字会导致参数通过引用来传递。这与 ref 关键字类似,不同之处在于 ref 要求变量必须在传递之前进行初始化。
|
请发表评论