初学Linux线程创建

线程概念

  1. 进程
    进程是资源(CPU、内存等)分配的基本单位,它是程序执行时的一个实例。
  2. 线程
    线程是一条执行路径,是程序执行时的最小单位,它是进程的一个执行流,是CPU调度和分派的基本单位,一个进程可以由很多个线程组成,线程间共享进程的所有资源,每个线程有自己的堆栈和局部变量。
    线程是一条可以执行的路径。多线程就是同时有多条执行路径在同时(并行)执行。
  3. 进程与线程的关系
    一个程序就是一个进程,而一个程序中的多个任务则被称为线程。进程是表示资源分配的基本单位,又是调度运行的基本单位
    一个线程只能属于一个进程,而一个进程可以有多个线程,但至少有一个线程。线程是操作系统可识别的最小执行和调度单位。

线程正常终止的方法:
1、return从线程函数返回。
2、通过调用函数pthread_exit使线程退出
3. 线程可以被同一进程中的其他线程取消

其他变量

pthread_t tid
线程标示符 ,用于声明线程ID。
pthread_attr_t
线程属性
1)线程具有属性,用pthread_attr_t表示,在对该结构进行处理之前必须进行初始化,在使用后需要对其去除初始化。
2)调用pthread_attr_init之后,pthread_t 结构所包含的内容就是操作系统实现支持的线程所有属性的默认值。
3)如果要去除对pthread_attr_t结构的初始化,可以调pthread_attr_destroy函数。如果pthread_attr_init实现时为属性对象分配了动态内存空间,pthread_attr_destroy还会用无效的值初始化属性对象,因此如果经pthread_attr_destroy去除初始化之pthread_attr_t结构被pthread_create函数调用,将会导致其返回错误。

typedef struct
{
       int                       detachstate;   // 线程的分离状态
       int                       schedpolicy;   // 线程调度策略
       structsched_param         schedparam;    // 线程的调度参数
       int                       inheritsched;  // 线程的继承性
       int                       scope;         // 线程的作用域
       size_t                    guardsize;     // 线程栈末尾的警戒缓冲区大小
       int                       stackaddr_set; // 线程的栈设置
       void*                     stackaddr;     // 线程栈的位置
       size_t                    stacksize;     // 线程栈的大小
} pthread_attr_t; //线程的属性

常用函数

1.pthread_create(thread,attr,start_routine,arg)
描述:创建一个新线程并使之运行起来。该函数可以在程序的任何地方调用。
参数:
thread:指向线程标识符的指针。
attr:用来设置线程属性,上面也可以用NULL,表示使用默认的属性。
start_routine:线程将会执行一次的C函数, 是线程运行函数的起始地址。
arg: 运行函数的参数,NULL表示无参数。

示例中的函数: pthread_create(&tid,&attr,runner,argv[1]);

2.atoi(const char *str)
描述:把参数 str 所指向的字符串转换为一个整数(类型为 int 型)。
库函数:#include <stdlib.h>
实例:将字符串转换成一个整数并返d回结果。参数str 以数字开头,当函数从str 中读到非数dao字字符则结束转换并将结果返回。例如,

int i = atoi( “512.0” );
i 的值为 512.

3. pthread_attr_init(pthread_attr_t *attr)
描述:初始化一个线程属性对象
库函数:#include <pthread.h>
参数:指向一个线程属性的指针
返回值:0 - 成功,非0 - 失败

pthread_attr_init (attr);

4. pthread_attr_destroy(pthread_attr_t *attr)
描述:销毁一个线程属性对象
库函数:#include <pthread.h>
参数:指向一个线程属性的指针
返回值:0 - 成功,非0 - 失败

pthread_attr_destroy(attr);

5.pthread_join (threadid,status)
描述 :用来等待一个线程的结束,即函数的调用者在等待子线程退出后才继续执行!
参数 :
thread: 线程标识符,即线程ID,标识唯一线程。
retval: 用户定义的指针,用来存储被等待线程的返回值。
返回值 : 0代表成功。 失败,返回的则是错误号。

pthread_join(tid,NULL);

6.pthread_exit (void *retval )
描述:使用函数pthread_exit退出线程,这是线程的主动行为;
原型:void pthread_exit(void *retval)
库函数:#include <pthread.h>
参数:value_ptr是函数的返回代码

pthread_exit(0);

示例

使用Pthread机制设计线程创建实验。

#include <pthread.h>
#include <stdio.h>
int sum; /* this data is shared by the thread(s) */
void *runner(void *param); /* threads call this function */
int main(int argc, char *argv[])
{
pthread_t tid; /* the thread identifier */
pthread_attr_t attr; /* set of thread attributes */
if (argc != 2) {
fprintf(stderr,"usage: a.out <integer value>\n");
return -1;
}
if (atoi(argv[1]) < 0) {
fprintf(stderr,"%d must be >= 0\n",atoi(argv[1]));
return -1;
}
/* get the default attributes */
pthread_attr_init(&attr);
/* create the thread */
pthread_create(&tid,&attr,runner,argv[1]);
/* wait for the thread to exit */
pthread_join(tid,NULL);
printf("sum = %d\n",sum);
}
/* The thread will begin control in this function */
void *runner(void *param)
{
int i, upper = atoi(param);
sum = 0;
for (i = 1; i <= upper; i++)
sum += i;
pthread_exit(0);
}

