解决并发问题,最简单的办法是使用操作锁或文件锁。
synchronized 和 lock.
synchronized 为操作锁,用synchronized 标记的操作,不同的线程不能再同一时刻执行,只能由抢占到资源的线程执行完成,下一个线程才能执行相同的操作。
文件锁有,lock和try lock两种形式。前者具有阻塞性,线程执行到该语句时,只有获得锁(lock),才会继续执行,否则线程将会一直停在该lock语句,直到获得锁。 trylock,具有半阻塞性,它如果没获得锁,便会跳出,所以需用try{}catch{}来捕捉,它的跳出。
还有一点注意,就是不能单单只锁了read()和write()这两步
[img]http://dl2.iteye.com/upload/attachment/0117/7284/8fe9cd07-0762-3145-a344-45c486abf43f.png[/img]
如上图,因为会出现一个线程在执行中间(读后写前)的操作时,另一个线程读取数据,还是会造成数据错误
synchronized 和 lock.
synchronized 为操作锁,用synchronized 标记的操作,不同的线程不能再同一时刻执行,只能由抢占到资源的线程执行完成,下一个线程才能执行相同的操作。
文件锁有,lock和try lock两种形式。前者具有阻塞性,线程执行到该语句时,只有获得锁(lock),才会继续执行,否则线程将会一直停在该lock语句,直到获得锁。 trylock,具有半阻塞性,它如果没获得锁,便会跳出,所以需用try{}catch{}来捕捉,它的跳出。
还有一点注意,就是不能单单只锁了read()和write()这两步
[img]http://dl2.iteye.com/upload/attachment/0117/7284/8fe9cd07-0762-3145-a344-45c486abf43f.png[/img]
如上图,因为会出现一个线程在执行中间(读后写前)的操作时,另一个线程读取数据,还是会造成数据错误