Unix/Linux C/C++编程:mutex变量的创建与销毁

需积分: 48 1 下载量 189 浏览量 更新于2024-08-13 收藏 4.7MB PPT 举报
本文主要介绍了在Unix/Linux环境下,C/C++编程中涉及到的互斥锁(mutex)变量的创建与销毁函数,以及相关的操作系统和编程基础知识。内容涵盖Unix/Linux操作系统的历史、主要版本及其衍生物,以及多线程编程中的关键概念。 在Unix/Linux操作系统中,多线程编程是实现并发执行的重要手段,而互斥锁(mutex)是确保线程安全的关键工具。`pthread_mutex_init`函数用于初始化一个互斥锁,它的原型为: ```c int pthread_mutex_init(pthread_mutex_t *mutex, const pthread_mutexattr_t *attr); ``` 这个函数接受两个参数,`mutex`是互斥锁的指针,`attr`是互斥锁属性的指针,可以用来设置互斥锁的特定属性,如是否为递归锁等。如果不设置特殊属性,`attr`可以传入NULL。 当不再需要互斥锁时,应使用`pthread_mutex_destroy`来释放资源: ```c int pthread_mutex_destroy(pthread_mutex_t *mutex); ``` 此函数将释放由`mutex`指向的互斥锁,避免内存泄漏。 此外,`pthread_mutexattr_init`和`pthread_mutexattr_destroy`分别用于初始化和销毁互斥锁属性对象: ```c int pthread_mutexattr_init(pthread_mutexattr_t *attr); int pthread_mutexattr_destroy(pthread_mutexattr_t *attr); ``` 这两个函数帮助开发者管理和配置互斥锁的属性。 除了这些具体的编程技术,课程还涉及到了Unix/Linux操作系统的各个方面,包括其历史背景、主要派生版本如System V、Berkley和Hybrid,以及它们各自的代表操作系统,如AIX、Solaris、FreeBSD、NetBSD、OpenBSD、MacOS X和Linux等。Linux作为一种开源的Unix-like操作系统,已经广泛应用于各种设备,从服务器到嵌入式系统。 课程内容还包括了GNU编译工具GCC和GNuC,这些都是开发Unix/Linux软件的重要工具。内存管理、文件I/O、进程管理、信号处理、进程间通信(IPC)和网络通信也是学习的重点。多线程编程是进程间通信的一种方式,通过互斥锁等同步机制确保多个线程在共享数据时的安全性。 这门课程全面地涵盖了Unix/Linux系统编程的基础知识,对于想要深入理解操作系统并进行系统级编程的开发者来说,是非常有价值的资源。
2023-07-15 上传

注释下段代码void put(struct prodcons * b, int data) { pthread_mutex_lock(&b->lock);//上锁 /*等待缓冲区非满*/ if (b->writepos == 0){ printf("第十七个数,wait for not full\n"); pthread_cond_signal(&b->notempty); pthread_cond_wait(&b->notfull,&b->lock); } /*写数据并且指针前移*/ b->buffer[b->writepos] = data; b->writepos++; if (b->writepos >= BUFFER_SIZE) b->writepos = 0; /*设置缓冲区非空信号*/ pthread_mutex_unlock(&b->lock); if (data == -1){ printf("最后,生产任务结束\n"); pthread_cond_signal(&b->notempty); } } /*--------------------------------------------------------*/ /*从缓冲区中读出一个整数 */ int get(struct prodcons * b) { int data; pthread_mutex_lock(&b->lock); /* 等待缓冲区非空*/ if (0 == b->readpos){ pthread_cond_signal(&b->notfull); pthread_cond_wait(&b->notempty,&b->lock); printf("wait for not empty\n"); } /* 读数据并且指针前移 */ data = b->buffer[b->readpos]; b->readpos++; if (b->readpos >= (BUFFER_SIZE)) b->readpos = 0; /* 设置缓冲区非满信号*/ pthread_mutex_unlock(&b->lock); return data; } /*--------------------------------------------------------*/ #define OVER (-1) struct prodcons buffer; /*--------------------------------------------------------*/ void * producer(void * data) { int n; for (n = 0; n <= 96; n++) { printf(" put-->%d\n", n); put(&buffer, n); } put(&buffer, OVER); printf("producer stopped!\n"); return NULL; } /*--------------------------------------------------------*/ void * consumer(void * data) { int d; while (1) { d = get(&buffer); if (d == OVER ) break; printf(" %d-->get\n", d); } printf("consumer stopped!\n"); return NULL; } /*--------------------------------------------------------*/ int main(void) { pthread_t th_a, th_b; void * retval; init(&buffer); pthread_create(&th_a, NULL, producer, 0); pthread_create(&th_b, NULL, consumer, 0); /* 等待生产者和消费者结束 */ pthread_join(th_a, &retval); pthread_join(th_b, &retval); return 0; }

2023-06-08 上传
2023-05-30 上传