求C#与Java中汉英语法的异同同点

C#中有无符号数Java没有。

C#中有值类型且可自己定义值类型的结构体(struct)。

Java中的基本类型(或叫基元类型)即为值类型但Java没有结构体,所以不能自定义值类型

C#中的值类型(包括所有基本类型)间接继承自Object,有自己的方法可以调用;Java中的值类型(即基本类型)不继承自Object只是简单的数据,没有方法可以调用

Java中int是基本类型,是值类型而Integer是引用类型,Integer是int的包装器int自身没有方法,Integer有一些方法;int与Integer之间可隐式转换(导致装箱和拆箱)但当Integer值为null的时候会在运行时抛出异常。boolean等类似

其他基本类型与之类似。

C#中的委托可以认为是方法的类型化于是可以将方法放在变量里传递。事件是對委托做了一层包装

Java通过接口来实现C#中委托和事件的功能,可通过匿名类来达到C#中匿名委托的作用(同样也能实现闭包的功能)

另,C#Φ也有匿名类但C#和Java的匿名类刚好各做各的事情:Java中的匿名类只有方法没有数据;C#中的匿名类只有数据没有方法。

C#可以有非托管代码可鉯有指针等。Java没有

C#有索引器,可方便容器类实现类似数组的效果Java没有,Java的容器基本上用put,get,set等方法达到同样效果

C#的属性通过在内部定义get/set方法,使外部使用时像是在使用变量字段但其实是在调用get/set方法,以达到透明的封装数据的目的

Java没有属性的概念。Java通过约定为字段XX添加getXX,setXX方法达到同样的目的

C#可重载操作符。Java没有

Java自己重载了String的+和+=,但没有重载==这是我这段时间犯的最多的错误。C#中String的==是比较值相等Java中==是Object嘚默认行为:比较引用相等,要比较值相等得用equals方法(这么多年编程以来,我似乎从来没有遇到过要比较两个字符串变量的引用相等對于比较值相等来讲,==符号比equals方法调用看上去优雅得多况且方法调用还得注意空指针的情况)

Java的内部类可以直接访问外部类的实例成员。

C#的不行C#的内部类等同于Java的静态内部类。

C#允许用gotoJava的goto是保留关键字,不能使用但Java允许有标签,在有嵌套循环时可以在continue、break后面跟标签名

Java的switch中的case子句在后面没有跟break的情况下直接跳到下一个case子句;

C#中只有在前一个case没有任何代码的情况下才允许不写break直接跳到下一个case,C#中可以通過goto跳转到另一case

C#中的枚举是值类型,且其基于数值类型(默认基于int)可设置枚举项对应的数字,不能在其中添加方法等任何其他成员

JavaΦ的枚举是引用类型(Java除了基本类型外,任何类型都是引用类型)不是基于数值类型。除了不能继承外它跟普通类差别不大,可以添加成员方法和成员变量等(当然也就可以重写toString方法)

可以将C#的枚举作为数值看待而直接进行位运算,因此可以在一个变量中存储多个位標记

Java的枚举跟数值没有直接关系,因此不能直接这么用Java用EnumSet来存储枚举标志,不需要直接使用位运算更远离底层。

C#能被重写的方法必須添加virtual关键字声明为虚方法派生类重写子类方法时添加override关键字。

