从和朋友的调侃中看C#和JAVA的区别

来源:互联网 发布:node cluster 编辑:程序博客网 时间:2024/05/17 08:18
 以下是和朋友聊天的内容,纯粹是调侃的,大伙稍微一看就明白我们谈的是什么了!

2004-12-26 22:28:27 cafecup
饿了,吃饭,哈哈

2004-12-26 22:28:44 孤独客二号
朱去不,要不明天

2004-12-26 22:28:37 cafecup
他在打电话。。

2004-12-26 22:29:00 孤独客二号
吃饭?现在还有饭吃,爽啊

2004-12-26 22:28:51 cafecup
你用你的超级无敌泡泡给他发短信

2004-12-26 22:28:56 cafecup
哈哈,你吃不

2004-12-26 22:28:59 cafecup
这里还有好多

2004-12-26 22:29:15 孤独客二号
你问问他,如果明天行就明天去

2004-12-26 22:29:20 孤独客二号
不要给我说是面

2004-12-26 22:29:25 孤独客二号
是面一律不吃

2004-12-26 22:29:15 cafecup
不是

2004-12-26 22:29:20 cafecup
是方便面

2004-12-26 22:30:51 孤独客二号
高,实在是高,已经能认为方便面不是面了,智商至少.....我估计应该相当于5岁大孩了吧,要不就可以进非正常人研究所了

2004-12-26 22:31:38 cafecup
。。。方便面是面的子类,可以把一个方便面的句柄给一个面变量,但是反之不行,明白了不

2004-12-26 22:32:16 孤独客二号
所以说方便面是面,面不是方便面,懂不

2004-12-26 22:33:05 cafecup
方便面 fbm = new 方便面();
面 m = fbm;

2004-12-26 22:33:44 cafecup
反之。
面 m = new 面();
方便面 fbm = m;错误~

2004-12-26 22:33:54 cafecup
哈哈,不跟你扯了,明天啥时候

2004-12-26 22:34:17 孤独客二号
方便面已经实现面这个接口,所以在用到面的时候就可以使用方便面,所以说方便面是面

2004-12-26 22:34:57 cafecup
哈哈,不跟你扯了,不知道你对这个概念掌握的还挺不错的,蒙你不过去了

2004-12-26 22:35:12 孤独客二号
同时注意这里的面是面这个接口,不是面粉这个具体类

2004-12-26 22:35:10 cafecup
。。。扯

2004-12-26 22:35:25 cafecup
为什么要声明称一个接口。。

2004-12-26 22:35:58 cafecup
接口不能有任何的属性啊,面就没有一点的共性了么

2004-12-26 22:36:15 孤独客二号
噢?为什么要声明一个接口?

2004-12-26 22:36:39 孤独客二号
哈哈,不知道了吧,接口是可以有属性的

2004-12-26 22:36:59 cafecup
。。。接口的方法必须声明为 abstract

2004-12-26 22:37:22 孤独客二号
不过是PUBLIC STATIC FINAL的而已,呵呵,偶的JAVA基础还是没你的好喽

2004-12-26 22:37:32 cafecup
。。。

2004-12-26 22:38:32 孤独客二号
我暑假在公司,老板说什么东西都要先写接口,要先定义好他的行为,然后知道他的特点,再写他的属性,写他的子类

2004-12-26 22:38:41 cafecup
。。。接口可以有属性么?

2004-12-26 22:39:05 孤独客二号
呵呵,确实应该是用抽象类,不应该用接口,偶承认,呵呵,不扯了

2004-12-26 22:38:58 cafecup
哈哈


呵呵,和朋友聊完天,我去洗涮了,准备睡觉。但仔细考虑了一下我回答朋友我为什么用接口而不是用抽象类的原因,自己总感觉我给的原因是强给自己找理由,这到底是为什么我会先想到用接口而不是用抽象类呢?苦思了一会,终于明白了!因为我这一两年来一直在使用C#,在C#定义接口的时候是可以定义属性的,而JAVA中是不可以的,而且C#中的属性和JAVA的属性还不太一样!举个例子来说吧!定义一个测试类,分别用JAVA和C#语言来实现:
C#
public class Test
{
    private string _name;
    public string Name
    {
        get{
              if(_name==null)
                return "";
              else
                return _name;
        }
        set{
        _name=value;}
    }
}

JAVA
public class Test
{
    public string name;
}

这里,很明显,JAVA中的属性是直接对其进行了存取,其安全性就存在了问题。存在什么问题呢?那就是任何持有对象reference的人都可以对它的属性进行直接的读取或赋值。所以JAVA就对其进行了改进和封装,如下:
public class Test
{
    private string _name;
    public String GetName()
    {
        if(_name==null)
              return "";
        else
              return _name;
    }
    public void SetName(String name)
    {
        _name=name;
    }
}
但这里很明显,JAVA中对属性的存取已经不是直接对属性的操作了,而是方法,这时的属性也已经对用户不可见了!而C#呢?其中的属性是JAVA所没有的,其中已经内含了对“属性”的存取操作了,你可以只设其SET或GET,或在其SET或GET中加入一些判断!

有了以上的概念,再来讲JAVA和C#的接口的不同之处。因为C#新加入的这种属性概念已经内置了对JAVA中所谓属性的存取操作,所以在C#中是可以有属性的,而JAVA不可有这种属性(JAVA接口中的属性只能是PUBLIC STATIC FINAL的,这点在上面的聊天中已提及)。因此,如果在JAVA中如果实现一个类似于基类的概念的时候,因为对象是由属性为表现其状态的,因而是由属性的,且基类拥有的子类的共性,即共有的属性,因而只能用抽象类,而不能用接口。而C#中的属性已经内置了对属性的存取控制,从而控制了安全性,因而C#接口中是可以包含这种属性的。如下例:
C#
public interface Test
{
    public string Name
    {
        get;
        set;//可以根据自己的需要或者只定义GET或只定义SET
    }
}

在暑假中,我所在的公司是用.NET作二次开发的,老板确实要求是要先定义接口的,因而现在在考虑JAVA的时候还是用C#的思想,因而在一下子就想到了用接口。而实际上在C#中,接口已经可以取代部分抽象类了,要求抽象类中不包含部分方法的实现和一些属性的实现,也就是纯抽象的!


个人陋见,难免粗浅,请各位指教!
原创粉丝点击