- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我目前正在将我们的代码从 global sign 包迁移到 go mongo-driver,不确定我应该在哪里使用 context.TODO()
和 context.Background()
,这真的很令人困惑,我知道它都返回非零空,所以我应该在 main 函数和 init()
函数中使用 context.Background()
?并在其他地方使用 context.TODO()
?有人可以帮忙吗?
尝试检查我应该使用哪个参数 context.TODO()
或 context.Background()
。
最佳答案
检查他们的文档:
func Background() Context
Background returns a non-nil, empty Context. It is never canceled, has no values, and has no deadline. It is typically used by the main function, initialization, and tests, and as the top-level Context for incoming requests.
func TODO() Context
TODO returns a non-nil, empty Context. Code should use context.TODO when it's unclear which Context to use or it is not yet available (because the surrounding function has not yet been extended to accept a Context parameter).
根据文档,当您需要上下文但您(还)没有并且不知道使用什么时,请使用 context.TODO()
。这正是您的情况,正确使用 context.TODO()
记录。此外,静态分析工具和 IDE 可能会支持发现这些上下文,并在稍后向您发出警告以解决该问题。
另请注意,如果您在必须使用 mongo 驱动程序时确实有上下文,请考虑使用该上下文,或从中派生一个新上下文。
例如,如果您正在编写一个需要查询某些文档的 HTTP 处理程序,则 HTTP 请求 http.Request
已经有一个可以使用 Request.Context()
访问的上下文.当您调用需要上下文的其他 API 函数时,这是一个主要的候选者。
为什么,你可能会问?因为当 HTTP 客户端放弃/中止请求时请求的上下文被取消,这意味着无论你做什么,客户端都不会收到它,所以例如如果 HTTP 处理程序只是提供信息,你也可以中止生成它,节省一些资源。因此,如果在您执行 MongoDB 查询时请求上下文被取消,您也可以取消查询,因为您无论如何都不需要(不会处理)结果。取消传递给查询执行的上下文(例如 Collection.Find()
)是告诉 MongoDB 服务器尽可能取消查询的方法(因为您不需要结果)。
因此在这种情况下使用请求上下文可以在 HTTP 服务器和 MongoDB 服务器上为您节省一些 CPU 时间和内存。
另一个例子:假设您必须在 10 秒内生成 HTTP 响应(可能是平台限制),在此期间您必须执行 MongoDB 操作,并且必须对结果进行后处理,这需要 4 秒。在这种情况下,如果 MongoDB 操作花费的时间超过 6 秒,您将无法完成后处理以适应 10 秒的限制。因此,如果 MongoDB 操作未在 6 秒内完成,您不妨取消它。
解决这个问题的一个简单方法是派生一个超时为 6 秒的上下文:
ctx, cancel := context.WithTimeout(r.Context(), 6 * time.Second)
defer cancel()
// ctx automatically times out after 6 seconds
curs, err := c.Find(ctx, bson.M{"some": "filter"})
在这个例子中,ctx
将在 6 秒后超时,所以如果 c.Find()
操作没有完成,传递的 ctx
将发出可以取消的信号(在这种情况下将返回错误)。由于 ctx
派生自 r.Context()
,如果请求的上下文被提前取消(例如 HTTP 客户端中止),ctx
也会被取消。
现在假设您不是在编写 HTTP 处理程序,而是在编写一些其他代码(独立应用程序、后台工作程序等),您可能没有上下文,但您有自己的标准,不想再等了超过 30 秒的查询。这是一个主要示例,您可以使用 30 秒超时从 context.Background()
派生上下文:
ctx, cancel := context.WithTimeout(context.Background(), 30 * time.Second)
defer cancel()
// ctx automatically times out after 30 seconds
curs, err := c.Find(ctx, bson.M{"some": "filter"})
如果查询在 30 秒内完成,一切都很好,您可以使用结果。否则,上下文将在 30 秒后取消,因此 c.Find()
也(可能)返回错误。
关于go - context.TODO() 或 context.Background(),我更喜欢哪一个?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/74239074/
我是 os 2 的新手,所以真的不知道从哪里开始。是否可以编写一个 WatchOs 2 应用程序,它将在后台运行并每小时唤醒一次?网上没有那么多可用的信息,但到目前为止我所看到的表明不可能编写后台应用
如何将 url 背景图像添加到渐变中并具体定位?因为梯度本身被当作图像 CSS background: linear-gradient(to bottom, #98cb01 2%,#60a822 10
我是 android 开发的新手,正在开发我的第一个 android 应用程序。我在布局的 xml 中设置了 View 的背景颜色,如下所示。 android:background="@+color/
为了尽可能简洁地使用样式,如果使用双像素密度设备(例如 iPhone 4)查看我的页面,我宁愿不使用包含的媒体查询样式表。 话虽如此,如果我只是做这样的事情就可以了吗? .icon-1 { bac
我有一个由 62 张 91 * 91 像素的图像组成的 Sprite ,这使得整个图像为 91 * 5642 像素。它们以动态网格的形式显示,该网格会根据用户/指针的移动而增长和缩小。有时,一个元素(
我一直在尝试制作一款使用 Xbox One Kinect (V2) 的 Unity 游戏。 我遵循了本教程中的说明: http://www.imaginativeuniversal.com/blog/
看来firefox会自动组合一些东西,例如它需要单独的css值,例如“border-color”,“border-width”并将它们全部转储到“border”中..这使jquery变得很痛苦因为 .
我正在构建我的第一个 Chrome 扩展程序。我浏览了 Chrome 开发人员文档,但我无法理解几个主题。 我的理解: 有两个 Action : 浏览器操作(地址栏外的按钮) 页面操作(地址栏内的按钮
我的后台监听器是 chrome.runtime.onMessage.addListener(function (request, sender, sendResponse) 在chrome.conte
哪个更有效: 我正在尝试找出哪种提供半透明背景的方法更有效/更快: background-color: rgba(255, 255, 255, .12); 或者 background-image: u
我想要一个有 tr 作为黑色背景的表格,里面有一个白色背景的表格。
我在我的主页上放了一个背景。它可以在除 android chrome 之外的所有浏览器上正确显示。这是我的 CSS: body.path-frontpage { background-imag
我正在尝试对我的背景图像应用滤镜,但是我遇到了 CSS 属性 URL 和线性渐变的问题。我想要的背景图片 .bg-image-full { background: no-repeat center
在样式部分的 chrome 中使用谷歌开发者控制台时,它会立即为我提供“在我键入时”的背景颜色属性。几个月前,它一直在提供我更喜欢的一般属性(property)“背景”。 是否有机会自定义这些提示,或
我正在尝试实现 faux column网站上的布局。简而言之,它涉及在包含两个垂直列的 div 上平铺背景图像,使其看起来像两个列一直延伸到底部。 我的专栏如下所示: XXXX MMMM XXXX
这是一个 example .我想裁剪背景图像,然后将裁剪图像用作更大(尺寸)元素的背景。我的意思是 div 比它的背景大,我不需要重复。现在,当 background-repeat 取消注释时,元素消
CSS3 声明 background-clip 和 background-origin 似乎对背景有相同的效果。它们似乎都将背景限制在相对于 HTML 元素的某个区域,所以我想知道这两个声明在功能上是
我正在为图片库制作缩略图页面。缩略图预览作为 完成 float 具有固定的方形尺寸。 然而,缩略图本身不一定是正方形或相同大小,它们具有它们所代表的大图像的属性。 为了让它看起来不错,我想在正方形中
这个问题在这里已经有了答案: Get a CSS value with JavaScript (8 个答案) 关闭 6 年前。
你好, 就像我在标题中所说的 background-image:none; 不起作用,因为使用 css3 background-image:url('...'); 返回一个新层每次文件都是新的。我正在
我是一名优秀的程序员,十分优秀!