java高并发程序设计学习笔记(一)

并发与高并发

刚开始学的我一直认为并发和高并发没什么区别,但并发是指多个线程同时运行,它们都是同时存在的,高并发是在其基础之上使其同时并行处理大量的数据。

创建线程

线程的创建十分的简单,只需要new一个thread并执行它的start方法即可。

Thread t = new Thread();
  t.start();

线程执行start方法之后,则会去调用thread里的run方法。顾名思义就是让线程跑起来,切记,千万别直接去调用run方法,不然这就不是线程了,这叫调用方法,只会串行执行代码。接下来线程嘛,得给他布置任务了。程序执行了线程并跑起来,我们重写它的run方法,布置一个输出文字的任务。

Thread t = new Thread() {
   public void run() {
    System.out.println("I like java");
   }
  };

以上代码使用匿名内部类,也可以直接继承thread,然后 类名 引用 = new 类名();引用.start();在本类中重写run方法即可。
创建线程还有一种方法,可以使用runnable接口创建线程。

public class thread implements Runnable {
 public static void main(String[] args) {

  Thread t = new Thread(new thread());
  t.start();
 }
 public void run() {
  System.out.println("l like java");
 }
}

终止线程

刚开始学多线程的时候,终止线程的方法我用的是stop方法,查阅jdk你会发现这个方法被标注为一个废弃的方法,这个方法太过于暴力,强制关机不过如此。拿二维数组(五子棋?)举例,假设这里有读线程和写线程这两个线程,写线程在规定的时间里把棋子信息覆盖二维数字,突然被stop了,然后规定时间到了,读线程开始运行,那么它只能读取到不完整的棋盘。
解决方法是设置一个布尔临时变量,如果希望它停止运行,把临时变量改成true,线程的run方法里每次写完一个棋盘判断一下是否需要退出,就好了。

中断线程

public boolean isInterrupted()//是否被中断

public void interrupt()//中断线程

public static boolean interrupted() //判断是否被中断,若被中断则清除中断状态
public static void main(String[] args) throws InterruptedException {
  Thread t = new Thread() {
   public void run() {
    while(true) {
     Thread.yield();
    }
   }
  };
  t.start();
  Thread.sleep(1000);
  t.interrupt();
 }
public static void main(String[] args) throws InterruptedException {
  Thread t = new Thread() {
   public void run() {
    while(true) {
     if(Thread.currentThread().isInterrupted()) {
      System.out.println("我被中断了");
      break;
     }
     Thread.yield();
    }
   }
  };
  t.start();
  Thread.sleep(1000);
  t.interrupt();
 }

java提供了一种更为高效的方法,第一段是jdk自带的方法,作用已经给出,第二段的线程无疑是一个死循环,使用了interrupt是否会让这个程序停止运行吗?答案是否定的,线程中断并不会直接中断一个线程,使用了interrupt方法是告诉了这个线程“你该中断了”的信息,如何处理这种中断信息?
第三段代码给出解释,Thread.currentThread()是当前的线程信息,isInterrupted()判断是否被中断。如果当前线程被中断,则退出这个循环,线程就结束了。
这个方法和之前的设计临时变量有些相似,都是需要判断当前自己是否需要中断。

Thread.sleep

public static void main(String[] args) throws InterruptedException {
  Thread t = new Thread() {
   public void run() {
    while(true) {
     if(Thread.currentThread().isInterrupted()) {
      System.out.println("我被中断了");
      break;
     }
     try {
      Thread.sleep(2000);
     }catch (InterruptedException e) {
      System.err.println("sleep被中断");
      Thread.currentThread().interrupt();
     }
    }
   }
    };
    t.start();
    Thread.sleep(1000);
    t.interrupt();
 }

sleep(long time);会让当前线程休眠一段时间,它抛出InterruptedException,在休眠状态下程序被打断休眠会抛出这个异常,这段代码中的try语句块中被主方法的sleep方法打断抛出一个异常,它不是运行时错误,我们必须捕获处理它,并为这个线程设置一个中断位。
要知道,捕获了中断异常,这个线程的中断标记被清除,也就是如果不在设置一个中断位,下次循环就无法捕获这个中断。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值