写点什么

C# 8 新提案让泛型 Attribute 成为现实

  • 2019-01-28
  • 本文字数:955 字

    阅读完需:约 3 分钟

C# 8新提案让泛型Attribute成为现实

从一开始, Attribute 就是.NET 的一部分。因此,它们在引入泛型之前就已经被创建好,这意味着如果要引用属性中的类型,必须暴露一个 Type 参数或属性。例如:


[TypeConverter(typeof(X))]
复制代码


这种模式存在一些限制。在上面的示例中,X 必须有一个无参数的构造函数,并继承 TypeConverter。编译器不会强制这些,所以开发人员只能在运行时发现错误。


相反,如果我们使用泛型类型参数,那么就可以在编译器强制执行这些规则,而且语法会稍微清晰一些。


[TypeConverter<X>]
复制代码


理论上,“Allow Generic Attributes”提案是一个非常简单的变更。CLR 已经支持这个概念,问题是如何在.NET 语言中使用它。但有时候理论和现实是两条平行线,而且即使 CLR 可以支持,并不代表就一定会支持。Jan Kotas 解释说:


我认为这个问题的本质与局部引用和 return 类似。局部引用和 return 不受任何 API 的限制,理论上它们在现有的运行时、工具和库上都能正常运行。但在实际当中,它们可能不能正常运行,因为它们暴露了预先存在的错误和限制,可能是因为它们的处理路径从未被执行过,或者它们明显不在预期之内。与引用 return 相关的错误和问题刚刚开始出现,因为人们开始使用这项功能,并发现了一些不奏效的地方。我认为这在预期之内。我们应该承认这些事实,并且不会采取之前我们撤回默认值类型构造函数功能那样的行动。

这个功能非常类似。ECMA 并没有针对禁止使用泛型 Attribute 的内容,在理论上应该可以正常运行,但实际上却没有。如果要正常运行,必须更新整个系统中的很多部件:

  1. 存在多个运行时(Mono、CoreRT、整个框架);

  2. IL 的一些工具也可能会受到影响(编译器、基于 Cecil 或基于 CCI2 的工具);

  3. 可能需要用于访问泛型 Attribute 的 API(例如,现有的反射 API 不允许你访问泛型 Attribute——你必须进行枚举)。


该提案的一个限制是在编译时必须“关闭”Attribute 功能。下面是提案中提供的一个启用泛型 Attribute 的例子。


[SomeAttribute<T>]public void DoSomething<T>(T input) { }
复制代码


因为 T 不是在编译时定义的,因此反射机制就不知道这个表达式会返回什么。


typeof(GenericClass<>).GetMethod("DoSomething").GetCustomAttributes()
复制代码


状态


目前,泛型 Attribute 功能列在C# 8路线图中,状态为“进行中”。


查看英文原文https://www.infoq.com/news/2019/01/Generic-Attributes


2019-01-28 10:075382
用户头像

发布了 731 篇内容, 共 468.2 次阅读, 收获喜欢 2006 次。

关注

评论

发布
暂无评论
发现更多内容

YashanDB数据库集群架构设计及实现步骤详解

数据库砖家

征程 6X|GPU 应用场景

地平线开发者

自动驾驶 算法工具链 地平线征程6

【HarmonyOS next】ArkUI-X休闲益智记忆翻牌【进阶】

RunkBear

跨平台的数据开发和管理工具 DB Solo for Mac

Rose

仓颉:深入解析仓颉编程语言中的枚举类型 (Enum)

x

仓颉

从策展式推荐到全周期赋能,AppGallery照亮精品应用每一程

脑极体

AI

HarmonyOS实战:GIF图下载突破5M限制保存到相册

IT小码哥

HarmonyOS Next IM实战: Worker线程中模块未初始化异常处理

轻口味

HarmonyOS HarmonyOS NEXT

2D和三维家居设计和室内装饰计划 Planner 5D for Mac中文

Rose

AI 智能体开发的技术方案

北京木奇移动技术有限公司

AI智能体 软件外包公司 AI技术应用

从工业标杆到AI City,天津有一种“经济上行的美”

脑极体

AI

HarmonyOS NEXT仓颉开发语言实战案例:图片预览器

幽蓝计划

HarmonyOS NEXT

YashanDB数据库配置优化及资源合理分配技巧

数据库砖家

【HarmonyOS next】ArkUI-X休闲益智打地鼠【进阶】

RunkBear

HarmonyOS NEXT仓颉开发语言实战案例:动态广场

幽蓝计划

HarmonyOS NEXT

AI 智能体开发的技术架构

北京木奇移动技术有限公司

AI教育 AI智能体 软件外包公司

AI 英语写作App的开发

北京木奇移动技术有限公司

AI技术开发 软件外包公司 AI英语学习

【HarmonyOS next】ArkUI-X新闻热搜聚合App【进阶】

RunkBear

【HarmonyOS Next】ArkUI-X休闲益智接水果【进阶】

RunkBear

YashanDB数据库集群管理与故障切换操作详解

数据库砖家

Luminar AI for Mac AI 智能修图、一键增强、创意模板

Rose

编程开发!Binary Ninja Mac 逆向编译工具

Rose

走近华为HDC,深度感受HarmonyOS使能下的千行百业创新体验

最新动态

【HarmonyOS next】ArkUI-X休闲益智儿童拼图【进阶】

RunkBear

从0到1:园区巡检与隐患上报小程序开发笔记(上)

CC同学

【HarmonyOS next】ArkUI-X休闲益智连连看【进阶】

RunkBear

【HarmonyOS next】ArkUI-X休闲益智消消乐【进阶】

RunkBear

【HarmonyOS next】ArkUI-X休闲娱乐搞笑日历【基础】

RunkBear

YashanDB数据库集群环境中的数据同步最佳实践

数据库砖家

Apeaksoft Blu-ray Player for Mac(蓝光视频播放器)

Rose

Amazon Bedrock Agent 示例与最佳实践

qife

Amazon Bedrock 多智能体协作

C# 8新提案让泛型Attribute成为现实_语言 & 开发_Jonathan Allen_InfoQ精选文章