java实现多线程同步代码块
package cn.star;
/*
* 创建线程的第二种方式:实现Runnable接口
* 步骤:
* 1,定义类实现Runnable接口
* 2,覆盖Runnable接口中的run方法。
* 将线程要运行的代码存放在该run方法中。
* 3,通过Thread类建立线程对象。
* 4,将Runnable接口的子类对象作为实际参数传递给Thread类的构造函数。
* 为什么要将Runnable接口的子类对象传递给Thread构造函数。
* 因为,自定义的run方法所属的对象是Runnable接口的子类对象。
* 所以要让线程取指定对象的run方法,就必须明确run方法所属对象
* 5,调用Thread类的start方法开启线程并调用Runnable接口的run方法
* 实现方式和继承方式有什么区别?
* 实现方式好处:避免了单继承的局限性
* 在定义线程时,建立使用实现方式。
* 两种方式区别:
* 继承Thread:线程代码存放Thread子类run方法中。
* 实现Runnable,线程代码存在接口的子类的run方法。
* 通过try{Thread.sleep(10);}catch(Exception e){}发现,打印出0,-1,-2等错票。
* 多线程的运行出现了安全问题
* 问题原因:
* 当多条语句在操作同一个线程共享数据时,一个线程对多条语句只执行了一部分,还没有执行完,
* 另一个线程参与进来执行,导致共享数据的错误。
* 解决办法:
* 对多条操作共享数据的语句,只能让一个线程都执行完。在执行过程中,其他线程不可以参与执行。
* java对于多线程的安全问题提供了专业的解决方式。
* 就是同步代码块。
* synchronized(对象){
* 需要被同步的代码
* }
* */
//class Person{}
class Tickets implements Runnable// extends Thread
{
private int tick = 100;
Object obj=new Object();
//Person p=new Person();
public void run() {
while (true) {
synchronized(obj){
if (tick > 0) {
try{Thread.sleep(10);}catch(Exception e){}
System.out.println(Thread.currentThread().getName() + "--sale:" + tick--);
}}
}
}
}
public class Demod {
public static void main(String[] args) {
//long start = System.currentTimeMillis();
Tickets t = new Tickets();
// Ticket t2 = new Ticket();
// Ticket t3 = new Ticket();
// Ticket t4 = new Ticket();
// t1.start();
// t2.start();
// t3.start();
// t4.start();
Thread t1 = new Thread(t);
Thread t2 = new Thread(t);
Thread t3 = new Thread(t);
Thread t4 = new Thread(t);
t1.start();
t2.start();
t3.start();
t4.start();
//long end = System.currentTimeMillis();
//System.out.println(end-start);
}
}
/*
* 创建线程的第二种方式:实现Runnable接口
* 步骤:
* 1,定义类实现Runnable接口
* 2,覆盖Runnable接口中的run方法。
* 将线程要运行的代码存放在该run方法中。
* 3,通过Thread类建立线程对象。
* 4,将Runnable接口的子类对象作为实际参数传递给Thread类的构造函数。
* 为什么要将Runnable接口的子类对象传递给Thread构造函数。
* 因为,自定义的run方法所属的对象是Runnable接口的子类对象。
* 所以要让线程取指定对象的run方法,就必须明确run方法所属对象
* 5,调用Thread类的start方法开启线程并调用Runnable接口的run方法
* 实现方式和继承方式有什么区别?
* 实现方式好处:避免了单继承的局限性
* 在定义线程时,建立使用实现方式。
* 两种方式区别:
* 继承Thread:线程代码存放Thread子类run方法中。
* 实现Runnable,线程代码存在接口的子类的run方法。
* 通过try{Thread.sleep(10);}catch(Exception e){}发现,打印出0,-1,-2等错票。
* 多线程的运行出现了安全问题
* 问题原因:
* 当多条语句在操作同一个线程共享数据时,一个线程对多条语句只执行了一部分,还没有执行完,
* 另一个线程参与进来执行,导致共享数据的错误。
* 解决办法:
* 对多条操作共享数据的语句,只能让一个线程都执行完。在执行过程中,其他线程不可以参与执行。
* java对于多线程的安全问题提供了专业的解决方式。
* 就是同步代码块。
* synchronized(对象){
* 需要被同步的代码
* }
* */
//class Person{}
class Tickets implements Runnable// extends Thread
{
private int tick = 100;
Object obj=new Object();
//Person p=new Person();
public void run() {
while (true) {
synchronized(obj){
if (tick > 0) {
try{Thread.sleep(10);}catch(Exception e){}
System.out.println(Thread.currentThread().getName() + "--sale:" + tick--);
}}
}
}
}
public class Demod {
public static void main(String[] args) {
//long start = System.currentTimeMillis();
Tickets t = new Tickets();
// Ticket t2 = new Ticket();
// Ticket t3 = new Ticket();
// Ticket t4 = new Ticket();
// t1.start();
// t2.start();
// t3.start();
// t4.start();
Thread t1 = new Thread(t);
Thread t2 = new Thread(t);
Thread t3 = new Thread(t);
Thread t4 = new Thread(t);
t1.start();
t2.start();
t3.start();
t4.start();
//long end = System.currentTimeMillis();
//System.out.println(end-start);
}
}
评论
发表评论