写点什么

.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:521747
用户头像

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

关注

评论

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

行业分析| 快对讲,楼宇对讲

anyRTC开发者

音视频 快对讲 语音对讲 视频对讲 楼宇对讲

易观分析《2022年中国银行业隐私计算平台供应商实力矩阵分析》研究报告正式启动

易观分析

银行技术

LSF 集群全面监控!浅析 HPC 基于龙蜥操作系统的迁移替代解决方案

OpenAnolis小助手

开源 解决方案 龙蜥操作系统 常青藤开源科技 HPCinsights

2022 开源软件安全状况报告:超41%的企业对开源安全没有足够的信心

SEAL安全

DevSecOps 开源安全 软件供应链 安全左移

如临现场的视觉感染力,NBA决赛直播还能这样看?

阿里云CloudImagine

音视频 直播 音视频直播 直播解决方案

百度APP 基于Pipeline as Code的持续集成实践

百度Geek说

Java’

中国内地仅四家突围 联想智慧颐和园荣获 “2022年IDC亚太区智慧城市大奖”

科技大数据

智联招聘基于 Nebula Graph 的推荐实践分享

NebulaGraph

知识图谱 Nebula Graph

《运营之光3.0》全新上市——跨越时代,自我颠覆的诚意之作!

博文视点Broadview

Java培训 动态代理的底层原理

@零度

JAVA开发 动态代理

大神详解开源 BUFF 增益攻略丨直播讲座

Apache IoTDB

开源 面试 求职 秋招 线上讲座

讲师征集令 | Apache DolphinScheduler Meetup分享嘉宾,期待你的议题和声音!

白鲸开源

Apache 大数据 开源 workflow dolpinsheduler

百问百答第44期:应用性能探针监测原理-Python探针

博睿数据

APM AIOPS 智能运维 博睿数据 性能监测

一套十万级TPS的IM综合消息系统的架构实践与思考

JackJiang

网络编程 架构设计 即时通讯 im开发

TiDB v6.0.0 (DMR) :缓存表初试丨TiDB Book Rush

PingCAP

TiDB

VPS是干嘛用的?有哪些知名牌子?与云服务器有什么区别?

行云管家

运维 等保备案 VPS

人人都可以参与开源!龙蜥社区最不容错过的开发者活动来了

OpenAnolis小助手

开源 龙蜥社区 礼品 开发者激励 贡献

小白创业做电商,选对商城系统很重要!

CRMEB

太阳能无线LED显示屏的特点

Dylan

LED LED显示屏

当量子计算遇上人工智能

启科量子开发者官方号

人工智能 算力 量子计算

物联网低代码平台常用《组件介绍》

AIRIOT

低代码 物联网 低代码开发平台 低代码平台 低代码,项目开发

叮!Techo Day 腾讯技术开放日如约而至!

CODING DevOps

CODING DevOps Cloud Studio Techo 腾讯技术开放日

web前端培训Node.js 如何连接到 PostgreSQL 数据库

@零度

node.js 前端开发

2022中国信通院首届业务与应用安全发展论坛成功召开!

中国IDC圈

Flink流处理API大合集:掌握所有flink流处理技术,看这一篇就够了

百思不得小赵

大数据 6月月更 flink api

等保备案主体是谁?在当地网安进行备案是吗?

行云管家

等保 等级保护 等保备案

wallys/DR7915-wifi6-MT7915-MT7975-2T2R-support-OpenWRT-802.11AX-supporting-MiniPCIe-Module

wallys-wifi6

setInterval、setTimeout和requestAnimationFrame

源字节1号

软件开发

通过大数据培训学习后到35岁后为什么会失业

@零度

《数字经济全景白皮书》消费金融数字化篇 重磅发布

易观分析

消费金融

layui-vue简单体验

Python研究所

6月月更

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