草庐IT

threaded_comments

全部标签

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

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

java - Future.get() 是 Thread.join() 的替代品吗?

我想编写一个永远运行的命令行守护进程。我知道如果我希望JVM能够在linux中正常关闭,则需要通过一些C代码包装Bootstrap。我想我现在可以使用关闭Hook。关于我的问题:我的main(String[])block将启动一个单独的Superdaemon。Superdaemon将永远轮询和循环。所以通常我会这样做:classSuperdaemonextendsThread{...}classBootstrap{publicstaticvoidmain(String[]args){Threadt=newSuperdaemon();t.start();t.join();}}现在我想如果

java.lang.IllegalStateException : Not on FX application thread; currentThread = Thread-4 错误

我正在尝试从Thread设置Text对象的字符串,但它给了我这个错误:Exceptioninthread"Thread-4"java.lang.IllegalStateException:NotonFXapplicationthread;currentThread=Thread-4atcom.sun.javafx.tk.Toolkit.checkFxUserThread(UnknownSource)atcom.sun.javafx.tk.quantum.QuantumToolkit.checkFxUserThread(UnknownSource)atjavafx.scene.Scene

java - 为什么使用 Thread.currentThread().isInterrupted() 而不是 isInterrupted()?

我对Thread子类取消政策的实现有疑问。这样做似乎是常见的做法:classAextendsThread{[...]publicfinalvoidrun(){try{while(!Thread.currentThread().isInterrupted()){[...]}}catch(InterruptedExceptionconsumed){}}publicfinalvoidcancel(){interrupt();}}我的问题是关于Thread.currentThread()...为什么通常的做法是使用currentThread()来检查中断标志而不是在cancel()方法中设置它

java - Sonar 、Java 和 'trailing comment' 违规

在我的一个项目上运行Sonar后,我收到了“尾随评论”的违规通知。所以我想知道,这是否纯粹与Java接受/推荐的代码布局约定有关,还是“更多”?其背后的原因是什么?当我查看一些C++代码(最近的Doomcodereview时,有大量(或充满Binder的)尾随注释。 最佳答案 来自名著代码大全:Thecommentshavetobealignedsothattheydonotinterferewiththevisualstructureofthecode.Ifyoudon'talignthemneatly,they'llmakeyo

java - 使用 Thread.sleep 进行测试

使用Thread.sleep()加速测试的推荐方法是什么。我正在测试一个具有重试功能的网络库,当连接断开或发生超时错误等时。然而,该库在重试之间使用了Thread.sleep()(因此它不会服务器重新启动时t连接数千次)。该调用显着减慢了单元测试速度,我想知道有哪些选项可以覆盖它。请注意,我愿意实际更改代码,或使用模拟框架来模拟Thread.sleep(),但我想先听听您的意见/建议。 最佳答案 将与时间相关的功能委托(delegate)给单独的组件通常是个好主意。这包括获取当前时间,以及像Thread.sleep()这样的延迟。这

并发编程Thread的常用API有哪些?

引言在JDK17(或以上版本)中,Thread类提供了一组常用的API,用于管理线程的创建、启动、暂停、恢复和销毁等操作。本文从api、源码、编程示例等方面详细说明Thread常用函数的使用和注意事项。线程sleep使当前正在执行的线程暂停(挂起)指定的毫秒数。但受系统计时器和调度程序的精度和准确性限制。线程不会失去任何monitor(监视器)的所有权。每个线程的休眠互不影响,Thread.sleep只会导致当前线程进入指定时间的休眠。publicstaticnativevoidsleep(longmillis)throwsInterruptedException;publicstaticvo

java - Java 中的 Thread.yield() 和 Thread.sleep(0) 有什么区别?

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:AreThread.sleep(0)andThread.yield()statementsequivalent?在我的理解中,Thread.yield()和Thread.sleep(0)都应该通过某种调度算法让CPU重新判断运行哪个线程。区别在于:Thread.yield()是给其他线程执行的机会,而Thread.sleep(0)不会,它只是告诉CPU你应该重新安排执行线程,包括当前线程本身。Thread.yield()只是一个建议,这意味着它可能根本不会被接受,但Thread.sleep(0)会强制进行重新

java - java写并行算法时 "serial thread-confinement"是什么意思?

阅读Java8Spliterator的文档时我遇到了“串行线程限制”的概念。准确地说,文档说:Despitetheirobviousutilityinparallelalgorithms,spliteratorsarenotexpectedtobethread-safe;instead,implementationsofparallelalgorithmsusingspliteratorsshouldensurethatthespliteratorisonlyusedbyonethreadatatime.Thisisgenerallyeasytoattainviaserialthrea

java - Thread.isInterrupted() 在线程终止后返回 false

考虑以下JUnit测试:@TestpublicvoidtestSettingInterruptFlag()throwsInterruptedException{ThreadblockingThread=newThread(newRunnable(){@Overridepublicsynchronizedvoidrun(){try{wait();}catch(InterruptedExceptione){Thread.currentThread().interrupt();}}});blockingThread.start();blockingThread.interrupt();blo