java同步代码线程 java中线程同步的几种方法

Java中的线程同步与异步如何理解?线程,有时被称为轻量级进程(Lightweight Process,LWP),是程序执行流的最小单元 。一个标准的线程由线程ID,当前指令指针(PC) , 寄存器集合和堆栈组成 。
另外,线程是进程中的一个实体,是被系统独立调度和分派的基本单位 , 线程自己不拥有系统资源,只拥有一点儿在运行中必不可少的资源,但它可与同属一个进程的其它线程共享进程所拥有的全部资源 。
一个线程可以创建和撤消另一个线程,同一进程中的多个线程之间可以并发执行 。由于线程之间的相互制约,致使线程在运行中呈现出间断性 。线程也有就绪、阻塞和运行三种基本状态 。
就绪状态是指线程具备运行的所有条件,逻辑上可以运行,在等待处理机;运行状态是指线程占有处理机正在运行;阻塞状态是指线程在等待一个事件(如某个信号量),逻辑上不可执行 。每一个程序都至少有一个线程,若程序只有一个线程,那就是程序本身 。
线程是程序中一个单一的顺序控制流程 。进程内一个相对独立的、可调度的执行单元,是系统独立调度和分派CPU的基本单位指运行中的程序的调度单位 。在单个程序中同时运行多个线程完成不同的工作 , 称为多线程 。
同步就是只能A走完某一段然后停下 , 让B开始走一段再停下 , 再让A走 。。如此往复 。简单理解就是 , 必须是一段程序执行完后才能执行后面的程序 。。
异步就是,同一时间可能A和B同时都在往终点赶,此时不存在先后顺序,就是说,两个程序可以同时执行,称为异步 。
java中线程同步的几种方法线程同步主要有以下种方法(示例中是实现计数的功能):
1、同步方法 , 即使用synchronized关键字修饰方法,例如:
public synchronized void add(int c){...}
2、同步代码块,即有synchronized关键字修饰的语句块,例如:
public void addAndGet(int c){
synchronized(this){
count += c;
}
}
3、使用特殊域变量(volatile)实现线程同步,该方法不能保证绝对的同步 。
例如:private volatile int count = 0;
4、使用锁实现线程同步,例如:
private Lock lock = new ReentrantLock();
public void add(int c) {
lock.lock();//上锁
try{
count += c;
}finally{
lock.unlock();//解锁
}
}
5、使用原子变量实现线程同步,在java的util.concurrent.atomic包中提供了创建了原子类型变量的工具类 , 例如:
private AtomicInteger count= new AtomicInteger(1);
public void add(int c) {
count.addAndGet(c);
}
6、使用局部变量实现线程同步,如果使用ThreadLocal管理变量,则每一个使用该变量的线程都获得该变量的副本 ,  副本之间相互独立,这样每一个线程都可以随意修改自己的变量副本 , 而不会对其他线程产生影响 。
ThreadLocal 类的常用方法
new ThreadLocalT() : 创建一个线程本地变量
get() : 返回此线程局部变量的当前线程副本中的值
initialValue() : 返回此线程局部变量的当前线程的"初始值"
set(T value) : 将此线程局部变量的当前线程副本中的值设置为value
示例代码:
private static ThreadLocalInteger count= new ThreadLocalInteger(){
@Override
protected Integer initialValue(){
return 1;
}
};
public void add(int c){
count.set(count.get() + c);
}
7、使用阻塞队列实现 , 例如LinkedBlockingQueue,具体使用可百度LinkedBlockingQueue的用法或查看java文档 。
浅谈Java多线程的同步问题 多线程的同步依靠的是对象锁机制 synchronized关键字的背后就是利用java同步代码线程了封锁来实现对共享资源的互斥访问

推荐阅读