去某地面试,面试官问了两个问题,到现在还没有想明白,问题是这样的:有2000万的数据,DB管理员每三秒断开一次数据库连接,你要从DB中把这两千万条数据得到,你该怎么做?第二:除了使用synchronized方法做线程同步外,还有没有其他的方式进行线程同步,我看网上还有wait和notify,也不要用,他提醒说是能不能用标志位的方式进行线程同步,我冒想出来,分数不多,欢迎大家进行讨论讨论而已!
------解决思路----------------------
可以使用lock 来保证多线程同步
如果只是想让线程顺序执行某个方法,比如
原方法
public synchronized void method1(){
//do something here
}
使用lock
private final ReentrantLock lock = new ReentrantLock();
public void mehtod1(){
lock.lock();
try{
//do something here
}finally{
lock.unlock();
}
}
还有一种可能是为了缓存数据并发性更好,比如某个类中有一个数据集用于做缓存的,为了让读写性能更佳(原方法不举例,因为不试过)
class RWDictionary {
//缓存集合 m
private final Map<String, Data> m = new TreeMap<String, Data>();
private final ReentrantReadWriteLock rwl = new ReentrantReadWriteLock();
//读取锁,多个线程可以同时获取该锁
private final Lock r = rwl.readLock();
//写入锁,当写入锁被获取后,之后的读取乐和写入锁都得等待当前写入锁释放
private final Lock w = rwl.writeLock();
public Data get(String key) {
r.lock();
try { return m.get(key); }
finally { r.unlock(); }
}
public String[] allKeys() {
r.lock();
try { return m.keySet().toArray(); }
finally { r.unlock(); }
}
public Data put(String key, Data value) {
w.lock();
try { return m.put(key, value); }
finally { w.unlock(); }
}
public void clear() {
w.lock();
try { m.clear(); }
finally { w.unlock(); }
}
}
另外想跟楼主讨论讨论线程同步的做用。
线程同步极大的可能是为了数据的一至性,而一至性就很有可能会涉及系统的并发性能。
所以了解线程同步再试着了解一下并发方面的知识会有相互了解的做用。