草庐IT

set_thread_area

全部标签

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 - 使用 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 - Windows下Maven安装 : "JAVA_HOME is set to an invalid directory"

这个问题在这里已经有了答案:UnabletoinstallMavenonWindows:"JAVA_HOMEissettoaninvaliddirectory"(16个答案)关闭8年前。我是Maven的新手,我已经下载了3.0.5版本。我收到以下错误:JAVA_HOMEissettoaninvaliddirectory.pleasesetthejava_homevariableinyourenvironmentvariabletomatchthelocationofyourjavainstallation不过,当我在命令提示符下键入javac或echo%M2_HOME%时,我没有看到任

java - 总是使用 get 和 set 方法来访问类自己的成员字段是否属于反模式?

这个问题在这里已经有了答案:Usinggetterswithinclassmethods(6个答案)关闭9年前。在Java类中,使用getter和setter访问成员字段被认为是好习惯还是坏习惯?例如哪个更好:publicOrder{privateAgreementagreement;publicAgreementgetAgreement(){returnagreement;}publicvoidprocess(){//shouldIuse:getAgreement().doSomething();//Or:agreement.doSomething();}}一般来说,由于KISS原则

java - String get/set 是线程安全的吗?

假设我有以下内容,publicclassFoo{privateStringbar;publicStringgetBar(){returnbar;}publicvoidsetBar(Stringbar){this.bar=bar;}}由于String类的不可变特性,这些方法是否自动线程安全,或者是否需要某种锁定机制? 最佳答案 不,这不是线程安全的。Foo是可变的,所以如果你想确保不同的线程看到相同的值bar–即一致性–或者:制作barvolatile,或制作方法synchronized,或使用AtomicReference.bar的

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