package Visit;import java.net.*;
import org.apache.log4j.*;public class MainThread
    extends Thread {
  private Socket socket;
  public MainThread() {
  }  static Logger lg = Logger.getLogger(MainThread.class.getName());  /**
   * 线程方法
   */
  public void run() {
    while (true) {
      if (!VisitServer.Links.isEmpty()) {
        socket = (Socket) VisitServer.Links.firstElement();
        Online c = new Online(socket,
                              String.valueOf(socket.getRemoteSocketAddress()),
                              "V", 0, ""); 
        VisitServer.Onlines.addElement(c);
        c.start();
        VisitServer.Links.removeElementAt(0);
      }
      else {
        try {
          Thread.sleep(100);
        }
        catch (Exception e) {
          lg.info("主后台处理线程MainThread在处理用户进入线程处理时出现错误:" + e.getMessage());
        }
      }
    }
  }
}main方法里调用上面的方法()  /**
     * 开启运行主线程
     */
    MainThread mt = new MainThread();
    mt.start();上面这个MainThread是程序开始时运行的一个线程。这个线程就是用来判断Links这个队列,如果这个队列中有新的Socket连接进来的话,这个线程就负责开启一个新的线程来处理这个Socket连接。但是现在同时有6000多个(有时6106,有时5818等,但不达到7000.)Socket同时连接在线(同时处于连接状态,没有断)的时候,这个线程就停了。即使Links有新的Socket进入队列。这个也不执行了。当这个时候,我设置了断点。主线程还是正常继续执行(当然挺慢),这个MainThread 线程还是不执行。