1.Eclipse启动的时候,会启动一个JVM来运行eclipse(因为Eclipse是Java代码实现的)
2.Eclipse启动一个带main的主类的时候,会单独启动一个JVM来运行他。
3.Ecpilse启动多个带main的主类的时候,每个类都会有一个JVM。
class 1:
public class VectorTest1 {
Vector<String []> v=new Vector<String []>(100);
//
///*
// * ConcurrentLinkedQueue是“线程安全”的队列,而LinkedList是非线程安全的。
// *
// * 下面是“多个线程同时操作并且遍历queue”的示例
// * (01) 当queue是ConcurrentLinkedQueue对象时,程序能正常运行。
// * (02) 当queue是LinkedList对象时,程序会产生ConcurrentModificationException异常。
// *
// TODO: queue是LinkedList对象时,程序会出错。
//private static Queue<String> queue = new LinkedList<String>();
public static Queue<String> queue = new ConcurrentLinkedQueue<String>();
public static void main(String[] args){
for(int i=0;i<1000;i++) {
queue.add("job"+i+"'s key value timestamp");
System.out.println(i);
}
}
class 2:
```
public class FixedThreadExecutorTest {
public static void createPoolAndTread() {
ScheduledExecutorService pool = Executors.newScheduledThreadPool(5);
pool.scheduleAtFixedRate(new Runnable() {
@Override
public void run() {
if(!VectorTest.queue.isEmpty())
System.out.println(Thread.currentThread().getName()+" Send message to graphite "+VectorTest.queue.poll());
else {
System.out.println("No Graphite message to send !!");
}
}
},0, 10, TimeUnit.MILLISECONDS);
}
public static void main(String[] args) throws InterruptedException {
VectorTest.start();
createPoolAndTread();
}
}
```
class1和class2同时启动,我们可以发现,class2的进程,不会获得ConcurrentLinkedQueue的任何信息。说明不是在同一个jvm。