jjzjj

Multithreading

全部标签

javascript - increment 是 JavaScript 中的原子操作吗?

increment是JavaScript中的原子操作吗?如果一个线程正在访问++i;同时另一个开始访问运行会不会有什么问题? 最佳答案 在JavaScript中,函数总是运行到完成。这意味着如果一个函数正在运行,那么它将完全运行;只有在那之后,另一个函数才会被调用。因此,语句之间没有交错的机会(但在Java中则不同)。如果您对异步执行感到困惑,请始终记住async意味着以后不是并行的。所以,对于您的问题,答案是,不,您不会遇到任何问题,这将是一个完整的原子操作。 关于javascript

javascript - 多线程JavaScript怎么来的?

是否有在JavaScript中创建多线程应用程序的想法(库或方法)? 最佳答案 最接近的是网络worker(仅在FF3.5/HTML5中)。检查一下-http://www.whatwg.org/specs/web-workers/current-work/ 关于javascript-多线程JavaScript怎么来的?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/2145829

multithreading - 引用计数资源的线程安全映射

关闭。这个问题需要更多focused。它目前不接受答案。想要改进这个问题?更新问题,使其只关注editingthispost的一个问题。关闭5年前。Improvethisquestion关于管理资源集合:可通过全局列表(例如HashMap)按名称访问从多个线程同时访问引用计数(Golang缺少“弱引用”;参见https://groups.google.com/forum/#!topic/golang-nuts/PYWxjT2v6ps)例子:vartheListtMap//global//inthreadA,B,CetcaThing:=theList.ref("aThing")//ife

multithreading - 戈朗 : can WaitGroup leak with go-routines

我计划实现一个go-routine并有一个sync.WaitGroup同步创建的go-routine的结尾。我基本上使用go创建了一个线程.所以它是这样的:main(){varwgsync.WaitGroupfor{gomyThread(wg)wg.Add(1)}wg.wait()}myThread(wgsync.WaitGroup){deferwg.Done()}我之前曾与pthread_create合作过在某些情况下确实无法创建线程。在这种情况下,是否可能针对上述gomyThread(wg)无法启动和/或运行wg.Done()例程的其余部分是否正常运行?如果是这样,将报告什么以及如

multithreading - Go语言中线程的同步

我想更多地了解线程同步在go中的工作原理。下面是我的程序的一个功能版本,它使用完成channel进行同步。packagemainimport(."fmt""runtime")funcGoroutine1(i_chanchanint,donechanbool){forx:=0;x但是,当我尝试在没有任何同步的情况下运行它时。使用等待语句并且没有channel来指定何时完成,因此没有同步。constMAX=1000000funcGoroutine1(i_chanchanint){forx:=0;x它会打印出错误的i值。如果你延长等待时间,比如说1秒,它就会完成并打印出正确的语句。我有点理解

multithreading - slice 的并行性

我想让它根据线程数并行运行。但结果并不如我所料。我不知道如何使它高效和快速。我最终得到了这段代码。packagemainimport("fmt""io/ioutil""net/http""os""runtime""strconv""strings""sync""time")funcmain(){start:=time.Now()target:=os.Args[1]thread,_:=strconv.Atoi(os.Args[3])file,err:=ioutil.ReadFile(os.Args[2])iferr!=nil{fmt.Println("Error:Pleasedouble

multithreading - 为什么这段代码没有达到竞争条件?

我有这个go代码,它遍历目录文件树并生成其中每个文件的MD5哈希值,并将结果写入输出文件。packagemainimport("crypto/md5""encoding/hex""fmt""io""os""path/filepath""sync")funcmain(){filePath:=os.Args[1]output:=os.Args[2]wg:=&sync.WaitGroup{}err:=filepath.Walk(filePath,func(pathstring,infoos.FileInfo,errerror)error{if!info.IsDir(){wg.Add(1)go

multithreading - 基于 Go 的 http 包构建的 Web 应用程序是否作为使用多个线程处理传入请求的单个进程工作?

我读到Go应用程序使用内置Web服务器直接从客户端接收连接,而不是在Apache等Web服务器后面运行。此外,我还阅读了网络服务器(例如Apache)使用由fork()创建的多个进程处理传入请求的信息。对于Go应用程序也是如此,还是它在单个进程上运行并通过多个线程处理传入请求? 最佳答案 Go应用程序通常使用net/http包来实现Web服务器。documentationforthatpackage说:ServeacceptsincomingHTTPconnectionsonthelistenerl,creatinganewserv

java - 转到-我如何做类似Python或Java的线程?

我试着用go语言做线程,多任务。如何使用GO线程(如Python,Java)?例如:#!/usr/bin/pythonimportthreadingdeffunction1():print"B)LATER-iwasranasthread,todomultitasking"classserver(object):defrun(self):print"A)FIRST-iwasranasnormal"t1=threading.Thread(target=function1())t1.start()t1.join()if__name__=='__main__':t=server()t.run(

java - NodeJS 和 Go 语言的单线程比 Java 的多线程好在哪里?

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭7年前。Improvethisquestion我想比较NodeJS、Golang和Java。我搜索并发控制。结果是Java的并发控制是多线程,NodeJS和Golang的并发控制是单线程。所以,我想知道NodeJS和Go语言的单线程比Java的多线程好在哪里?谁能帮帮我?谢谢你的每一条评论。