tag 标签: linux线程

相关博文
  • 热度 11
    2013-6-5 11:01
    901 次阅读|
    0 个评论
      作者:武汉华嵌嵌入式培训中心   讲师   张老师      在线程对共享相同内存操作时,就会出现多个线程对同一资源的使用,为此,需要对这些线程进行同步,以确保它们在访问共享内存的时候不会访问到无效的数值。   以下是线程的几种同步方式: 1、 互斥量。        通过使用pthread的互斥接口保护数据,确保同一时间只有一个线程访问数据。互斥量从本质上讲是一把锁,在访问共享资源前对互斥量进行加锁,在访问完成后释放互斥量上的锁。如下例所示,就是互斥量对共享数据的操作:   #include stdio.h #include pthread.h int value = 5;//共享变量 pthread_mutex_t mutex;//互斥变量 void *mythread1(); void mainshow(); int main() {     int retval;     pthread_t tid1;     retval = pthread_create(tid1,NULL,mythread1,value);//创建线程     if(retval != 0){printf(“Can not create mythread1\n”);     mainshow();     retval = pthread_join(tid1,NULL);//等待线程 mythread1结束     if(retval != 0){printf(“Can not join with mythread.\n”);     printf(“value = %d\n”,value);     return 0; } void *mythread1() {       int retval;       retval = pthread_mutex_lock(mutex);//上锁       value = value + 1;//对共享变量的操作       printf("value = %d\n",value);       retval = pthread_mutex_unlock(mutex);//解锁       pthread_exit((void *)0); }   void myshow() {       int retval;       retval = pthread_mutex_lock(mutex);//上锁       value = value + 1;//对共享变量的操作       printf(“value = %d\n”,value);       pthread_mutex_unlock(mutex);//解锁 }   2、 信号量        该信号量是 Posix 提供的基于内存的信号量,它们由应用程序分配信号量的内存空间。 如下例所示,就是信号量对共享数据的操作:   #include stdio.h #include pthread.h #include semaphore.h int value = 5; sem_t sem1,sem2; void mainshow(); void *mythread(); int main() {        int retval;        pthread_t tid;        retval = sem_init(sem1,0,0);        retval = sem_init(sem2,0,1);        retval =pthread_create(tid,NULL,mythread,NULL);        mainshow();        pthread_join(tid,NULL);          printf("value3 = %d\n",value);        return 0; }   void *mythread() {        int retval;        retval = sem_wait(sem1);        value = value + 1;        printf("value1 = %d\n",value);        retval = sem_post(sem2);        pthread_exit((void *) 0); }   void mainshow() {        int retval;        retval = sem_wait(sem2);        value = value + 1;        printf("value2 = %d\n",value);        retval = sem_post(sem1); } ------分隔线---------------------------- 上一篇:ARM异常处理小结 下一篇:Ubuntu下各网络服务器配置小结