zoukankan      html  css  js  c++  java
  • pthread_create

    1函数简介
    
    头文件
    #include<pthread.h>
    函数声明
    intpthread_create(pthread_t*tidp,constpthread_attr_t*attr,
    (void*)(*start_rtn)(void*),void*arg);
    
    返回值
    
    若线程创建成功,则返回0。若线程创建失败,则返回出错编号,并且*thread中的内容是未定义的。[1] 
    返回成功时,由tidp指向的内存单元被设置为新创建线程的线程ID。attr参数用于指定各种不同的线程属性。
    新创建的线程从start_rtn函数的地址开始运行,该函数只有一个万能指针参数arg,如果需要向start_rtn函
    数传递的参数不止一个,那么需要把这些参数放到一个结构中,然后把这个结构的地址作为arg的参数传入。
    linux下用C语言开发多线程程序,Linux系统下的多线程遵循POSIX线程接口,称为pthread。
    由 restrict 修饰的指针是最初唯一对指针所指向的对象进行存取的方法,仅当第二个指针基于第一个时,
    才能对对象进行存取。对对象的存取都限定于基于由 restrict 修饰的指针表达式中。 由 restrict 修饰的
    指针主要用于函数形参,或指向由 malloc() 分配的内存空间。restrict 数据类型不改变程序的语义。 编译
    器能通过作出 restrict 修饰的指针是存取对象的唯一方法的假设,更好地优化某些类型的例程。
    参数
    
    第一个参数为指向线程标识符的指针。
    第二个参数用来设置线程属性。
    第三个参数是线程运行函数的起始地址。
    最后一个参数是运行函数的参数。
    注意事项
    
    因为pthread并非Linux系统的默认库,而是POSIX线程库。在Linux中将其作为一个库来使用,因此加上 -lpthread
    (或-pthread)以显式链接该库。函数在执行错误时的错误信息将作为返回值返回,并不修改系统全局变量errno,
    当然也无法使用perror()打印错误信息。
    2示例
    编辑
    
    输出线程标识符
    
    #include <stdio.h>
    #include <stdlib.h>
    #include <pthread.h>
    #include <unistd.h>
    #include <string.h>
     
    void printids(const char *s)
    {
        pid_t pid;
        pthread_t tid;
        pid = getpid();
        tid = pthread_self();
        printf("%s pid %u tid %u (0x%x)
    ", s, (unsigned int) pid,
                (unsigned int) tid, (unsigned int) tid);
    }
     
    void *thr_fn(void *arg)
    {
        printids("new thread: ");
        return NULL;
    }
     
    int main(void)
    {
        int err;
        pthread_t ntid;
        err = pthread_create(&ntid, NULL, thr_fn, NULL);
        if (err != 0)
            printf("can't create thread: %s
    ", strerror(err));
        printids("main thread:");
        pthread_join(ntid,NULL);
        return EXIT_SUCCESS;
    }
    $ gcc main.c -o main -std=c99 -pthread
    $ ./main
    main thread: pid 13073 tid 3077572816 (0xb77008d0)
    new thread: pid 13073 tid 3077569392 (0xb76ffb70)
    简单的线程程序
    
    #include <stdio.h>
    #include <stdlib.h>
    #include <pthread.h>
    #include <unistd.h>
     
    #define    NUM_THREADS     8
     
    void *PrintHello(void *args)
    {
        int thread_arg;
        sleep(1);
        thread_arg = (int)args;
        printf("Hello from thread %d
    ", thread_arg);
        return NULL;
    }
     
    int main(void)
    {
        int rc,t;
        pthread_t thread[NUM_THREADS];
     
        for( t = 0; t < NUM_THREADS; t++)
        {
            printf("Creating thread %d
    ", t);
            rc = pthread_create(&thread[t], NULL, PrintHello, (void *)t);
            if (rc)
            {
                printf("ERROR; return code is %d
    ", rc);
                return EXIT_FAILURE;
            }
        }
        for( t = 0; t < NUM_THREADS; t++)
            pthread_join(thread[t], NULL);
        return EXIT_SUCCESS;
    }
    $ gcc thread_test.c -o thread_test -std=c99 -pthread
    $ ./thread_test
    Creating thread 0
    Creating thread 1
    Creating thread 2
    Creating thread 3
    Creating thread 4
    Creating thread 5
    Creating thread 6
    Creating thread 7
    Hello from thread 1
    Hello from thread 2
    Hello from thread 3
    Hello from thread 4
    Hello from thread 5
    Hello from thread 6
    Hello from thread 7
    Hello from thread 0
     
  • 相关阅读:
    SQL Server 2005中NTEXT与NVARCHAR(MAX)
    WiX安装选项开始菜单项
    Linq to SQL 查询Tips
    WCF的Message Logging 和Tracing
    Publish Server Performance Monitors with MsChart
    Pushing Data to a Silverlight Client with a WCF Duplex Service
    IronPython 2.0 发布了
    设置系统环境变量立即生效的VBS脚本
    微软网络数据包分析工具 Microsoft Network Monitor 3.2
    SQL Server 2005最新Service Pack 3
  • 原文地址:https://www.cnblogs.com/zendu/p/4991072.html
Copyright © 2011-2022 走看看