go - Go中的阻塞构造函数
问题描述
假设我有一个 type Connection
,它代表一个 TCP 连接。建立连接是一个阻塞操作。我看到了两种设计其界面的方法,我的问题是哪一种在 Go 中更惯用:
func NewConnection(...) (*Connection, error)
阻塞并返回已建立的连接。- 优点:不能有 invalid
Connection
s 闲逛。内存中的任何Connection
一个都是已建立的有效连接。 - 缺点:阻塞构造函数可能令人惊讶。
- 优点:不能有 invalid
func NewConnection(...) Connection
立即返回一个新连接,我们需要调用阻塞func (c *Connection) Establish() error
来实际建立连接。- 优点:非阻塞构造函数对我来说似乎更“正常”。
- 缺点:人们可能会忘记打电话
Establish
。在这种情况下这是微不足道的,但是如果类型很复杂并且我们需要对其进行大量配置(甚至可能需要按特定顺序调用事物),这给程序员提供了更多搞砸的机会。
解决方案
正如评论所暗示的,阻塞构造函数没有任何问题,但函数的命名应该反映它可能阻塞的事实。文档也应该。
在标准库中,如果您想创建一个新套接字并连接到某个服务器,您可以在一次调用中完成:net.Dial
func Dial(network, address string) (Conn, error)
这是一个返回新的阻塞操作Conn
。
所以在 Go 中这样做是惯用的,你应该把它命名正确。我同意你的直觉,即#2 对可用性来说不太好。
推荐阅读
- javascript - 你如何让 Math.max 给你变量名
- python - 如何根据返回的值缓存函数的结果
- linux - 如何使用 Linux 以 MonthYear 格式(December2020)获取上个月和上一年
- javascript - 如何在 div 中垂直居中内容?
- docker - 如何在 Docker-in-Docker 容器之间重新共享卷?
- php - 当用户在 laravel 8 中注册时,我如何将通知电子邮件发送到参考电子邮件
- proxy - 如何按百分比分配我的流量?
- c++ - 将 QML TypedArray 发送到 C++
- javascript - 通过删除负面的lookbehind使正则表达式Safari兼容
- django - 此处不允许使用目录索引。如何解决这个问题?