00001 /* 00002 * ################################################################ 00003 * 00004 * ProActive: The Java(TM) library for Parallel, Distributed, 00005 * Concurrent computing with Security and Mobility 00006 * 00007 * Copyright (C) 1997-2007 INRIA/University of Nice-Sophia Antipolis 00008 * Contact: proactive@objectweb.org 00009 * 00010 * This library is free software; you can redistribute it and/or 00011 * modify it under the terms of the GNU Lesser General Public 00012 * License as published by the Free Software Foundation; either 00013 * version 2.1 of the License, or any later version. 00014 * 00015 * This library is distributed in the hope that it will be useful, 00016 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00017 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00018 * Lesser General Public License for more details. 00019 * 00020 * You should have received a copy of the GNU Lesser General Public 00021 * License along with this library; if not, write to the Free Software 00022 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 00023 * USA 00024 * 00025 * Initial developer(s): The ProActive Team 00026 * http://www.inria.fr/oasis/ProActive/contacts.html 00027 * Contributor(s): 00028 * 00029 * ################################################################ 00030 */ 00031 package org.objectweb.proactive.core.group.threadpool; 00032 00033 00039 public class EndControler { 00040 00042 private int numberOfAwakeThreads = 0; 00043 00049 // private boolean started = false; 00050 00052 synchronized public void waitDone() { 00053 try { 00054 while (this.numberOfAwakeThreads > 0) { 00055 this.wait(); 00056 } 00057 } catch (InterruptedException e) { 00058 System.err.println("InterruptedException"); 00059 } 00060 } 00061 00062 // /** Waits for the first thread to start. */ 00063 // synchronized public void waitBegin() { 00065 // this.started=true; 00066 // // try { 00067 // // while (!this.started) { 00069 // // this.wait(); 00070 // //} } 00071 // // catch (InterruptedException e) { System.err.println("InterruptedException"); } 00072 // } 00073 00075 synchronized public void jobStart() { 00076 // Thread.dumpStack(); 00077 // System.out.println("EndControler.jobStart()"); 00078 this.numberOfAwakeThreads++; 00079 // this.started = true; 00080 // this.notify(); 00081 } 00082 00084 synchronized public void jobFinish() { 00085 // System.out.println("EndControler.jobFinish()"); 00086 // Thread.dumpStack(); 00087 this.numberOfAwakeThreads--; 00088 this.notify(); 00089 } 00090 00092 synchronized public void reset() { 00093 this.numberOfAwakeThreads = 0; 00094 } 00095 }