Java默认方法都可被重写派生类和子类方法签名一样时被认为是重写。要聲明不能被重写的方法需在方法前加final关键字重写时可以在方法前添加标注(即C#中的定制特性)@Override,这样一旦此方法找不到被重写的方法时编译器会报错以防止拼写错误。

C#用中括号[]将定制特性括起来Java用@打头,后面跟定制特性的名字

Java中泛型实现使用的擦除机制,为类型参数传叺类型并不导致新类型出现即传入了类型参数后在运行时仍然完全不知道类型参数的具体类型,它的目的是为了兼容非泛型(所以可以茬泛型和非泛型之间隐式转换会有编译警告但不会有编译错误,这当然其实并不安全);这同时衍生了一系列问题:不能定义泛型类型參数的数组如T[]不能通过new T()的方式实例化泛型,等

Java的泛型不支持值类型(使用的话会被自动包装成引用类型)。

C#的泛型在类型参数传入类型后会产生一个新类型(虽然CLR的优化机制会使引用类型共享同样的代码)可以在运行时得到类型参数的类型信息。可以定义泛型数组可以添加约束使其可以new。C#的泛型可以使用值类型(不会被装箱)

对于Java的泛型,简单的讲它的好处只在编译时,运行时没有任何泛型的意义当伱在使用已有的泛型类时,这通常能满足要求;但如果你要自己定义泛型类那你得知道它有多少你觉得它应该可以但事实上不可以的事凊。

C#允许使用关键字out,ref显式指定参数传递方式为引用传递

C#在写字符串时可以在引号前加个@符号来取消/的转义作用。

C#的??二元操作符当前面的表达式不为null时返回前面表达式的值前面表达式为null时返回后面表达式的值。

C#可以用using为命名空间或类指定别名(using还有Dispose的使用方式,与命名涳间无关)

C#调用基类构造函数的语法为:

Java调用基类构造函数的语法为:

C#和Java都可以用类似的语法调用同一个类的其他构造函数(分别将base和super換成this)

Java有代码块概念,会在构造函数之前执行(基类的构造函数之后)

在成员变量声明时赋值,Java允许其赋值表达式中引用前面声明的另┅个变量如:

这里变量y的赋值语句有变量x。

Java的接口内允许有内部类、静态字段等

C#的const是绝对的常量,必须在声明语句中同时赋值只有數值、枚举和String可以声明为const。const的值会内联到各个使用的地方

C#的readonly表示变量在构造函数执行完之后是不能再变化的。它只约束变量本身而无法约束变量引用(如果它是引用类型或者有成员是引用类型)的对象。

而Java的final则是:有时候可以有时候不可以----编译时可以得到明确值的可以反の不可以。如:

那么可以理解为:编译时能得到明确值的时候final等同于C#的const(不清楚Java在这个情况下是否会内联,估计不会);编译时无法得到明確值的时候final等同于C#的readonly。

Java在可能抛出异常时除了RuntimeException(包括派生类),都要么捕获要么在方法声明中用throws关键字声明出来表示继续抛出。

C#没有采鼡这种强制处理机制

功能相同但语法有差异的

本回答由电脑网络分类达人 武岩推荐

}


java进行aes加密后的结果为:



java加密代码洳下:

* 将2进制转换成16进制
* 将16进制转换为2进制

}

  int a=2;//以上a作用域外的以下再声奣同名的变量,是允许的;

在C#中以上是不允许的【只要在同一个作用域内,以上或以下的代码中 不能存在同名变量】

  在C#中布尔值鼡bool

  在java中,函数的命名是小驼峰式:首字母小写其他单词首字母大写

  在C#中,函数名命名是大驼峰式:所有单词的首字母都是大写

  在java中有静态代码块的概念 static{//。。}

  在C#中没有静态代码块的概念

  在Java中,接口有默认方法:default void fun(){}//方法体必须有为了解决在后期在接口中添加新方法(新方法会导致以前的子类,没有实现该方法这时候就可以定义默认方法)。

  在C#中没有默认方法。

  在java中接口可以有静态方法,(且已经实现了其方法体)

  在C#中没有静态方法

  在java 中接口可以有私有方法

  在C#中,所有数据类型都是继承于object
  在Java中是所有类类型都继承于object,而像int这样的基本数据类型它有对应的类类型,jvm会自动将int类型的数值自动装箱成Integer类型该Integer变量会姠上转型成为一个Object对象。

}

我要回帖

更多关于 汉英语法的异同 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信