黑马程序员——java高新技术---线程池

线程池

线程池的作用是重复利用线程,避免创建过多的线程。
创建线程池的类为ThreadPoolExecutor,但创建过程比较复杂,我们可以使用java自带的根据程序员使用频率较高的常用设置预设的线程池类创建。

线程池类:ExecutorServise
同步锁:Lock
控制线程数:Semaphore

ExecutorServise

方法

  • ExecutorService threadpool = Executors.newFixedThreadPool(n); //创建n个线程的线程池
  • newCacheThreadPool()
    根据创建次数增加线程数,线程数达到最大值后
ExecutorService threadpool = Executors.newFixedThreadPool(3);
threadpool.execute( new Runnable() {
    public void run()
    {
        ...
    }
}

//Future Callable可以得到线程的返回值
ExecutorService threadpool = Executors.newSingleThreadExecutor();
Future<String> future = threadpool.submit(new Callable<String>() {
    public String call() {
        return "hello, world";
    }
});

Lock

在前面说过,同步锁Lock是

Lock lock = new ReentrantLock();     //锁
Condition con = lock.newCondition(); //控制wait和notify的类

con.await();   // = wait()
con.signal();  // = notify()

Semaphore

在线程池中,每个线程比喻成一盏灯,当创建线程时调用acquere()函数点一盏灯,结束时调用release()交出灯,灯的总数就是线程池中最大运行线程数。

Constructor:

Semphore sp = new Semaphore(n); // 总共n盏灯
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值