主要是防止多核处理器同时访问修改某段代码,或者在对设备驱动程序进行临界区的保护。
3。 自旋锁
常用的同步方式有:原子操作、互斥锁、条件变量、读写锁、文件锁、信号灯。
1. 互斥锁
1. Share Memory共享内存
头文件以及相关函数
#inlcude <sys/shm.h>
void *shmat(int shm_id, const void *shm_addr, int shmflg);
int shmctl(int shm_id, int cmd, struct shmid_ds *buf);
int shmdt(const void *shm_addr);
int shmget(key_t key, size_t size, int shmflg);
3. Message Queues消息队列
头文件以及相关函数
#Include<sys/msg.h>
int msgctl(int msqid, int cmd, struct msqid_ds *buf);
int msgget(key_t key, int msgflg);
int msgrcv(int msqid, void *msg_ptr, size_t msg_sz, long int msgtype, int msgflg);
int msgsnd(int msqid, const void *msg_ptr, size_t msg_sz, int msgflg)
互斥锁+条件变量
读写锁(区分读写请求)--->文件锁(进一步细分被锁对象的粒度)
原文:http://www.cnblogs.com/cherishui/p/3574962.html