java多线程学习笔记之线程安全
假设i为银行的存款数据,i = 100, 现在使用A B两个线程(两个人)同时执行 i = i 10;(存10块钱)的操作,由于默认情况下异步执行,那么流程可能会是这样:
1. A线程从系统内存中读到 i。
2. B线程从系统内存中读到 i。
3. A线程执行 i 10。
4. B线程执行 i 10。
5. A线程将110写回到系统内存,内存中i的值为 110。
6. B线程将110写回到系统内存,内存中i的值为 110,。
显然这程结果是不正确的,少了一个人存的钱。
synchronized关键字
我理解这个关键字作用是控制对象在多线程情况下,保护其在工作内存中只存在一份引用。
多线程安全实例:
<table width="620" align="center" border="0" cellpadding="1" cellspacing="1" style="background:#FB7"> <tr> <td width="464" height="27" bgcolor="#FFE7CE"> 代码如下</td> <td width="109" align="center" bgcolor="#FFE7CE" style="cursor:pointer;" onclick="doCopy('copy5102')">复制代码</td> </tr> <tr> <td height="auto" colspan="2" valign="top" bgcolor="#FFFFFF" style="padding:10px;" class="copyclass" id=copy5102>package threads;
public class TestIPP
{
public static void main(String[] args) throws InterruptedException
{
Num num = new Num(100000);
Thread plus = new Plus(num);
Thread cut = new Cut(num);
plus.start();
cut.start();
plus.join();
cut.join();
System.out.print(num.getNum());
}
public static class Num
{
int num;
public void plus()
{
num ;
}
public void cut()
{
num--;
}
public Num(int num)
{
this.num = num;
}
public int getNum()
{
return this.num;
}
}
static public class Plus extends Thread
{
Num num;
public Plus(Num num)
{
this.num = num;
}
public void run()
{
synchronized (num) {
for (int i = 0; i < 5; i ) {
num.plus();
System.out.println(" 1");
}
}
}
}
static public class Cut extends Thread
{
private Num num;
public Cut(Num num)
{
this.num = num;
}
public void run()
{
synchronized (num) {
for (int i = 0; i < 5; i ) {
num.cut();
System.out.println("-1");
}
}
}
}
}
例了
<table width="620" align="center" border="0" cellpadding="1" cellspacing="1" style="background:#FB7"> <tr> <td width="464" height="27" bgcolor="#FFE7CE"> 代码如下</td> <td width="109" align="center" bgcolor="#FFE7CE" style="cursor:pointer;" onclick="doCopy('copy8458')">复制代码</td> </tr> <tr> <td height="auto" colspan="2" valign="top" bgcolor="#FFFFFF" style="padding:10px;" class="copyclass" id=copy8458>import java.io.*;
//多线程编程
public class MultiThread
{
public static void main(String args[])
{
System.out.println("我是主线程!");
//下面创建线程实例thread1
ThreadUseExtends thread1=new ThreadUseExtends();
//创建thread2时以实现了Runnable接口的THhreadUseRunnable类实例为参数
Thread thread2=new Thread(new ThreadUseRunnable(),"SecondThread");
thread1.start();//启动线程thread1使之处于就绪状态
//thread1.setPriority(6);//设置thread1的优先级为6
//优先级将决定cpu空出时,处于就绪状态的线程谁先占领cpu开始运行
//优先级范围1到10,MIN_PRIORITY,MAX_PRIORITY,NORM_PAIORITY
//新线程继承创建她的父线程优先级,父线程通常有普通优先级即5NORM_PRIORITY
System.out.println("主线程将挂起7秒!");
try
{
Thread.sleep(7000);//主线程挂起7秒
}
catch (InterruptedException e)
{
return;
}
System.out.println("又回到了主线程!");
if(thread1.isAlive())
{
thread1.stop();//如果thread1还存在则杀掉他
System.out.println("thread1休眠过长,主线程杀掉了thread1!");
}
else
System.out.println("主线程没发现thread1,thread1已醒顺序执行结束了!");
thread2.start();//启动thread2
System.out.println("主线程又将挂起7秒!");
try
{
Thread.sleep(7000);//主线程挂起7秒
}
catch (InterruptedException e)
{
return;
}
System.out.println("又回到了主线程!");
if(thread2.isAlive())
{
thread2.stop();//如果thread2还存在则杀掉他
System.out.println("thread2休眠过长,主线程杀掉了thread2!");
}
else
System.out.println("主线程没发现thread2,thread2已醒顺序执行结束了!");
System.out.println("程序结束按任意键继续!");
try
{
System.in.read();
}
catch (IOException e)
{
System.out.println(e.toString());
}
}//main
}//MultiThread
class ThreadUseExtends extends Thread
//通过继承Thread类,并实现它的抽象方法run()
//适当时候创建这一Thread子类的实例来实现多线程机制
//一个线程启动后(也即进入就绪状态)一旦获得CPU将自动调用它的run()方法
{
ThreadUseExtends(){}//构造函数
public void run()
{
System.out.println("我是Thread子类的线程实例!");
System.out.println("我将挂起10秒!");
System.out.println("回到主线程,请稍等,刚才主线程挂起可能还没醒过来!");
try
{
sleep(10000);//挂起5秒
}
catch (InterruptedException e)
{
return;
}
//如果该run()方法顺序执行完了,线程将自动结束,而不会被主线程杀掉
//但如果休眠时间过长,则线程还存活,可能被stop()杀掉
}
}
class ThreadUseRunnable implements Runnable
//通过实现Runnable接口中的run()方法,再以这个实现了run()方法的类
//为参数创建Thread的线程实例
{
//Thread thread2=new Thread(this);
//以这个实现了Runnable接口中run()方法的类为参数创建Thread类的线程实例
ThreadUseRunnable(){}//构造函数
public void run()
{
System.out.println("我是Thread类的线程实例并以实现了Runnable接口的类为参数!");
System.out.println("我将挂起1秒!");
System.out.println("回到主线程,请稍等,刚才主线程挂起可能还没醒过来!");
try
{
Thread.sleep(1000);//挂起5秒
}
catch (InterruptedException e)
{
return;
}
//如果该run()方法顺序执行完了,线程将自动结束,而不会被主线程杀掉
//但如果休眠时间过长,则线程还存活,可能被stop()杀掉
}
}
//该程序可做的修改如改休眠时间或优先级setPriority()
您可能感兴趣的文章:
java工作笔记之多线线程实例详解
java多线程的优先级实例程序
java中字符串学习笔记
学习J2SE过程中的30个基本概念
经典Java线程面试题70道
java多线程例子学习笔记
java多线程学习笔记之线程安全
Java多线程原理及ThreadLocal多线程实例详解
Java并发控制机制学习笔记
Java程序多线程测试笔记