• C语言中的多线程编程


    #include<stdio.h>

    #define NUM 6
    int main()
    {
        void print_msg(char*);
        print_msg("hello,");
        print_msg("world!");
    }
    void print_msg(char* m)
    {
        int i;
        for(i=0;i<NUM;i++)
        {
            printf("%s",m);
            fflush(stdout);
            sleep(1);
        }
    }
    下图反映了程序的执行流程:
    程序执行路线
    执行结果:
    hello,hello,hello,hello,hello,hello,world!world!world!world!world!world!
     
    那么如果想同时执行两个对于print_msg函数的调用,就想建立两个新的进程一样,那该怎么办?这种思想清楚的体现在下图:
    多线程版本的执行路线
    那么怎么才能达到这种效果呢?
     
     
    以下两个函数都包含在头文件pthread.h中
      我们可以使用函数pthread_create创建一个新的线程:
    函数原型:
      int pthread_create( pthread_t   *thread,   pthread_attr_t *attr,    void   *(*func),   void   *arg);
    参数:      thread     指向pthread_t类型变量的指针,  typedef unsigned long int pthread_t, pthread_t用于声明线程ID
                   attr         指向pthread_attr_t类型变量的指针,或者为NULL
                   func        指向新线程所运行函数的指针
                  arg          传递给func的参数
    返回值      0            成功返回
                  errcode    错误
     
      我们可以使用函数pthread_join等待某进程结束:
    函数原型:
      int pthread_join(pthread_t  thread, void **  retval);
    参数:     thread         所等待的进程
                  retval          指向某存储线程返回值的变量
    返回值:  0                 成功返回
                 errorcode     错误
    #include<stdio.h>
    #include<pthread.h>
    #define NUM 6
    int main()
    {
        void print_msg(void*);
       
        pthread_t t1,t2;
        pthread_create(&t1,NULL,print_msg,(void *)"hello,");
        pthread_create(&t2,NULL,print_msg,(void *)"world!\n");
       
        pthread_join(t1,NULL);
        pthread_join(t2,NULL);  
    }
    void print_msg(void* m)
    {
        char *cp=(char*)m;
        int i;
        for(i=0;i<NUM;i++)
        {
            printf("%s",m);
            fflush(stdout);
            sleep(1);
        }
    }
    运行结果:
    hello,world!
    hello,world!
    hello,world!
    hello,world!
    hello,world!
    hello,world!
     
    C语言有一次拓展了我的视野,多线程的问题还有很多,像线程间的分工合作、使用互斥机制保证线程间数据的安全共享、使用条件变量同步线程间的数据传输、传递多个参数给线程等,若读者有兴趣,可自行深入。

  • 相关阅读:
    20160402_[转]联合体(union)的使用方法及其本质
    20160402_C语言位操作符的使用
    20160402_多道程序环境中的设备抢占问题
    20160402_TCP/IP协议簇
    20160402_TCP连接的建立、终止和状态转换
    20160402_C++中的内存对齐
    20160127_Android程序完全退出的方法
    Redis持久化
    github慢!怎么办?
    mybatis-plus-generator: 自动生成entity,mapper,service,controller的代码
  • 原文地址:https://www.cnblogs.com/renyuan/p/2789139.html
Copyright © 2020-2023  润新知