【ArchSummit】如何通过AIOps推动可量化的业务价值增长和效率提升?>>> 了解详情
写点什么

.NET API 审查第二部分

  • 2015-01-27
  • 本文字数:1740 字

    阅读完需:约 6 分钟

本文是对于 1 月 14 日所进行的.NET API 审查会议的分析的第二部分。这篇报告中涵盖了HashSet、RegEx、Process.Start、Immutable collections 和BitVector32 等API 的相关讨论。

[视频] GitHub Issue#382:为HashSet添加一个新的构造函数,可以在其中指定数据结构的初始大小

这一条意见毫无争议地通过了,只是让人有些疑惑的是,为什么原始版本中竟然会不支持这一特性。

[视频] GitHub Issue#304:正则功能应当提供一个校验方法

目前,RegEx 解析器采取了一种快速失败的方法。这就意味着,如果在某个正则表达式字符串中存在多个错误,解析器只会报告第一个错误的存在,并且会立即中断解析过程。

这一建议的关键就在于希望获取更多的信息。在理想的情况下,解析器应当返回一个错误集合,以显示正则表达式中的所有问题。但这就需要解析器尝试从错误中进行恢复,继续解析之后的表达式内容,并寻找其它错误。

对此建议的一个顾虑在于,如果接受了这一建议。接下来就会有人提出进一步的要求,例如自定义高亮、代码自动完成等等,以便在Roslyn 中进行使用。而这种要求已经远远超出API 的范围了,因此评审团队担心,一旦接受了这一建议,迟早都会需要一个新的API。

结论:分别讨论两组建议。

一个建议是在RegEx 在解析过程中出错时,对RegEx 抛出的异常信息加以改善。这里只会包含一些基本信息,例如第一个错误的具体位置,前提是这种方式不会让代码产生太多重写要求。

第二个建议是,是否应该添加对应的TryParse 方法。

RegEx API 并不会扩展到这种可以支持 IDE 的程度。

[视频] GitHub Issue#311:重新引入Console.CancelKeyPress 方法

这一条建议本身非常简单,就是重新引入这个存在于Windows 桌面版的.NET 中的方法,并将其扩展至跨平台版本的.NET 中。不考虑兼容性问题的话,那就是简单地从原始版本中进行拷贝粘贴而已。

[视频] GitHub Issue#306:为Process.Start 方法增加一个选项,以改变句柄的继承

表面上看,这个问题十分简单。在Windows 中,句柄可以在子进程中继承,这可能会导致预料之外的问题,例如Notepad 可能会持续保持一个打开的TCP socket,即使在父应用尝试关闭它之后。这个新的参数则能够让用户选择不继承句柄。

问题在于,这种处理在Linux 环境下毫无意义。在Windows 下创建子进程会使用一个全局的配置,而Linux 则允许在创建句柄时指定每个句柄是否能够被继承。

一种建议是为句柄继承提供一个三态的属性:操作系统默认、继承句柄,以及不继承句柄。

另一种建议是创建一个基础版本的ProcessStartInfo 方法,并且只提供跨平台的选项。然后通过创建子类的方法实现Linux、Win32 和Windows Shell Execute 的特定功能。

结论:提供一个新的属性,其类型为现有的HandleInheritability 枚举,其中包含两个状态值。

[视频] GitHub Issue#318:对ImmutableInterlocked.ApplyChange API 的建议

要确保对一个可变集合的变更是线程安全的,你必须获得对该集合的一个引用,创建一个替代的列表,并尝试调用 Interlocked.CompareExchange 来决定是否能够成功地替换原始列表。如果另一个线程在同一时间要覆盖该集合,该方法会返回 false,你必须重新启动该过程以再次尝试。

ImmutableInterlocked 能够简化一些基础操作的过程,例如添加或移除集合的项。你仍然需要在循环中使用它,但可以避免对本地变量的处理。

下一个建议是增加一个相应的泛型实现,其中可以接受一个 lambda 表达式进行某些操作。从技术上来说,这个泛型实现会使其它实现方式都变成多余的了,但既然那些实现已经发布,也不可能删除它们了。

