草庐IT

Multithreading

全部标签

java - tomcat 6线程池异步处理

简短的问题:在Tomcat6应用程序中-我如何运行(单独的)线程池?运行线程池的最佳解决方案是什么?长问题:我这里有一个简单的需求;轮询数据库以获取某些数据,同时允许Web客户端等待答案(长轮询连接)。当该数据在数据库中可用时,我会向相关客户发送回复。话虽如此,我宁愿目前不深入研究任何框架(quartzscheduler也许吧?)。因此,正如我得出的结论,我需要一个线程池来在后台完成这项工作。那么如果我要使用Thread(实际上是Runnable),哪个类可以组织这一切?有排序吗ThreadPool解决方案?有什么推荐吗? 最佳答案

java - 如何将参数传递给java中已经运行的线程?

如何在java中将参数传递给已经运行的线程——而不是在构造函数中,并且可能不使用wait()(可能??)类似于HowcanIpassaparametertoaJavaThread?中的评论Doyoumeanpassingaparametertoanalreadyrunningthread?Becauseallthecurrentanswersareaboutpassingparameterstonewthreads...–ValentinRocherMay18'09at10:43[编辑]是的,我一直在寻找类似于生产者/消费者模式的东西。我想要一个类似线程的东西,其中有处理并准备就绪用于

java - Spring单例线程安全

如果我在下面定义了一个Java类,它通过依赖注入(inject)注入(inject)到我的Web应用程序中:publicAccountDao{privateNamedParameterJdbcTemplatenjt;privateListaccounts;publicAccountDao(Datasourceds){this.njt=newNamedParameterJdbcTemplate(ds);refreshAccounts();}/*calledatcreation,andthenviaAPIcallstoinformservicenewusershavebeenaddedto

java - 什么原语用于实现 synchronized 关键字?

当我们在java中使用synchronized关键字时,到底使用了哪个同步原语?锁、信号量、监视器、互斥量?编辑:JVM如何在native级别实现锁? 最佳答案 在字节码级别,java有monitorenter和monitorexit操作,记录在thispageofTheJavaVirtualMachineSpecification,下面粘贴了片段(objectref是操作的操作数,取自堆栈):monitorenter片段Eachobjecthasamonitorassociatedwithit.Thethreadthatexecu

java - Java 中的哈希表和同步

我读到哈希表是线程安全的,因为它是同步的。考虑这个代码片段if(!hashtable.contains(key)){hashtable.put(key,value);}哈希表的操作可能不同步。例如,如果Threadt1访问hastable并检查key,同时Threadt2在t1执行put之前检查key。现在有两个线程在ifblock内并且发生键值覆盖。所以同步块(synchronizedblock)是必要的。synchronized{if(!hashtable.contains(key)){hashtable.put(key,value);}}这个理解对吗?或hastables对在ha

java - 如何正确关闭java ExecutorService

我有一个简单的javaExecutorService运行一些任务对象(实现Callable)。ExecutorServiceexec=Executors.newSingleThreadExecutor();Listtasks=newArrayList();//...createsometasksfor(CallableTasktask:tasks){Futurefuture=exec.submit(task);result=(String)future.get(timeout,TimeUnit.SECONDS);//TASKSloadsomeclassesandinvoketheirm

java - 每个请求模型的线程能否比非阻塞 I/O 更快?

我记得2或3年前读过几篇文章,其中人们声称现代线程库变得如此出色以至于每个请求线程服务器不仅比非阻塞服务器更容易编写,而且它们会也更快。我相信这甚至在Java中通过将Java线程映射到pthread的JVM进行了演示(即Javanio开销超过了上下文切换开销)。但现在我看到所有“尖端”服务器都使用异步库(Javanio、epoll,甚至node.js)。这是否意味着异步赢了? 最佳答案 我认为不是。如果两种模型都得到很好的实现(这是一个很大的要求),我认为NIO的概念应该占上风。计算机的核心是内核。无论您做什么,您都无法将应用程序并

java - 如何实现多个 'threads'只在一个线程中运行

最近我一直在想:他们如何在一个线程中实现多个“线程”?我的意思是,他们如何在一个线程中实现多段并行运行的代码?他们如何保存“线程”的状态、创建中断并将CPU传递给下一个线程?我认为ScalaActor实现了这一点。但是如何呢?这个对于JVM或者C都可以回答,没关系。我真的很想了解它的理论。 最佳答案 我觉得你很困惑coroutines和greenthreads在这里。协程在准备执行时放弃控制,没有任何中断,所以中断的问题在这里无关紧要。Scala参与者作为协程实现。绿色线程是虚拟机在不使用native操作系统功能的情况下实现的用户模

java - 如何在 setter 在 Java 中工作时同步 getter

我有一个多线程应用程序,它使用一个提供列表的静态类。我希望静态类的getter可以自由工作(不相互同步)但是当setter工作时我希望所有getter都被锁定并等待setter的工作完成。我不想在一起调用setter/getter时锁定setter/getter,因为这会大大降低性能。Getter每天被调用1,000,000次,而setter每天只应该工作一次。 最佳答案 考虑使用java.util.concurrent.locks.ReadWriteLock实现,例如ReentrantReadWriteLock(参见javadoc

允许多个线程同时读取或一个修改的Java类

假设您有以下类(class):classA{privateFoofoo=newFoo();FoogetFoo(){returnfoo;//foo.clone()?}voidmodifyFoo(){//modifythis.foo//...}}我想允许:多个线程调用getFoo()或一个线程调用modifyFoo(),一旦一个线程想要修改foo,在修改完成之前,不会执行其他新的getFoo()调用,直到修改完成。在Java中是否已经有针对这个问题的类,或者我是否必须实现它?如果一定要实现,那么如何实现才能保证线程安全? 最佳答案 听起