c语言多线程同步使用(linux)

一、多线程

头文件:
  #include<pthread.h>
函数声明:
  int pthread_create(pthread_t*restrict tidp,const pthread_attr_t *restrict_attr,void*(*start_rtn)(void*),void *restrict arg);
参数依次为:
  指向线程标识符的指针、设置线程属性、线程运行函数的起始地址、传入参数。

食用方法:
指针函数:

void *mythread_function(void *arg)
{
  ...
}

调用代码:

...
#include <pthread.h>
...
pthread_t mythread;
pthread_create(&mythread, NULL, mythread_function, NULL)

注意:

  1. pthread_create第4个传参为向线程传入参数,但因为只能传入一个,所以传参多的时候需要用struct封装一下。
  2. 线程创建成功返回.

二、信号量

头文件:
  #include <semaphore.h>
函数:

  • 初始化信号量
      int sem_init(sem_t *sem, int pshared, unsigned int val);
    参数依次为:
      信号量指针、信号量类型,信号量初始值。
      第二个参数pshared为0时,该进程内所有线程可用,不为0时不同进程间可用。
  • 信号量减1
      int sem_wait(sem_t *sem);
    说明:
      该函数申请一个信号量,当前无可用信号量则等待,有可用信号量时占用一个信号量,对信号量的值减1。
  • 信号量加1
       int sem_post(sem_t *sem);
  • 销毁信号量
      int sem_destory(sem_t *sem);
    该函数销毁信号量。

三、互斥锁

头文件和线程的相同:
  #include <pthread.h>
使用方法:

  • 创建
      方式一:
      pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
      方式二:
      pthread_mutex_init函数,函数原型:
      int pthread_mutex_init(pthread_mutex_t *mutex, const pthread_mutexattr_t * attr)
    注:第二个参数为设置互斥锁属性,NULL表示默认为普通锁。
  • 属性
      设置方法:
       方式一:
      pthread_mutexattr_init(pthread_mutexattr_t *mattr);
      方式二:
      pthread_mutexattr_setpshared(pthread_mutexattr_t *mattr, int pshared);
      方式三:
      pthread_mutexattr_settype(pthread_mutexattr_t *attr , int type)
    注:第二个参数为设置互斥锁的范围:可以指定是该进程与其他进程的同步还是同一进程内不同的线程之间的同步。可以设置为PTHREAD_PROCESS_SHAREPTHREAD_PROCESS_PRIVATE。默认是后者,表示进程内使用锁。
       获取锁类型:
      pthread_mutexattr_gettype(pthread_mutexattr_t *attr , int *type)

互斥锁的类型:
1.PTHREAD_MUTEX_TIMED_NP,这是缺省值,也就是普通锁。当一个线程加锁以后,其余请求锁的线程将形成一个等待队列,并在解锁后按优先级获得锁。这种锁策略保证了资源分配的公平性。
2.PTHREAD_MUTEX_RECURSIVE_NP,嵌套锁,允许同一个线程对同一个锁成功获得多次,并通过多次unlock解锁。如果是不同线程请求,则在加锁线程解锁时重新竞争。
3.PTHREAD_MUTEX_ERRORCHECK_NP,检错锁,如果同一个线程请求同一个锁,则返回EDEADLK,否则与PTHREAD_MUTEX_TIMED_NP类型动作相同。这样就保证当不允许多次加锁时不会出现最简单情况下的死锁。
4.PTHREAD_MUTEX_ADAPTIVE_NP,适应锁,动作最简单的锁类型,仅等待解锁后重新竞争。

  • 锁销毁
    int pthread_mutex_destroy(pthread_mutex_t *mutex);
  • 加锁
    int pthread_mutex_lock(pthread_mutex_t *mutex);
  • 解锁
    int pthread_mutex_unlock(pthread_mutex_t *mutex);
  • 尝试加锁(被占据时返回EBUSY而不是挂起等待)
    int pthread_mutex_trylock(pthread_mutex_t *mutex);
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 多线程系列文章源码头文件内容: #include #include #include 作为程序员,就是要减少重复劳...
    batbattle阅读 970评论 0 1
  • 转自:Youtherhttps://www.cnblogs.com/youtherhome/archive/201...
    njukay阅读 1,631评论 0 52
  • Linux下提供了多种方式来处理线程同步,最常用的是互斥锁、条件变量和信号量。 Linux线程同步-----互斥锁...
    什锦甜阅读 487评论 0 1
  • linux线程同步 信号灯:与互斥锁和条件变量的主要不同在于"灯"的概念,灯亮则意味着资源可用,灯灭则意味着不可用...
    鲍陈飞阅读 711评论 0 2
  • 线程基础 线程是进程的一个执行单元,执行一段程序片段,线程共享全局变量;线程的查看可以使用命令或者文件来进行查看;...
    秋风弄影阅读 762评论 0 0