1.Eclipse启动的时候,会启动一个JVM来运行eclipse(因为Eclipse是Java代码实现的)
2.Eclipse启动一个带main的主类的时候,会单独启动一个JVM来运行他。 3.Ecpilse启动多个带main的主类的时候,每个类都会有一个JVM。class 1:
public class VectorTest1 { Vectorv=new Vector (100);/////*// * ConcurrentLinkedQueue是“线程安全”的队列,而LinkedList是非线程安全的。// *// * 下面是“多个线程同时操作并且遍历queue”的示例// * (01) 当queue是ConcurrentLinkedQueue对象时,程序能正常运行。// * (02) 当queue是LinkedList对象时,程序会产生ConcurrentModificationException异常。// * // TODO: queue是LinkedList对象时,程序会出错。 //private static Queue queue = new LinkedList (); public static Queue queue = new ConcurrentLinkedQueue (); 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。