Java多线程控制的心得

近期我刚刚完成了一个信息采集的Java项目,其中采集环节是以多线程的方式来运行的。开发时在多线程的控制方面遇到了不少的麻烦,主要是线程同步问题和线程的状态管理,我就这两方面简单谈谈自己的心得。

在Java中,经常会出现多个线程同时对同一资源进行操作,比如同时改变同一个变量,例如线程A刚刚将变量值改为1,紧接着线程B又将变量值改为2,这时线程A继续下面的程序时如果需要用的这个变量,就会出现错误。

因此我们需要让一个线程操作资源时其他线程进行等待,这就需要用到锁的概念,Java中提供了synchronized这个方法让线程对资源操作时进行同步。synchronized具体的用法可以上网搜索一下,相关的技术文章很多很多。这里就不详细举例了。

在我的项目中,还遇到了另外一个问题,就是线程尚未结束,主进程就已经结束了,由于主进程过早结束造成数据库连接被销毁,导致线程无法正常操作数据库而报错。我的解决方案是先构建一个线程池,线程池中记录活动的线程数量,在主进程最后结束前,做一个while循环判断线程池中的活动线程数量,当活动线程为0时,再退出while循环并且结束主进程。

线程池的实现方法简要来说就是每创建一个新的线程,就将线程池中的活动线程数量+1,当线程结束时,通过线程回调,将线程池中的活动线程数量再-1。

Java多线程的实现

以NetBeans环境为例,新建一个J2SE的项目,然后在项目中新建一个名为mythread的包,在mythread包中,新建两个类,分别为Main.java和MyThread.java,下面提供这两个文件的代码。

Main.java代码:

package mythread;

/**
 * @author Jason
 */
public class Main
{
    public static void main(String[] args)
    {
        for(int i = 0; i < 5; i++) new MyThread(i+1).start();
    }
}

MyThread.java代码:

package mythread;

/**
 * @author Jason
 */
public class MyThread extends Thread
{
    int intCount = 1, intNumber;

    /**
     * 构造函数
     * @param int num 线程编号
     */
    public MyThread(int num)
    {
        intNumber = num;
        System.out.println("创建线程 " + intNumber);
    }

    @Override
    /**
     * 线程启动
     */
    public void run()
    {
        while(true)
        {
            System.out.println("线程 " + intNumber + ":计数 " + intCount);
            if(++intCount == 9) return;
        }
    }
}