结果
正确结果如下:
在这里插入图片描述

如果注释掉 **pthread_join(tid,NULL);**错误结果如下:

也就是说:子线程还没有执行完毕,main函数已经退出,那么子线程也就退出了!

在这里插入图片描述

注意!主函数的理解

主函数int main(int argc,char *argv[])

参数:int argc为命令行参数个数,char *argv[]为命令行参数数组。这种写法,主要用在需要从命令行获取参数的功能。

argc – 即修饰命令行参数的个数(包含argv[0])
argv[ ] – 命令行输入的字符串
argv[0] --获取可执行程序的路径
argv[i] – 自己在命令行输入的字符串

函数参数详细理解请参考:https://blog.csdn.net/yh3608/article/details/79618784

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 《Linux多线程服务器编程PDF》是一本关于在Linux系统下进行多线程服务器编程的电子书。它主要讲解了如何利用Linux多线程技术来搭建高性能的服务器应用程序。 这本书首先介绍了多线程编程的基本概念和原理,包括线程创建与销毁、线程同步与互斥、线程调度等。然后,针对服务器应用开发过程中的常见问题,详细讲解了如何利用多线程解决这些问题,比如如何处理多个客户端的并发请求、如何实现高效的请求处理、如何解决资源竞争和线程安全等。 除了基础知识和问题解决方法,本书还深入探讨了多线程服务器的性能优化技巧。作者通过实例演示了如何利用线程池、异步IO和事件驱动等技术来提高服务器的并发性能和响应速度。同时,还介绍了一些常用的性能监测工具和调优方法,帮助读者找出性能瓶颈并进行优化。 阅读这本书可以帮助读者掌握Linux多线程服务器编程的核心技术,从而设计和实现高性能、稳定性好的服务器应用程序。无论是对于专业开发人员还是对于对服务器编程感兴趣的学习者来说,都是一本非常实用的参考书籍。 ### 回答2: 《Linux多线程服务器编程PDF》是一本关于如何在Linux环境下进行多线程服务器编程的书籍。这本书主要介绍了如何利用Linux操作系统的特性来实现高效的多线程服务器程序。 在这本书中,首先会介绍多线程服务器编程的基础知识,包括线程和进程的概念,以及多线程编程的优势和挑战。然后,会详细讲解如何使用Linux提供的系统调用和库函数来创建和管理线程,以及如何利用线程之间的同步和互斥机制来实现高效的并发处理。 此外,书中还会介绍如何利用Linux提供的网络编程接口来实现基于TCP/IP协议的网络通信。它将介绍如何创建和管理套接字,以及如何使用套接字进行客户端和服务器之间的通信。同时,也会介绍如何使用多线程来处理多个客户端的请求,以及如何利用线程池来优化服务器的性能。 除了介绍基本的多线程服务器编程技术之外,这本书还会介绍一些高级的主题,如如何处理并发访问共享资源的问题,如何利用信号来实现进程间的通信,以及如何使用多进程和多线程的混合编程模型。 总之,这本《Linux多线程服务器编程PDF》是一本全面而实用的指南,适合对多线程服务器编程感兴趣的读者学习和参考。通过学习这本书,读者可以了解到在Linux环境下如何编写高效且稳定的多线程服务器程序,提高应对高并发访问的能力,并为实际项目开发提供指导和支持。 ### 回答3: 《Linux多线程服务器编程》是一本介绍在Linux环境下开发多线程服务器程序的PDF电子书。本书主要内容包括多线程编程的基础知识、线程间同步与通信、线程池的设计与实现、多线程服务器的模型与架构等。这本书通过详细讲解多线程编程的原理、技巧和注意事项,帮助读者理解多线程服务器的基本概念和工作原理,掌握多线程编程的核心技术。 《Linux多线程服务器编程》首先介绍了多线程编程的基本概念和背景,包括线程的定义、线程创建与销毁、线程的同步与互斥等。然后,书中详细讲解了多线程编程中常用的同步与通信机制,如互斥量、条件变量、信号量等,以及它们的具体应用场景和用法。 接着,本书介绍了线程池的设计与实现。线程池是一种常用的服务器编程模型,可以提高服务器的性能和可扩展性。本书详细讲解了线程池的设计原理、线程池的管理与调度算法,以及线程池在实际服务器程序中的应用。通过学习线程池的设计与实现,读者可以更好地理解服务器程序的并发模型和性能优化技巧。 最后,本书介绍了多线程服务器的模型与架构。通过实际案例和代码示例,读者可以了解到多线程服务器的常用设计模式和架构思想,如单线程多路复用模型、多线程非阻塞模型等。这些模型和思想可以帮助读者设计和开发高性能、稳定可靠的多线程服务器程序。 综上所述,《Linux多线程服务器编程》是一本非常实用和全面的指南,适合对Linux服务器编程感兴趣的读者学习和参考。无论是初学者还是有一定经验的程序员,都可以通过阅读本书,全面提升自己在多线程服务器编程方面的能力和水平。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值