草庐IT

THREAD_NAME

全部标签

java - Thread.isInterrupted 不起作用,Thread.interrupted 起作用

下面的程序演示了这个问题(最新的JVM等等):publicstaticvoidmain(String[]args)throwsInterruptedException{//ifthisistrue,bothinterruptedandisInterruptedworkfinalbooleanwithPrint=false;//decidewhethertouseisInterruptedorinterrupted.//ifthisistrue,theprogramneverterminates.finalbooleanuseIsInterrupted=true;ExecutorServ

javax.naming.NameNotFoundException : Name [comp/env] is not bound in this Context. Java 调度程序无法找到 [comp] 错误

我想做的是在一段时间后更新我的数据库。所以我正在使用java调度程序和连接池。我不知道为什么,但我的代码只能工作一次。它将打印:initsuccesssuccessjavax.naming.NameNotFoundException:Name[comp/env]isnotboundinthisContext.Unabletofind[comp].atorg.apache.naming.NamingContext.lookup(NamingContext.java:820)atorg.apache.naming.NamingContext.lookup(NamingContext.jav

java - Thread::yield 与 Thread::onSpinWait

好吧,标题基本上说明了一切,还有一点我真的很想知道什么时候使用它们。它可能很简单——我已经阅读了它们的文档,但仍然看不出它们的区别。有像this这样的答案这里基本上说:Yieldingalsowasusefulforbusywaiting...我不太同意他们的观点,原因很简单,ForkJoinPool在内部使用了Thread::yield,这是jdk世界中最近才添加的。真正困扰我的是在jdk中也有这样的用法(StampledLock::tryDecReaderOverflow):elseif((LockSupport.nextSecondarySeed()&OVERFLOW_YIELD

java - web.xml的<filter-mapping>里面的<servlet-name>是什么意思?

我开始学习Struts2。我偶然发现了这段代码:web.xml...someothercodes...MyFilterMyFiltercom.xxx.yyy.zzz.MyFilterMyFilterMyActioncom.xxx.yyy.StrutsListenerMyActionorg.apache.struts.action.ActionServletparamName1param-name>paramVal1paramName2paramVal21...someothercodes...我的问题在这部分MyFilterMyAction为什么在中映射一个servlet标签?这种映射

java - java.lang.Thread 中新增的附加字段,是什么意思?

在Java8中,java.lang.Thread类获得了3个新字段:/**ThecurrentseedforaThreadLocalRandom*/@sun.misc.Contended("tlr")longthreadLocalRandomSeed;/**Probehashvalue;nonzeroifthreadLocalRandomSeedinitialized*/@sun.misc.Contended("tlr")intthreadLocalRandomProbe;/**SecondaryseedisolatedfrompublicThreadLocalRandomsequen

java - Apache 公共(public) CLI : how to prevent using short-name for options?

在ApacheCommonsCLI库中,是否可以绕过短名称的使用,从而强制用户使用长名称?通常,选项定义如下:newOption("u","username",true,"automaticusername")我想禁止使用“u”。但是,如果我用null或空字符串替换它,就会出现异常...为什么有这个要求?我希望我的所有选项都只采用--optionName=optionValue的形式,因为我的应用程序的某些部分是SpringBoot并且SpringBoot默认识别这种格式的选项。此外,为了在开发人员和用户之间保持一致并简化文档,我发现如果我们有一种独特的方式来使用一个选项而不是2个选项

java.util.MissingResourceException : Can't find bundle for base name

我正在测试Java的i18n特性,遇到一个问题,当语言文件不在类根目录中时,我无法加载它。现在我的文件在/lang目录中。在SO中查看了几个答案,将其放在classes子目录中并像lang.Messages一样加载它,使用完整的位置路由/Test/lang/Message(测试是项目名称),仅使用/lang/Message我仍然得到:java.util.MissingResourceException:Can'tfindbundleforbasename错误。还有什么可以尝试的吗?我的文件结构是:Test/lang/Messages_es.propertiesTest/src/test

java - 在 Java 中从 main() 中的 Thread 实例上运行 wait()

我正在研究java.lang.Object中wait()的定时版本,并观察到它在两种不同情况下的行为不同。场景一:在Thread中使用run()的默认定义publicstaticvoidmain(String[]args)throwsInterruptedException{Threadt=newThread();t.start();System.out.print("X");synchronized(t){t.wait(10000);}System.out.print("Y");}关于场景1的问题:我在X和Y之间遇到延迟。这是因为我从main调用wait()(即使在t上),因此调用m

java - 如果 Thread.sleep 是静态的,单个线程如何知道它已进入休眠状态?

我对Thread.sleep()方法有点困惑。如果Thread.sleep()是静态方法,两个线程如何知道哪个线程进入休眠状态。例如,在下面的代码中,我有两个三个Threadsmain、t和t1。我总是调用Thread.sleep()。不是t.sleep()。这是否意味着Thread.sleep()使当前线程进入休眠状态?这意味着Thread实例通过调用静态方法自行进入休眠状态。如果t1想让t进入休眠状态怎么办?这不可能是正确的?publicclassThreadInterrupt{publicstaticvoidmain(String[]args)throwsInterruptedE

java - RxJava : Observable and default thread

我有以下代码:Observable.create(newObservableOnSubscribe(){@Overridepublicvoidsubscribe(@NonNullfinalObservableEmitters)throwsException{Threadthread=newThread(newRunnable(){@Overridepublicvoidrun(){s.onNext("1");s.onComplete();}});thread.setName("background-thread-1");thread.start();}}).map(newFunction