新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   XML论坛     W3CHINA.ORG讨论区     >>计算机科学论坛<<     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> 本版讨论.NET,C#,ASP,VB技术
    [返回] 计算机科学论坛计算机技术与应用『 Dot NET,C#,ASP,VB 』 → C#.net 2003的改变 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 2461 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: C#.net 2003的改变 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     admin 帅哥哟,离线,有人找我吗?
      
      
      
      威望:9
      头衔:W3China站长
      等级:计算机硕士学位(管理员)
      文章:5255
      积分:18407
      门派:W3CHINA.ORG
      注册:2003/10/5

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给admin发送一个短消息 把admin加入好友 查看admin的个人资料 搜索admin在『 Dot NET,C#,ASP,VB 』的所有贴子 点击这里发送电邮给admin  访问admin的主页 引用回复这个贴子 回复这个贴子 查看admin的博客楼主
    发贴心情 C#.net 2003的改变


    发信人: Nineteen (_-), 信区: DotNET        
    标  题: C#.net 2003的改变
    发信站: BBS 水木清华站 (Thu Jun  5 18:01:24 2003), 转信

    Visual C# .NET 2003 语言的改变  
    Prashant Sridharan
    Microsoft Corporation  
    2002年12月30日  
    适用于:
       Microsoft Visual Studio? C# 2003

    摘要:为了与欧洲计算机制造商协会 (ECMA) 的 C# 规范完全兼容,Microsoft  
    Corporation 对 C# 编译器的实现进行了几处改动。这些改动将在多方面影响现有的代码
    ,因此用户必须检查他们的代码以确保这些代码符合 C# 编程语言必需的和推荐的使用要
    求。  

    目录

    背景  
    C# 语言的新功能  
    实现的改变  
    小结  
    背景
    2001 年年底,ECMA 将 C# 编程语言批准为一项标准 (ECMA-334)。为了与 Microsoft 在
    C# 和公共语言接口 (CLI) 标准化进程方面的举措保持一致,Microsoft 遵循 ECMA C#  
    标准的精神和文字规范对 C# 编译器进行了几处小的改动。另外,Microsoft 在遵循 C#  
    标准规范的同时对 C#  
    实现作了一些额外的小改动,并更正了 C# 程序员遇到的一些编译器问题和错误。其中的
    每处改动都可能导致使用 Visual C# .NET 2002 版编译器编写的代码在用于 Visual C#  
    .NET 2003 之前必须进行修改。

    C# 语言的新功能
    Visual C# .NET 2003 版的 C# 语言中添加了两个新功能。第一,编译器现在支持  
    #line hidden 预处理器指令。#line hidden 指令主要用于源代码生成器,它通知编译器
    忽略紧跟在 #line hidden 指令后面的所有代码行的调试程序信息,直到遇到下一个  
    #line 指令为止(该 #line  
    指令的调试程序信息也一并被忽略),这里假设它们中间不会立即碰到下一个 #line  
    hidden 预处理指令。在下面的示例中,编译器生成了 IL 代码,其中的 WriteLine 语句
    不包含调试信息。这样,调试应用程序的程序员将无法查看“隐藏”的代码并检查其中的
    内容:

    public class Customer
    {
       public static void Main()
       {
          MyClass c = new MyClass();

          c.ExecuteCommand();

          #line hidden
          Console.WriteLine(&quot;显示一些文字&quot;);
          Console.WriteLine(&quot;显示一些文字&quot;);
          Console.WriteLine(&quot;显示一些文字&quot;);
          #line

          c.ProcessCommand();

          c.Close();
       }
    }
    然而,#line hidden 指令并不隐藏编译器错误。当然,编译器仍然将代码编译到 IL 中
    ,且代码仍旧执行;编译器只是禁止调试程序进入它的内容。

    第二个 C# 新功能涉及 XML 注释,是根据 ECMA 标准添加的。C# 现在支持在使用“斜线
    和星号”符号(/* 和 */)编写的多行注释中添加 XML 注释。下面的 XML 注释在 2003  
    版的 C# 编译器中是合法的:

    /**
    &lt;summary&gt;这是
    注释

    &lt;/summary&gt;
    */
    此外,出于完整性的考虑(但实际上绝不推荐),程序员可以混合并匹配注释样式,同时
    仍然能够编写出有效的 XML 注释代码。这样,下面的这个注释声明现在也是合法的:

    /**
    &lt;summary&gt;这是
    注释
    */
    /// &lt;/summary&gt;
    实现的改变
    2003 版的 C# 编译器和 2002 版也有微小的区别。在有些情况下,这些区别可能会导致
    代码无法编译,或导致其运行方式与应执行的方式大相径庭。

    “Foreach”语句的改变
    现在,foreach 语句可以动态地检查它所迭代的数据结构中是否存在 IDisposable 接口
    。以前,编译器从不动态地检查 Idisposable 接口是否存在,除非从 GetEnumerator 返
    回的类型已实现了 IEnumerator 接口。然而,如果此类型对于实现 Idisposable  
    是静态已知的,则编译器将一直调用 Dispose。换句话说,如果迭代程序类型实现了枚举
    器设计模式,但没有专门实现 IEnumerator 接口,编译器就不会调用 Dispose 方法,除
    非 iterator 类型对于实现 IDisposable 接口是静态已知的。

    现在,编译器在检测是否存在 IDisposable 接口时,无论迭代程序类型是否实现  
    IEnumerator,都将调用 Dispose 方法(如果已实现)。在下面的示例中,Visual C#  
    .NET 2002 编译器未调用 Dispose 方法,但 Visual C# .NET 2003 编译器调用了该方法


    abstract class Base
    {
       public int Current { get; }
       public bool MoveNext();
    }

    class Derived: Base, IDisposable
    {
       // Base 和 IDisposable 的实现
    }

    class MyClass
    {
       public Base GetEnumerator()
       {
          return new Derived();
       }
    }
    当 foreach 语句在某个对象集合中使用迭代时,它将执行 GetEnumerator 方法并接收转
    换为 Base 类型的 Derived 实例作为它的迭代程序类型。当然,Base 类型无需为了调用
    它的 Current 和 MoveNext 方法而实现 Ienumerator 接口。在早期编译器中,Derived  
    类型的 Dispose  
    方法不被调用,因为它不实现 IEnumerator,并且类 Base 对于实现 Idisposable 不是
    静态已知的。在新的编译器中,Dispose 方法被调用,因为编译器在所有 foreach 语句
    的迭代程序类型中检查是否存在 Idisposable 接口。由于 GetEnumerator 调用的结果是
    一个转换为 Base  
    类型的 Derived 类型,并且由于 Derived 类型实现 Idisposable 接口,因此编译器动
    态检查 Idisposable 接口是否存在,会导致对 Dispose 方法的调用。

    属性声明的改变
    ECMA C# 标准明确禁止为相应的属性创建获取和设置函数。实际上,C# 编译器将属性声
    明转换为获取和设置函数,以便不支持属性的语言也可以访问数据。因此,下面的代码是
    无效的,因为编译器会产生 get_Prop 和 set_Prop 方法,而这两个方法与用户声明的方
    法发生冲突:

    public class MyClass
    {
       public int Prop

       {
          get
          {
          }

          set
          {
          }
       }

       // 现在属于非法函数
       public int get_Prop()
       {
       }

       // 现在属于非法函数
       public void set_Prop(int val)
       {
       }
    }
    以前,C# 编译器允许创建此类函数,显然这是一个软件错误。2003 版的 C# 编译器纠正
    了这个错误。

    作为此编译器错误纠正的必然结果,C# 编译器将不再允许显式创建生成属性的获取和设
    置函数(如果将属性定义为接口实现的结果)。在下面的示例中,2003 版的 C# 编译器
    不再允许在 Derived 类中显式实现 IMyInterface.get_Prop 和 IMyInterface.set_Prop
    方法:

    interface IMyInterface
    {
       public int Prop { get; set; }
    }

    public class Derived : IMyInterface
    {
       public int Prop
       {
          get
          {
          }

          set
          {
          }
       }

       // 非法
       public int IMyInterface.get_Prop()
       {
       }

       // 非法
       public void IMyInterface.set_Prop(int val)
       {
       }
    }
    其他改变
    C# 编译器的早期版本允许不兼容地使用属性。2003 版的 C# 编译器已经纠正了这些用法
    ,因此更符合 ECMA 规范。首先是对 C# 编译器进行了纠正,不允许在其参数列表中使用
    未在属性类声明中声明为 public 的命名参数。例如,如果某个 AuthorAttribute 类是
    使用名为 authorName  
    的私有字段创建的,则下面的语句在 C# 编译器的早期版本中是允许的,但在 C# 2003  
    编译器中却会导致错误:

    [Author(authorName=&quot;microsoftuser&quot;)]
    public class MyClass
    {
    }
    第二,ObsoleteAttribute 现在可以应用到运算符,这样程序员就可以使重载的运算符函
    数失效。最后,编译器以前对于无法识别的属性位置常常生成一个错误,而现在则根据  
    ECMA C# 规范的要求只生成一个警告。

    另外,C# 编译器以前接受用户定义的移位运算符参数(&lt;&lt; 和 &gt;&gt;),而根据 ECMA C# 规
    范,这些参数是无效的。例如,移位运算符以前可以按以下方式进行声明,即将封装类的
    类型声明为第二个操作数:

    public class MyClass
    {
       public static MyClass operator &lt;&lt;(int I, MyClass c)  
       {
       }
      
       public static void Main()
       {
       }
    }
    按照规范,如果向左移位运算符被重载,则二进制运算符的操作数列表中的第一个参数必
    须为封装类型。同样,如果向右移位运算符被重载,则二进制运算符的操作数列表中的第
    二个参数必须为封装类型。下面的代码示例演示了向左移位运算符的正确声明方式:

    public class MyClass
    {
       public static MyClass operator &lt;&lt;( MyClass c, int i)  
       {
       }
      
       public static void Main()
       {
       }
    }
    最后,还加入了几个用于纠正编译器错误的修复,包括:  

    对显式赋值算法的纠正,使编译器对于符合 ECMA C# 规范的代码不再报错。  
    枚举类型现在可以转换为字符(详见 ECMA C# 规范中的说明)。  
    内部虚警告已被删除,因为内部虚函数无法在程序集外被重写。  
    小结
    C# 编译器以不同的方式实现了几个功能,从而获得了比前一版更高的性能。但这些改进
    不会影响对代码的编译和执行:  

    在迭代字符串的元素时,foreach 语句现在使用字符串的索引器而非枚举器模式,这样使
    性能更佳。  
    现在,C# 编译器在处理浮点运算和十进制数学运算方面更严格地遵循 ECMA C# 规范。  
    几个软件错误已被修复,使控制流得到优化。  

      
    --
    “你就是猪头——砍下来也没有半斤的那种!”
    “悟空,世事无常,明镜在心,你猴眼看人,又如何分辨猪头之美丑?”


    ※ 修改:·DRAGONESE 于 Jun  6 11:06:20 修改本文·[FROM:  166.111.152.18]
    ※ 来源:·BBS 水木清华站 smth.org·[FROM: 202.206.1.26]
    上一篇
    返回上一页
    回到目录
    回到页首
    下一篇


       收藏   分享  
    顶(0)
      




    ----------------------------------------------

    -----------------------------------------------

    第十二章第一节《用ROR创建面向资源的服务》
    第十二章第二节《用Restlet创建面向资源的服务》
    第三章《REST式服务有什么不同》
    InfoQ SOA首席编辑胡键评《RESTful Web Services中文版》
    [InfoQ文章]解答有关REST的十点疑惑

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2004/11/9 2:26:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 Dot NET,C#,ASP,VB 』的所有贴子 点击这里发送电邮给Google AdSense  访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2025/7/23 0:46:59

    本主题贴数1,分页: [1]

    管理选项修改tag | 锁定 | 解锁 | 提升 | 删除 | 移动 | 固顶 | 总固顶 | 奖励 | 惩罚 | 发布公告
    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    62.988ms