草庐IT

线程占用

全部标签

Delphi TWebBrowser 中的 Javascript,关闭线程

我正尝试在Delphi中构建一个允许用户使用Googlemap的系统。一切正常,但我注意到每次创建新的TWebBrowser对象并加载处理Googlemap的javascript时,都会生成许多新线程。我的问题是,即使网络浏览器被销毁(并且肯定被销毁),创建的线程仍然存在。我正在设计这个程序,使其运行时间长,并且谷歌地图的打开和关闭发生多次,因此,一段时间后,生成了如此多的线程并且没有终止,以至于程序速度急剧下降。有什么方法可以自己销毁这些线程,还是我做错了什么导致线程持续存在?我的程序基于以下代码:constHTMLStr:AnsiString=''+''+''+''+''+''+'

Javascript/网络浏览器线程模型

如果我正在运行javascript代码,例如在计时器上执行某些操作,并且此代码嵌入在Web浏览器的选项卡1和选项卡2中的网页中,那么客户端代码可以同时运行吗?还是javascript客户端代码总是只在单个浏览器线程中运行?或者,如果有一个包含父框架和子框架的框架集,那么在这种情况下javascript代码可以并发运行吗?是否有标准指定模型或是否依赖于浏览器?我的主要目标环境是IE9,所以很想知道那里发生了什么。编辑我不是在寻找线程支持或如何在javascript中进行线程处理。我个人认为没有必要。这也让生活变得更加复杂。我只想知道我是否需要担心它,如果需要,在哪些浏览器上。

javascript - Web Workers - 他们创建实际的线程吗?

我一直认为webworkers创建单独的线程,但今天我在w3c网站上看到了规范。以下是关于网络worker的引文:Thisallowsforthread-likeoperationwithmessage-passingasthecoordinationmechanism.问题是-如果它是类线程,而不是实际的线程,那么使用该技术的优势(性能方面)是什么?任何帮助将不胜感激! 最佳答案 是的,网络worker创建实际的线程(或进程,规范对此很灵活)。根据WebWorkers规范,创建工作人员时的第一步是:Createaseparatep

javascript - 多线程JavaScript怎么来的?

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

C#高级--多线程详解

C#高级–多线程详解零、文章目录一、什么是多线程1、进程当一个程序开始运行时,它就是一个进程,进程包括运行中的程序和程序所使用到的内存和系统资源。而一个进程又是由多个线程所组成的。2、线程线程是程序中的一个执行流,每个线程都有自己的专有寄存器(栈指针、程序计数器等),但代码区是共享的,即不同的线程可以执行同样的函数。3、句柄句柄是Windows系统中对象或实例的标识,这些对象包括模块、应用程序实例、窗口、控制、位图、GDI对象、资源、文件等。4、多线程(1)多线程概念多线程是指程序中包含多个执行流,即在一个程序中可以同时运行多个不同的线程来执行不同的任务,也就是说允许单个程序创建多个并行执行的

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

go - append() 在原子/线程中是安全的吗?

阅读几个列表后,我想将每个列表中的所有行添加到一个大数组中。我在它自己的goroutine中运行每个列表阅读器。我可以在阅读后立即追加一行吗?这个线程是保存还是可以在我手中爆炸?typelistHolder{entries[]entry}func(h*listHolder)readAllLists(s[]list){c:=make(chanlist)varwgsync.WaitGroupfor_,l:=ranges{wg.Add(1)goh.readSomeList(&wg,l)}c.close()wg.Wait()}func(h*listHolder)readSomeList(wg*

Golang 可见性或 CPU 线程缓存问题

1)golang如何解决可见性问题?2)下面的代码有什么问题吗?packagemaintypeServicestruct{stopbool}func(s*Service)Run(){for!s.stop{//Somelogic}}func(s*Service)Stop(){s.stop=true}funcmain(){s:=&Service{}gos.Run()//Somelogics.Stop()} 最佳答案 我建议使用context.WithCancel在这种情况下停止goroutines。

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

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