草庐IT

thread_safe

全部标签

java - Thread.join() 是否释放锁?还是继续持有?

据我了解,内部obj.join()调用wait()。这意味着join()总是释放锁(因为wait()总是在被调用后释放锁)。API文档explains:Thisimplementationusesaloopofthis.waitcallsconditionedonthis.isAlive.Asathreadterminatesthethis.notifyAllmethodisinvoked.Itisrecommendedthatapplicationsnotusewait,notify,ornotifyAllonThreadinstances.人hereonSO假设join()没有释放

猫头虎分享已解决Bug | Java Error: Exception in thread ‘main‘ java.lang.NullPointerException

博主猫头虎的技术世界🌟欢迎来到猫头虎的博客—探索技术的无限可能!专栏链接:🔗精选专栏:《面试题大全》—面试准备的宝典!《IDEA开发秘籍》—提升你的IDEA技能!《100天精通鸿蒙》—从Web/安卓到鸿蒙大师!《100天精通Golang(基础入门篇)》—踏入Go语言世界的第一步!《100天精通Go语言(精品VIP版)》—踏入Go语言世界的第二步!领域矩阵:🌐猫头虎技术领域矩阵:深入探索各技术领域,发现知识的交汇点。了解更多,请访问:猫头虎技术矩阵新矩阵备用链接文章目录猫头虎分享已解决Bug🐾|JavaError:Exceptioninthread'main'java.lang.NullPoin

java - 在 Java 中,对空闲线程使用 Thread.sleep(1) 是否有效?

我的线程中有一个主循环,其中一部分测试空闲boolean值是否为真。如果是,它将在每次循环迭代时调用Thread.sleep(1)。这是一种有效的方法吗?我的目标是让线程在空闲时占用最少的CPU。 最佳答案 没有。使用Object.wait相反,并确保您在包含boolean值的对象上同步。如果您不同步并且boolean不是volatile,您就没有内存屏障,因此无法保证轮询线程会看到对的更改boolean值。根据javadoc:Thismethodcausesthecurrentthread(callitT)toplaceitsel

java - "VM Periodic Task Thread"是什么?

我可以在我的线程转储中看到这个线程:"VMPeriodicTaskThread"prio=10tid=0x00007fc23000e800nid=0x49e6waitingoncondition这是什么? 最佳答案 查看最新的OpenJDK源代码,这是C++级别的线程,它在没有native定时器中断的系统上执行许多任务。它似乎主要用于采样/分析JVM正在做什么。 关于java-"VMPeriodicTaskThread"是什么?,我们在StackOverflow上找到一个类似的问题:

JavaFX : Use a Thread more than once

我是JavaFX的新手,线程有点问题:我可以执行它两次,但找不到原因。这是我的代码的总结:Tasktask=newTask(){@OverridepublicVoidcall()throwsImageLoadedException,HomographyException,IOException{try{System.out.println("GO!");returnnull;}catch(Exceptione){e.printStackTrace();}returnnull;}@Overrideprotectedvoidsucceeded(){super.succeeded();Sys

Java 并发数 : executing many "infinite" tasks with few threads

我正在为一组根据牛顿定律在空间中移动的N个粒子构建一个(并发)模拟器。我的想法是将每个粒子建模为一个任务,它与其他粒子(任务)相互作用以获得它们的位置和质量,从而计算它所受到的合力。每个粒子任务都是while(true){force=thisParticle.calculateNetForce(allTheParticles);thisParticle.waitForAllTheParticlesToCalculateNetForce();//synchronizationthisParticle.updatePosition(force);thisParticle.waitForAl

Java-Thread 与 Runnable

这个问题在这里已经有了答案:"implementsRunnable"vs"extendsThread"inJava(43个回答)关闭8年前。在阅读here中Thread和Runnable之间的显着差异时,我遇到的区别是:当您扩展Thread类时,您的每个线程都会创建唯一的对象并与之关联。当您实现Runnable时,它​​与多个线程共享同一个对象。。有代码给:classImplementsRunnableimplementsRunnable{privateintcounter=0;publicvoidrun(){counter++;System.out.println("Implemen

Java 并行流 : how to wait for threads for a parallel stream to finish?

所以我有一个列表,我从中获取并行流来填充map,如下所示:Mapmap=newHashMap();Listlist=some_filled_list;//Puttingdatafromthelistintothemaplist.parallelStream().forEach(d->{TreeNodenode=newTreeNode(d);map.put(node.getId(),node);});//printoutmapmap.entrySet().stream().forEach(entry->{System.out.println("ProcessingnodewithID="

java - HashMap 顺序在使用 Thread 时发生变化,但在没有 Thread 时保持不变

我知道HashMap不保证顺序。考虑以下代码:importjava.util.HashMap;importjava.util.Map;publicclassSandBox{protectedstaticclassBook{Stringname;publicBook(Stringname){this.name=name;}@OverridepublicStringtoString(){returnname;}}protectedstaticclassMyThreadextendsThread{@Overridepublicvoidrun(){super.run();finalintn=1

java - 为什么 java 安全管理器既不禁止创建 new Thread() 也不禁止启动它?

您知道为什么Java安全管理器不禁止创建或启动新线程的解释吗?newFileWriter在安全管理器下,但newThread()和threadInstance.start()都不是在安全管理器下,可以调用。禁止它不是很有用吗?会不会很难实现?或者创建和启动新线程与禁止它无关紧要? 最佳答案 无法定义安全策略来阻止代码使用标准JavaSecurityManager创建和启动新线程。假设您有以下代码:publicclassTest{publicstaticvoidmain(String[]args){System.out.println