jjzjj

java - (Java 7 NIO.2) 监视服务线程的自定义名称

在Java7中使用nio.2,当您创建这样的watch服务时:WatchServicewatcher=FileSystems.getDefault().newWatchService();然后,启动后台线程,在无限循环中轮询文件系统事件。此线程的名称是“Thread-n”,这在调查线程转储或分析session期间有点麻烦。我们可以更改该线程的名称吗? 最佳答案 直接看实现,好像不行。如果您不介意一些小技巧,您可以找到线程并重命名它。类似于(//TODO:进行错误检查)SetthreadsBefore=Thread.getAllSta

java - OS X Java 每个进程的最大线程数

运行这段代码for(inti=0;i结果Exceptioninthread"main"java.lang.OutOfMemoryError:unabletocreatenewnativethreadatjava.lang.Thread.start0(NativeMethod)atjava.lang.Thread.start(Thread.java:658)atcom.codeoverdrive.burnbearburn.Main.main(Main.java:10)2024个运行线程之后。使用JVM堆和堆栈大小没有帮助。sysctlkern.num_threads返回kern.num_

java - 列出 ThreadPoolTask​​Executor 中所有正在运行/排队的线程

我在Spring中使用ThreadPoolTask​​Executor来安排我的任务。有没有办法获取该任务执行器/池的每个正在运行和排队的线程的列表或其他信息? 最佳答案 也许不是很优雅,但通过这种方式我可以从已知的执行器中获取所有线程(使用startsWith()前缀)。SetthreadSet=Thread.getAllStackTraces().keySet();for(Threadthread:threadSet){if(thread.getName().startsWith("MyExecutor")){System.ou

java - 'Thread termination due to failure'指的是什么?

ExecutorService的javadoc有时会提到线程“由于失败”而终止的情况。但是,目前尚不清楚这指的是哪种故障。例如,singlethreadexecutor文档说ifthissinglethreadterminatesduetoafailureduringexecutionpriortoshutdown,anewonewilltakeitsplaceifneededtoexecutesubsequenttasks我本来以为这种情况可能发生在Exception的情况下,也可能是RuntimeException,但似乎并不是这样。运行以下代码似乎给出了相同的线程名称和线程ID。

Java Thread.sleep 最短时间

这个问题在这里已经有了答案:HowaccurateisThread.sleep?(3个答案)关闭5年前。TimeUnit.sleep(longtimeout)文档这样描述它的论点:timeout-theminimumtimetosleep.但是,我发现—至少在带有Java8update141的Windows764位上—线程hibernate的时间通常少于:publicstaticvoidmain(String[]args)throwsInterruptedException{finallongfrom=TimeUnit.MILLISECONDS.toNanos(100);finallo

java - 将数据批量上传到 GAE Java 项目的数据存储中

我想填充数据存储。然而,所有用于填充数据存储的示例和说明都与Python项目有关。有没有办法使用AppEngineJava工具上传批量数据?(目前数据是CSV格式,但我可以根据需要轻松地重新格式化数据。)如果它可以在EclipseIDE中完成,那将特别有用。谢谢。 最佳答案 我遇到了和你一样的问题。根据http://groups.google.com/group/google-appengine-java/browse_thread/thread/72f58c28433cac26的讨论目前还没有适用于Java的等效工具。然而,看起来

java - 单例对象工厂 : is this code thread-safe?

我有一个用于许多单例实现的通用接口(interface)。接口(interface)定义了可以抛出检查异常的初始化方法。我需要一个工厂来按需返回缓存的单例实现,想知道以下方法是否线程安全?UPDATE1:请不要建议任何第三部分库,因为由于可能的许可问题,这将需要获得法律许可:-)更新2:此代码可能会在EJB环境中使用,因此最好不要产生额外的线程或使用类似的东西。interfaceSingleton{voidinit()throwsSingletonException;}publicclassSingletonFactory{privatestaticConcurrentMap>CACH

java - 增加java中单个工作线程的堆栈空间

在我的javaweb应用程序中,我有一个后台工作线程,它需要大量堆栈空间,因为它使用activiti工作流引擎和groovy脚本任务运行一个非常复杂的工作流。目前我需要在64位Java和Tomcat上将JVMXss设置设置为16MB,以规避任何StackOverflowErrors。如果发生错误,堆栈跟踪非常大(几百行长),但它都发生在引擎内部,所以我真的无能为力。现在我的问题是:有没有办法在运行时增加单个线程的堆栈大小?我想将应用程序中所有线程的JVM默认Xss设置降低到512k,我知道这足够了,并且只运行16M的工作线程。JavaAPI为Thread类的构造函数提供了有关此主题的一

java - ORA-12519, TNS :no appropriate service handler found while inserting into Oracle Database with X threads

我正在尝试插入到具有两列的Oracle数据库中-IDPrimaryKeyvarchar2(4000)ACCOUNTvarchar2(4000)我为此编写了一个多线程程序。并且每个线程每次都使用uniqueid插入ID列,因为ID是主键。我在某些时候面临的唯一问题是-下面的代码在运行几秒钟后抛出以下异常。1)NullPointerException2)java.sql.SQLException:Listenerrefusedtheconnectionwiththefollowingerror:ORA-12519,TNS:noappropriateservicehandlerfound我无

java - 并发还是顺序?

我正在研究Java中的线程。我在网站上找到的以下示例:publicclassThreadTest{publicstaticvoidmain(Stringargs[]){Threadt1=newThread(newThread1());t1.start();Threadt2=newThread(newThread2());t2.start();}}publicclassThread1implementsRunnable{@Overridepublicvoidrun(){for(inti=0;i预期的结果是这样的:MonNov1120:06:12CET20130123456789MonNo