[多线程]Java OutOfMemoryError

Java OutOfMemoryError unable to create new native thread
错误
不知道是不是线程创建太多的缘故:
我程序是这样写的

有一个ArrayBlockingQueue
一个操作是 读文件,往里面扔数据offer

还有个操作是 拉数据,poll

这两个操作 都是基于多线程的

我是通过线程池ThreadPoolExecutor来管理的

这样难道还会出现问题么?
[b]问题补充:[/b]
启动参数

#!/bin/sh
java -jar -Xms512m -Xmx1024m ApacheParser.jar
[b]问题补充:[/b]
ThreadPoolExecutor threadPool = new ThreadPoolExecutor(10, 20,
1, TimeUnit.SECONDS, new LinkedBlockingQueue(20),
new ThreadPoolExecutor.DiscardOldestPolicy());

可能是你的JVM初始内存和最大内存设得过小。

你可以通过在JVM启动的时候添加参数-Xms来设置初始的堆大小,-Xmx来设置最大的堆大小。

http://www.ibm.com/developerworks/cn/java/j-nativememory-linux/

线程池来进行管理的话,你线程池的参数设置的太大,肯定还是会Java OutOfMemoryError 的啊,说明你的参数设置,已经超出了你配置的java虚拟机的内存,不能再继续创建线程了.

线程池看起来没什么问题,是不是你的读写文件的代码有内存问题?比如一次读写过多的文件到内存中

-Xss128k你可以考虑采用这个参数把线程的堆栈调小到128k,然后同时将-Xmx1024m这个数字减小到你可以接受的程度;

朋友,问题要自动关闭啦,结分哦