草庐IT

【JavaEE】进程和线程

全部标签

multithreading - Go语言中线程的同步

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

go - Golang 应用程序的类似 PM2 的进程管理解决方案?

Go是否有类似PM2forNodeJS的进程管理器?PM2的基本特征:无限期地在后台运行应用程序,例如等待请求的服务器。重启后重启应用。编者注:PM2提供了一种在后台永远运行NodeJS应用程序的简单方法,例如用于生产服务器。当然,您可以使用Linux操作系统,使用不特定于任何特定编程语言的工具来做到这一点,这些答案很有帮助。由于Go可以创建可执行文件,因此您实际上不需要Go语言特定的解决方案来解决这个问题。 最佳答案 开发环境对于开发,您可能需要进程管理器来监视文件更改并实时重新加载您的服务器二进制文件。我习惯了Godeganst

go - 为什么fasthttp像单进程?

requestHandler:=func(ctx*fasthttp.RequestCtx){time.Sleep(time.Second*time.Duration(10))fmt.Fprintf(ctx,"Hello,world!Requestedpathis%q",ctx.Path())}s:=&fasthttp.Server{Handler:requestHandler}iferr:=s.ListenAndServe("127.0.0.1:82");err!=nil{log.Fatalf("errorinListenAndServe:%s",err)}多个请求,耗时X*10s。f

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

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

file - 为什么我的 Go 程序使用打开文件的名称创建另一个 Go 进程,为什么它这么大?

我有一个大约2mb的大.json文件。我正在使用thiscode读取json,稍作修改:funcmain(){pages:=getPages()for{}for_,p:=rangepages{fmt.Println(p.toString())}如您所见,我设置了一个无限循环,这样我就可以让程序在读取进程的RAM大小时等待。当我去阅读它时,我发现有2个go程序在运行。我刚刚做了去运行myfile.go但后来我得到了2个二进制文件:一个名为go,另一个是文件名,没有json部分。go二进制文件大约有5mb,但是这个有36mb...为什么go使用文件名创建另一个进程?它是保存文件的地方以便我

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的多线程好在哪里?谁能帮帮我?谢谢你的每一条评论。

go - 即使进程结束也缓存或保留一个值

在GoLang中编写CLI应用程序并希望在不同的session/命令中使用URL。通过Cobra实现CLI,我想在开始时配置URL,然后在其他命令中继续使用它。尝试使用以下方法-os.Setenv("URL",URL)os.Getenv("URL")以上方法仅适用于同一进程(如果set和get进程不同则无效)。知道我们该怎么做吗?更新:我想知道是否可以在Go中完成?我知道这可以通过将其存储在文件/数据库中或者甚至在环境变量中设置来轻松完成,但探索在Go中完成它的方法。 最佳答案 您可以建立一个简单的监听器,为其他进程提供服务请求。它

go - 将 Goroutine 分离为独立进程

我有一个播放声音的函数,我想在我的main程序打印到标准输出并退出后继续执行。我的理由是我希望声音在程序退出后结束播放,但我不希望main程序在退出之前等待声音结束播放。我找到了一种在独立进程中执行声音的方法,方法是将其转换为名为playsound的可执行文件并执行goinstall。然后在我的主程序中,我在main()的末尾调用它:funcstartPlaySound(){cmd:=exec.Command("playsound")cmd.Start()}main(){//codethatprintsandexitsstartPlaySound()}这可行,但我希望能够在主程序退出后

multithreading - go指针多线程读写错误

正常应该是恒定输出test1test2........但是只有test1输出,程序挂了,没有任何反应指针的赋值是最基本的操作,这个应该是线程安全的,满足句号但是这个测试没能typePointstruct{XintYint}funcmain(){varp*Point=niltest:=truegofunc(){fortest{iftmp:=p;tmp==nil{p=&Point{}}}}()gofunc(){fortest{iftmp:=p;tmp!=nil{p=nil}}}()n:=0fortest{n++fmt.Printf("testing%v....\r\n",n)time.Sl