The
GOMAXPROCSvariable 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/
当我使用Bundler时,是否需要在我的Gemfile中将其列为依赖项?毕竟,我的代码中有些地方需要它。例如,当我进行Bundler设置时:require"bundler/setup" 最佳答案 没有。您可以尝试,但首先您必须用鞋带将自己抬离地面。 关于ruby-我需要将Bundler本身添加到Gemfile中吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/4758609/
给定这段代码defcreate@upgrades=User.update_all(["role=?","upgraded"],:id=>params[:upgrade])redirect_toadmin_upgrades_path,:notice=>"Successfullyupgradeduser."end我如何在该操作中实际验证它们是否已保存或未重定向到适当的页面和消息? 最佳答案 在Rails3中,update_all不返回任何有意义的信息,除了已更新的记录数(这可能取决于您的DBMS是否返回该信息)。http://ar.ru
这个问题在这里已经有了答案:Checktoseeifanarrayisalreadysorted?(8个答案)关闭9年前。我只是想知道是否有办法检查数组是否在增加?这是我的解决方案,但我正在寻找更漂亮的方法:n=-1@arr.flatten.each{|e|returnfalseife
我注意到像bundler这样的项目在每个specfile中执行requirespec_helper我还注意到rspec使用选项--require,它允许您在引导rspec时要求一个文件。您还可以将其添加到.rspec文件中,因此只要您运行不带参数的rspec就会添加它。使用上述方法有什么缺点可以解释为什么像bundler这样的项目选择在每个规范文件中都需要spec_helper吗? 最佳答案 我不在Bundler上工作,所以我不能直接谈论他们的做法。并非所有项目都checkin.rspec文件。原因是这个文件,通常按照当前的惯例,只
我实际上是在尝试使用RVM在我的OSX10.7.5上更新ruby,并在输入以下命令后:rvminstallruby我得到了以下回复:Searchingforbinaryrubies,thismighttakesometime.Checkingrequirementsforosx.Installingrequirementsforosx.Updatingsystem.......Errorrunning'requirements_osx_brew_update_systemruby-2.0.0-p247',pleaseread/Users/username/.rvm/log/138121
我有一个包含多个键的散列和一个字符串,该字符串不包含散列中的任何键或包含一个键。h={"k1"=>"v1","k2"=>"v2","k3"=>"v3"}s="thisisanexamplestringthatmightoccurwithakeysomewhereinthestringk1(withspecialcharacterslike(^&*$#@!^&&*))"检查s是否包含h中的任何键的最佳方法是什么,如果包含,则返回它包含的键的值?例如,对于上面的h和s的例子,输出应该是v1。编辑:只有字符串是用户定义的。哈希将始终相同。 最佳答案
我需要检查DateTime是否采用有效的ISO8601格式。喜欢:#iso8601?我检查了ruby是否有特定方法,但没有找到。目前我正在使用date.iso8601==date来检查这个。有什么好的方法吗?编辑解释我的环境,并改变问题的范围。因此,我的项目将使用jsapiFullCalendar,这就是我需要iso8601字符串格式的原因。我想知道更好或正确的方法是什么,以正确的格式将日期保存在数据库中,或者让ActiveRecord完成它们的工作并在我需要时间信息时对其进行操作。 最佳答案 我不太明白你的问题。我假设您想检查
我的日期格式如下:"%d-%m-%Y"(例如,今天的日期为07-09-2015),我想看看是不是在过去的七天内。谁能推荐一种方法? 最佳答案 你可以这样做:require"date"Date.today-7 关于ruby-检查日期是否在过去7天内,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/32438063/
这里有一个很好的答案解释了如何在Ruby中下载文件而不将其加载到内存中:https://stackoverflow.com/a/29743394/4852737require'open-uri'download=open('http://example.com/image.png')IO.copy_stream(download,'~/image.png')我如何验证下载文件的IO.copy_stream调用是否真的成功——这意味着下载的文件与我打算下载的文件完全相同,而不是下载一半的损坏文件?documentation说IO.copy_stream返回它复制的字节数,但是当我还没有下
我们的git存储库中目前有一个Gemfile。但是,有一个gem我只在我的环境中本地使用(我的团队不使用它)。为了使用它,我必须将它添加到我们的Gemfile中,但每次我checkout到我们的master/dev主分支时,由于与跟踪的gemfile冲突,我必须删除它。我想要的是类似Gemfile.local的东西,它将继承从Gemfile导入的gems,但也允许在那里导入新的gems以供使用只有我的机器。此文件将在.gitignore中被忽略。这可能吗? 最佳答案 设置BUNDLE_GEMFILE环境变量:BUNDLE_GEMFI