- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
The
GOMAXPROCS
variable limits the number of operating system threads that can execute user-level Go code simultaneously.
因此,如果 GOMAXPROCS
为 1,无论我有多少个 goroutine,都可以安全地从不同的 goroutine 访问变量(如 map
)而无需任何锁定。正确吗?
最佳答案
简短的回答是,“不”它不安全。冗长的答案确实太长,无法在此处进行足够详细的解释,但我将提供一个简短的摘要和一些文章链接,这些文章应该可以帮助您将各个部分放在一起。
让我们先区分“并发”和“并行”。考虑两个函数。并行运行,它们可以同时在不同的处理器上执行。同时运行其中一个,或两者同时运行,或者两者都可能正在执行,但两者都能够执行。如果它们是并发的但不是并行的,那么它们正在切换——如果没有 channel 或锁,我们无法保证先到先得的顺序。
“并发而不并行”想想可能很奇怪,但反之想想就很不起眼,并行但不并发;我的文本编辑器、终端和浏览器都在并行运行,但绝对不是并发的。
因此,如果两个(或 20,000 个)函数可以访问同一内存,比如说一个写入一个读取,并且它们同时运行,那么写入可能先发生,读取可能先发生。除非我们负责调度/排序,因此没有锁和 channel ,否则没有任何保证。
将 GOMAXSPROCS 设置为大于 1 可以使并发程序并行运行,但也可能不是,所有 concurrent goroutines 可能在一个 CPU 线程上,也可能在多个 CPU 线程上。因此,将 GOMAXPROCS 设置为 1 并不能保证并发进程在没有锁或 channel 来协调其执行的情况下是安全的。
线程[通常]由操作系统调度。参见 Wikipedia或者你最喜欢的人类知识库。 Goroutines 由 Go 调度。
接下来考虑这个:
Even with [a] single logical processor and operating system thread, hundreds of thousands of goroutines can be scheduled to run concurrently with amazing efficiency and performance.
还有这个:
The problem with building concurrency into our applications is eventually our goroutines are going to attempt to access the same resources, possibly at the same time. Read and write operations against a shared resource must always be atomic. In other words reads and writes must happen by one goroutine at a time or else we create race conditions in our programs.
来自 this article ,它很好地解释了差异并引用了一些您可能想要查找的其他 Material (该文章有些过时,因为 GMAXPROCS 不再默认为 1,但一般理论仍然准确)。
最后,Effective Go 刚开始时可能会令人望而生畏,但却是一本必读的书。 Here是Go中并发的解释。
关于go - 当 GOMAXPROCS 为 1 时是否需要加锁,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37391009/
我正在尝试用 C 语言编写一个使用 gstreamer 的 GTK+ 应用程序。 GTK+ 需要 gtk_main() 来执行。 gstreamer 需要 g_main_loop_run() 来执行。
我已经使用 apt-get 安装了 opencv。我得到了以下版本的opencv2,它工作正常: rover@rover_pi:/usr/lib/arm-linux-gnueabihf $ pytho
我有一个看起来像这样的 View 层次结构(基于其他答案和 Apple 的使用 UIScrollView 的高级 AutoLayout 指南): ScrollView 所需的2 个步骤是: 为 Scr
我尝试安装 udev。 udev 在 ./configure 期间给我一个错误 --exists: command not found configure: error: pkg-config and
我正在使用 SQLite 3。我有一个表,forums,有 150 行,还有一个表,posts,有大约 440 万行。每个帖子都属于一个论坛。 我想从每个论坛中选择最新帖子的时间戳。如果我使用 SEL
使用 go 和以下包: github.com/julienschmidt/httprouter github.com/shwoodard/jsonapi gopkg.in/mgo.v2/bson
The database仅包含 2 个表: 钱包(100 万行) 事务(1500 万行) CockroachDB 19.2.6 在 3 台 Ubuntu 机器上运行 每个 2vCPU 每个 8GB R
我很难理解为什么在下面的代码中直接调用 std::swap() 会导致编译错误,而使用 std::iter_swap 编译却没有任何错误. 来自 iter_swap() versus swap() -
我有一个非常简单的 SELECT *用 WHERE NOT EXISTS 查询条款。 SELECT * FROM "BMAN_TP3"."TT_SPLDR_55E63A28_59358" SELECT
我试图按部分组织我的 .css 文件,我需要从任何文件访问文件组中的任何类。在 Less 中,我可以毫无问题地创建一个包含所有文件导入的主文件,并且每个文件都导入主文件,但在 Sass 中,我收到一个
Microsoft.AspNet.SignalR.Redis 和 StackExchange.Redis.Extensions.Core 在同一个项目中使用。前者需要StackExchange.Red
这个问题在这里已经有了答案: Updating from Rails 4.0 to 4.1 gives sass-rails railties version conflicts (4 个答案) 关
我们有一些使用 Azure DevOps 发布管道部署到的现场服务器。我们已经使用这些发布管道几个月了,没有出现任何问题。今天,我们在下载该项目的工件时开始出现身份验证错误。 部署组中的节点显示在线,
Tip: instead of creating indexes here, run queries in your code – if you're missing any indexes, you
你能解释一下 Elm 下一个声明中的意思吗? (=>) = (,) 我在 Elm architecture tutorial 的例子中找到了它 最佳答案 这是中缀符号。实际上,这定义了一个函数 (=>
我需要一个 .NET 程序集查看器,它可以显示低级详细信息,例如元数据表内容等。 最佳答案 ildasm 是 IL 反汇编程序,具有低级托管元数据 token 信息。安装 Visual Studio
我有两个列表要在 Excel 中进行比较。这是一个很长的列表,我需要一个 excel 函数或 vba 代码来执行此操作。我已经没有想法了,因此转向你: **Old List** A
Closed. This question does not meet Stack Overflow guidelines。它当前不接受答案。 想要改善这个问题吗?更新问题,以便将其作为on-topi
我正在学习 xml 和 xml 处理。我无法很好地理解命名空间的存在。 我了解到命名空间帮助我们在 xml 中分离相同命名的元素。我们不能通过具有相同名称的属性来区分元素吗?为什么命名空间很重要或需要
我搜索了 Azure 文档、各种社区论坛和 google,但没有找到关于需要在公司防火墙上打开哪些端口以允许 Azure 所有组件(blob、sql、compute、bus、publish)的简洁声明
我是一名优秀的程序员,十分优秀!