结论:决定添加这个新方法。

有一个问题是,是否要将那些多余的方法标记为过期。

结论:由于那些多余的方法依然可以正常工作,因此不应该标记为过期。

[视频] GitHub Issue#373:BitVector32 应当实现IEquatable接口

BitVector32 能够以一个比特和小整数数组的形式表现一个整数值。该类型存在于 System.Collections.Specialiazed 命名空间中,这个命名空间通常被基础类库团队当作遗留代码,没人敢去动其中的内容。

与之相关的一个问题是 BitArray 类,如果不把 BitVector32 当作遗留代码处理,那么它就应当和 BitArray 中的功能相一致。

对于该提议尚未得出任何结论,稍后将会再次对此展开讨论。

查看英文原文:.NET API Review Part 2

2015-01-27 19:521256
用户头像

发布了 428 篇内容, 共 172.2 次阅读, 收获喜欢 38 次。

关注

评论

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

成为架构师 - 架构师训练营第 02 周

陈永龙Vincent

架构训练营-week6-学习总结-技术选型(二)

于成龙

架构训练营

玩转华为云开发|老板万万没想到:刚入职的我一人就搞定人脸识别开发

华为云开发者联盟

软件开发 模块化流程 人脸识别 API 华为云

第1周 架构方法-作业

SuGeek

全网首发,做第一人纯源码讲解RabbitMQ实践,收藏吧

小Q

Java 学习 架构 面试 RabbitMQ

架构训练营第二周学习小结

李日盛

写时复制集合 —— CopyOnWriteArrayList

程序员小航

Java 源码 并发 源码阅读 JUC

三分钟带你分清Mysql 和Oracle之间的误区

华为云开发者联盟

MySQL 数据库 oracle 安全 关系型数据库

使用抓包工具fiddler和apipost进行接口测试

测试人生路

测试工具 fiddler

架构师训练营第 1 期第 6 周学习总结

好吃不贵

极客大学架构师训练营

云小课|云数据库RDS实例连接失败了?送你7大妙招轻松应对

华为云开发者联盟

数据库 网络 ssl RDS实例 端口

架构师训练营 1 期第 6 周:技术选型(二) - 作业

piercebn

极客大学架构师训练营

架构师训练营第六周作业

我是谁

极客大学架构师训练营

架构师训练营第六周课后练习

薛凯

架构师训练营第二周作业

邢永春

软考资料学习库

玄兴梦影

作业一:

丁乐洪

CAP 原理

黄立

CAP

阿里五位MySQL封神大佬耗17个月总结出53章性能优化法则

996小迁

Java MySQL 大数据 架构 面试

架构师训练营 W02 作业

Geek_f06ede

架构师训练

架构师训练营第 1 期第 6 周作业

好吃不贵

极客大学架构师训练营

jdk 源码系列之HashMap

sinsy

源码 jdk HashMap底层原理

钻石与小度:智能语音助手背后的“马斯洛需求模型”

脑极体

Mysql中,这21个写SQL的好习惯,你值得拥有呀

捡田螺的小男孩

MySQL sql SQL优化 sql习惯

Java程序员必会的三个技能:Spring+MySQL+并发编程

Java架构师迁哥

架构师训练营 W02 总结

Geek_f06ede

架构师训练

阿里内部首发Spring Cloud全套微服务架构笔记,速拿去怼面试官!

Java架构追梦

Java 编程 面试 微服务 SpringCloud

十八般武艺玩转GaussDB(DWS)性能调优(二):坏味道SQL识别

华为云开发者联盟

数据库 sql 性能调优 GaussDB 算子

RabbitMQ之路由和通配符模式,附源码注释讲解

小Q

Java 学习 架构 面试 RabbitMQ

架构训练营-week6-作业

于成龙

CAP 架构训练营

渣渣2本学历CRUD一年半,决定改变现状,努力学习两个月成功拿到美团30k offer

Java架构之路

Java 程序员 架构 面试 编程语言

.NET API审查第二部分_.NET_Jonathan Allen_InfoQ精选文章