b2科目四模拟试题多少题驾考考爆了怎么补救
b2科目四模拟试题多少题 驾考考爆了怎么补救

pthread_create函数的详实讲解(包括向线程索引传递参数详解)

电脑杂谈  发布时间:2019-08-15 19:03:08  来源:网络整理

pthread_create 线程属性_pthread_create 线程属性_pthread 设置线程属性

pthread_create是UNIX环境创建线程索引头文档#include<pthread.h>函数声明int pthread_create(pthread_t*restrict tidp,const pthread_attr_t *restrict_attr,void*(*start_rtn)(void*),void *restrict arg);返回值若成功则前往pthread_create 线程属性,否则离开出错编号返回成功时,由tidp指向的内存单元被设置为新创建线程的线程ID。attr参数用来制定这些不同的线程属性。新创建的线程从start_rtn函数的地址开始运行,该字段只有一个万能指针参数arg,如果需要向start_rtn函数传递的取值不止一个,那么需要把它们取值放到一个结构中,然后把这个结构的地址也是arg的取值传入。linux下用C开发多线程程序,Linux系统下的多线程遵循POSIX线程接口pthread_create 线程属性,称为pthread。由 restrict 修饰的分针是最初唯一对时钟所指向的对象进行存取的原理,仅当第二个指针基于第一个时,才能对对象进行存取。

对对象的存取都限定于基于由 restrict 修饰的分针表达式中。 由 restrict 修饰的分针主要用来取值形参,或指向由 malloc() 分配的内存空间。restrict 数据类型不改变流程的短语。编译器能通过做出 restrict 修饰的分针是存取对象的惟一办法的计算,更好地优化这些类型的源码。参数第一个参数为指向线程标识符的分针。第二个参数用于增设线程属性。第三个参数是线程运行函数的起始地址。最后一个参数是运行函数的取值。另外,在编译时提醒加上-lpthread参数,以读取静态链接库。因为pthread并非Linux系统的默认库图示打印线程 IDs#include <pthread.h>#include <stdlib.h>#include <stdio.h>#include <unistd.h>#include <string.h>pthread_t ntid;void printids(const char *s){pid_t pid;pthread_t tid;pid = getpid();tid = pthread_self();printf("%s pid %u tid %u (0x%x)\n", s,(unsigned int)pid, (unsigned int)tid, (unsigned int)tid);} void *thr_fn(void *arg){printids("new thread: ");return((void *));}int main(void){int err;err = pthread_create(&ntid, NULL, thr_fn, NULL);if (err != )printf("can't create thread: %s\n", strerror(err));printids("main thread:");sleep(1);exit();}$ gcc main.c -lpthread

$ ./a.out

向线程索引传递参数详解:

向线程索引传递参数分为两种:

(1)线程索引只有一个参数的现象:直接定义一个变量通过使用传给线程索引。

例子:

#include <iostream>

#include <pthread.h>

pthread_create 线程属性_pthread_create 线程属性_pthread 设置线程属性

using namespace std;

pthread_t thread;

void fn(void *arg)

{

int i = *(int *)arg;

cout<<"i = "<<i<<endl;

return ((void *));

}

int main()

pthread_create 线程属性_pthread_create 线程属性_pthread 设置线程属性

{

int err1;

int i=10;

err1 = pthread_create(&thread, NULL, fn, &i);

pthread_join(thread, NULL);

}

2、线程索引有多个取值的现象:这种现象就必须申明一个结构体来涵盖一切的取值,然后在传到线程函数,具体如下:

例子:

首先定义一个结构体:

pthread 设置线程属性_pthread_create 线程属性_pthread_create 线程属性

struct parameter

{

int size,

int count;

。。。。。

。。。

};

然后在main函数将这个结构体指针,作为void *形参的实际参数传递

struct parameter arg;

pthread_create 线程属性_pthread 设置线程属性_pthread_create 线程属性

通过如下的方式来调用函数:
pthread_create(&ntid, NULL, fn,& (arg));

函数中需要定义一个parameter类型的结构指针来引用这个参数 

void fn(void *arg)

{

int i = *(int *)arg;

cout<<"i = "<<i<<endl;

return ((void *));

}

void thr_fn(void *arg)
{
       struct parameter *pstru;
       pstru = ( struct parameter *) arg;
       然后在这个函数中就可以使用指针来使用相应的变量的值了。
}


本文来自电脑杂谈,转载请注明本文网址:
http://www.pc-fly.com/a/jisuanjixue/article-119359-1.html

    相关阅读
      发表评论  请自觉遵守互联网相关的政策法规,严禁发布、暴力、反动的言论

      热点图片
      拼命载入中...