1.怎么解决多线程并发访问临界资源的产生的问题?
用锁 pthread_mutex_t mtx解决。
2.mtx锁的作用具体是什么?
先把临界资源锁起来,再把它打开,这样一来,多个执行流想要同时执行临界资源就不可以了,只能一个执行,等执行完,再把锁打开,方可放进其他执行流。
3.越多线程处理同一个问题,越快吗?
并不是,要看具体场景。
4.加锁了之后就是串行执行吗?会被切换吗?会有问题吗?
是串行执行,执行临界区代码执行一定是串行的,会被切换,但不会有问题,因为其他执行流进不去,申请不来被锁,因为那个被切换的执行流还没有解锁。
5.锁是不是一种临界资源,那怎么保护他的安全呢?
是一种临界资源,所以申请和释放锁的过程都是原子性操作。
6.从执行流的角度来看,CPU里的寄存器是什么?
寄存器的空间是被所以执行流共享的,但寄存器的内容是被每一个执行流私有的,是执行流的上下文。
7.锁如何实现自己保护自己?
所有的操作都是原子性操作,从头到尾只存在一个1,进行0与1之间的交换,而不是像过往一样对内存中的1进行复制。
al = 0;
mutex = 1 ;
al = 1 , mutex = 1;
…
8.什么叫重入?
9.可重入和线程安全的联系?
10.什么叫死锁?
持有锁的线程互相申请对方已占用的锁的状态叫死锁。