当前位置: 首页 > news >正文

多线程和线程同步

多线程在项目开发中使用频率高,使用多线程能够提高程序的并发性

提高程序的并发性:1.多线程,对系统资源的消耗更小一些

                                2.多进程

系统的cpu资源有线,cpu时间片被分好后,由系统进行调度,每个线程在执行的时候都需要抢这个cpu的时间片。如果抢到了,就执行,如果没抢到,就处于一个就绪态,就绪态的线程没有cpu的使用权 ,抢到cpu的时间片后,就处于运行态

linux里的多线程

线程概述

线程是轻量级的进程(LWP:light weight process),在Linux环境下线程的本质仍是进程。在计算机上运行的程序是一组指令及指令参数的组合,指令按照既定的逻辑控制计算机运行。操作系统会以进程为单位,分配系统资源,可以这样理解,进程是资源分配的最小单位,线程是操作系统调度执行的最小单位。

先从概念上了解一下线程和进程之间的区别:

进程有自己独立的地址空间, 多个线程共用同一个地址空间

线程更加节省系统资源, 效率不仅可以保持的, 而且能够更高
在一个地址空间中多个线程独享: 每个线程都有属于自己的栈区, 寄存器(内核中管理的)
在一个地址空间中多个线程共享: 代码段, 堆区, 全局数据区, 打开的文件(文件描述符表)都是线程共享的
线程是程序的最小执行单位, 进程是操作系统中最小的资源分配单位

每个进程对应一个虚拟地址空间,一个进程只能抢一个CPU时间片
一个地址空间中可以划分出多个线程, 在有效的资源基础上, 能够抢更多的CPU时间片

在处理多任务程序的时候使用多线程比使用多进程要更有优势,但是线程并不是越多越好,如何控制线程的个数呢?

文件IO操作:文件IO对CPU是使用率不高, 因此可以分时复用CPU时间片, 线程的个数 = 2 * CPU核心数 (效率最高)

处理复杂的算法(主要是CPU进行运算, 压力大),线程的个数 = CPU的核心数 (效率最高)

2.创建线程
只要是线程都有唯一一个线程id,id类型为pthread_t

pthread_t pthread_self(void);    // 返回当前线程的线程ID

在一个进程中调用线程创建函数,就可得到一个子线程,和进程不同,需要给每一个创建出的线程指定一个处理函数,否则这个线程无法工作。

#include <pthread.h>
int pthread_create(pthread_t *thread, const pthread_attr_t *attr,
                   void *(*start_routine) (void *), void *arg);
// Compile and link with -pthread, 线程库的名字叫pthread, 全名: libpthread.so libptread.a

pthread_t *thread传出参数

const pthread_attr_t *attr,线程属性

void *(*start_routine) (void *)函数指针,做会调用的,指针所指向的函数,就是在子线程里要执行的任务

void *arg任务函数的参数

回调函数,是由线程去调用的,而不是由程序员去调用的,因此程序员只需要把回调函数的任务写出来

2.2 创建线程
下面是创建线程的示例代码,在创建过程中一定要保证编写的线程函数与规定的函数指针类

型一致:void *(*start_routine) (void *):

// pthread_create.c 
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <pthread.h>// 子线程的处理代码
void* working(void* arg)
{printf("我是子线程, 线程ID: %ld\n", pthread_self());for(int i=0; i<9; ++i){printf("child == i: = %d\n", i);}return NULL;
}int main()
{// 1. 创建一个子线程pthread_t tid;pthread_create(&tid, NULL, working, NULL);printf("子线程创建成功, 线程ID: %ld\n", tid);// 2. 子线程不会执行下边的代码, 主线程执行printf("我是主线程, 线程ID: %ld\n", pthread_self());for(int i=0; i<3; ++i){printf("i = %d\n", i);}// 休息, 休息一会儿...// sleep(1);return 0;
}

3. 线程退出
在编写多线程程序的时候,如果想要让线程退出,但是不会导致虚拟地址空

相关文章:

  • Pandas取代Excel?
  • 交换排序——快速排序
  • opencv 图像的旋转
  • mysql的函数(第一期)
  • 简单线段树的讲解(一点点的心得体会)
  • 动态规划算法:状态压缩
  • 【python编程从入门到到实践】第二章 变量和简单的数据类型
  • Nginx 文件上传大小限制及 `client_max_body_size` 最大值详解
  • Linux 系统盘制作 | 引导加载器(GRUB 为例)| mount
  • 二叉树进阶 - 二叉搜索树
  • PDF转excel+json ,vue3+SpringBoot在线演示+附带源码
  • 宇树机器狗go2—slam建图(1)点云格式
  • MLLMs for TSAD ?
  • 单例模式:懒汉式的两种优化写法
  • 编译报错 宏 _IOC_SIZEBITS,而这个宏在编译时未定义
  • Bash 中的数学运算详解
  • 【每天一个知识点】模式识别
  • 自动驾驶---决策规划之导航增强端到端
  • Jinja2模板引擎SSTI漏洞
  • 加密壳(二)将shellcode写入PE
  • 对话地铁读书人|来自法学副教授的科普:读书日也是版权日
  • 城事|2小时40分42秒,天工夺冠!全球首个人形机器人半马开跑
  • 商务部新闻发言人就美对我海事、物流和造船等领域宣布最终措施答记者问
  • 平安银行一季度净赚超140亿元降5.6%,营收降13.1%
  • 福特预期6月美国市场涨价,机构称加税让每辆汽车成本至少增加数千美元
  • 推动行业健康发展,上海发布医药企业防范商业贿赂案例手册