C语言——多线程基础(pthread)

04-06 1187阅读

目录

1. 线程的定义以及线程的创建

C语言——多线程基础(pthread)

1.1 线程和进程的概念

1.2 使用pthread_create()函数创建进程

2.?使用pthread_join()等待线程结束

2.1 使用pthread_join()等待线程结束

2.1 使用pthread_join()得到线程函数的返回值


1. 线程的定义以及线程的创建

1.1 线程和进程的概念

线程:进程中的一个实体,是CPU调度和分派的基本单位。线程自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源(如程序计数器、一组寄存器和栈),但它可以与同属一个进程的其他线程共享进程所拥有的全部资源。一个线程可以创建和撤销另一个线程;同一个进程中的多个线程之间可以并发执行。线程在运行中呈现间断性。(以上来自《计算机四级教程——操作系统原理》)

谈到线程,就有必要说说进程的定义:进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,进程是系统进行资源分配和调度的一个独立单位。(以上来自《计算机四级教程——操作系统原理》)

进程的定义有点绕口,我们看看进程由什么组成:程序、数据和进程控制块。其中程序,对应进程定义中“具有一定独立功能的程序”,但是进程除了程序本身,还需要有数据(可以理解为资源),以及,进程控制块。数据和进程控制块是程序运行时必不可少的资源,程序依赖这些资源进行相应的活动,就是我们说的**“进程”**了。

进程的两个基本属性:

  • 进程是一个可拥有资源的独立单位;
  • 进程是一个可以独立调度和分派的基本单位。

    线程建立之初,就是为了将进程的上述两个属性分开,线程构成了**“CPU调度和分派的基本单位”,这样一个进程中可以有很多线程**,操作系统对线程进行调度和分派,可以更好地实现进程的并打执行;同时同一个进程下的线程可以共享该进程的全部资源,可以满足同一个进程下不同线程对进程资源的访问。线程的出现,巧妙地将进程的两个属性分开,使得进程可以更好地处理并行执行的需求。

    1.2 使用pthread_create()函数创建进程

    pthread_create()函数的声明如下:

    #include //需要添加pthread.h头文件
    int pthread_create(
                     pthread_t *restrict tidp,   //指向线程标识符的指针,用pthread_t创建
                     const pthread_attr_t *restrict attr,  //设置线程属性,默认为NULL
                     void *(*start_rtn)(void *), //线程运行函数的起始地址
                     void *restrict arg //线程运行函数的起始地址,默认为NULL
                      );
    

    基本的创建一个线程的程序如下:

    #include 
    #include 
    #include 
    void* ptintf_hello_world(void* tid);
    int main(void){
        pthread_t thread;
        int status,i=10;
        printf("Main here. Creating thread %d
    ",i);
        status=pthread_create(&thread,NULL,ptintf_hello_world,(void*)i);
        
        pthread_join(thread,NULL);  //pthread_join函数以阻塞的方式等待指定的线程结束;如果线程已经结束,函数会立即返回,并且指定的线程必须是joinable的 
        	
        if(status!=0){
            printf("pthread_create returned error code %d
    ",status);
        	exit(-1);
    	}
    	exit(0);
    }
    void* ptintf_hello_world(void* tid){
    	printf("Hello world %d.
    ",tid);
    	exit(0);
    }
    

    2.使用pthread_join()等待线程结束

    2.1 使用pthread_join()等待线程结束

    我们先看看下面的程序:

    #include 
    #include 
    #include 
    #define NUMBER_OF_THREADS 10
    void* ptintf_hello_world(void* tid);
    int main(void){
        pthread_t threads[NUMBER_OF_THREADS];
        int status,i;
        for(i=0;i

VPS购买请点击我

文章版权声明:除非注明,否则均为主机测评原创文章,转载或复制请以超链接形式并注明出处。

目录[+]