有这样一道面试题目:有一个int类型的变量count,有四个线程其中两个线程对count执行count+=1一百次,另外两个线程对cout执行count-=1一百次。在程序运行过程中确保count在0到一百范围之内。这是一个典型的生产消费者问题,涉及到线程的同步和互斥操作。
以上是我写的一个实现代码。 代码很简单很容易看懂。但是还有一些问题需要注意。
一、count是临界资源需要互斥访问。
二、当count等于100或等于0时需要使当前线程等待。当调用wait方法时当前线程放弃对对象监视器。(这里的对象监视器应该是指count对象,也就是当前线程进入互斥方法时获得的对象监视器。)
三、一开始我把while(count==100)写成了if(count==100),测试结果不正确。原因是如果两个线程同时被唤醒之后,就不会在对count进行测试有可能使count超过100。