三.多线程的创建方式
1.继承的方式:通过继承Thread并且重写run方法.
代码如下:
class MyThread extends Thread{
public void run(){
}
}
主方法中先生成对象然后启动线程:
MyThread myThread=new MyThread();
myThread.start();
2.通过实现Runnable接口: 重写run方法并将生成的对象通过Thread的构造方法传给相应的thread对象.
代码如下:
class MyRunnable implements Runnable{
public void run(){
}
}
主方法中:
MyRunnable myRunnabble=new MyRunnable();
Thread a=new Thread(myRunnabble);
a.start();
四.直接调用线程的run()方法和调用start()方法的区别
1.如果你直接调用run方法则相当于在主线程中调用一个普通对象的普通成员方法,并不会开启线程
2.调用start方法则会让线程进入就绪状态
五.synchronized关键字
1.对象锁
a.当使用对象锁的时候,注意要是相同的对象,并且当有线程正在访问对象锁内部的代码的时候,其他线程无法访问。(注意无法访问的范围)。
b.但是并不影响没有使用对象锁的部分的代码的运行。
对象锁分为两类一个叫做synchronized代码块(圆括号内是普通类的对象),另外一个是sybchronized修饰普通成员方法。它们二者其实可以通过this关键字进项转化。
2.类锁
a. 当使用类锁的时候,只要是同一个类的对象.当有线程正在访问类锁内部的代码的时候,其他线程无法访问。(注意无法访问的范围)
b. 但是并不影响没有使用类锁的部分的代码的运
对象锁分为两类一个叫做synchronized代码块(圆括号内是class对象),另外一个是sybchronized修饰静态成员方法。它们二者其实可以通过class对象进项转化。
注意: 类锁和对象锁之间没有关系.
六.sleep方法
会让当前线程进入阻塞状态,但是不会释放锁.(想让哪个线程休眠就在哪个线程中调用Thread.sleep(),在那个线程中调用的,哪个线程就休眠。不管是哪个对象调用的)在阻塞期间不释放锁
(注意: 会丢弃当前剩余的时间片,立马进入阻塞状态)
七.yield方法
会让当前线程暂停执行,进入就绪状态(在那个线程中调用的,哪个线程就回到调度中心不管是哪个对象 调用的)
(注意: 会丢弃当前剩余的时间片,立马回到调度中心)
八.join方法
会让产生线程进入阻塞状态,直到相应线程执行完毕。(在哪个线程中调用的,哪个线程就阻塞状态。不管是哪个对象调用的)静态的方法需要用具体对象调用
(注意: 会丢弃当前剩余的时间片,立马进入阻塞状态)