Java多线程同步和异步详解

1. 多线程并发时,多个线程同时请求同一资源,必然导致此资源的数据不安全。

2. 线程池

在WEB服务中,对于web服务器的响应速度必须尽可能的快,这就容不得在用户提交请求按钮后,再创建线程提供服务。为了减少用户的等待时间,线程必须预先创建,放在线程池中,线程池可以用HashTable这种数据结构实现。

锁提供了两种机制:互斥(mutual exclusion)和可见性(visibility)。


备注:

①HashMap和Hashtable的区别

a.HashMap是Map接口的一个实现;Hashtable基于Dictionary类的。

b.同步:Hashtable的方法是同步的;而HashMap的不是。

c.空值:HashMap的key或value可为空;

二者更优先使用HashMap,可用一定方法实现其同步。

②Java内置锁

每个Java对象都可以用做一个实现同步的锁,这些锁成为内质锁。线程进入同步代码块或方法的时候会自动获得该锁,在退出同步代码块或方法时会释放该锁。获得内置锁的唯一途径就是进入这个锁的保护的同步代码块或方法。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值