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

嵌入式开发学习———Linux环境下IO进程线程学习(五)

进程

僵尸进程

僵尸进程是子进程终止后,父进程未调用wait()waitpid()回收其退出状态,导致进程描述符仍留在系统中。此时子进程称为“僵尸进程”。

#include <unistd.h>
#include <stdlib.h>
int main() {pid_t pid = fork();if (pid == 0) exit(0);  // 子进程立即退出else sleep(60);         // 父进程不回收子进程return 0;
}
孤儿进程

孤儿进程是父进程先于子进程终止,子进程被init进程(PID=1)接管。孤儿进程不会对系统造成危害。

#include <unistd.h>
#include <stdlib.h>
int main() {pid_t pid = fork();if (pid == 0) sleep(60);  // 子进程存活else exit(0);             // 父进程先退出return 0;
}
守护进程

守护进程是在后台长期运行的独立进程,通常脱离终端控制。通过fork()后让父进程退出,子进程调用setsid()创建新会话。

#include <unistd.h>
#include <stdlib.h>
int main() {pid_t pid = fork();if (pid > 0) exit(0);    // 父进程退出setsid();                // 子进程创建新会话while (1) sleep(1);      // 守护任务return 0;
}

线程

线程概念

线程是程序执行的最小单位,属于同一进程的多个线程共享内存空间,但拥有独立的栈和寄存器。相比进程,线程切换开销更小,适合并发任务。

C语言线程核心函数(POSIX标准)

pthread_create
创建新线程,执行指定函数。

int pthread_create(pthread_t *thread, const pthread_attr_t *attr, void *(*start_routine)(void*), void *arg);

read_join
阻塞当前线程,等待目标线程终止并回收资源。

int pthread_join(pthread_t thread, void **retval);

pthread_exit
终止调用线程,返回结果可通过pthread_join获取。

void pthread_exit(void *retval);

作业:

1.使用创建两个线程,一个线程拷贝文件的前一部分,另一个线程拷贝文件的后一部分

#include <myhead.h>int flatg=0;void *PrevCopy(void *arg)
{FILE *fp1=NULL,*fp2=NULL;fp1=fopen("./myfile1","r");if(fp1==NULL){printf("fp1=fopen error\n");return NULL;}fp2=fopen("./myfile2","a");if(fp2==NULL){printf("fp2=fopen error\n");return NULL;}int size=*(int*)arg;for(int i=0;i<size/2;i++){char ch;ch=fgetc(fp1);fputc(ch,fp2);}if(fclose(fp1)!=0){printf("fclose(fp1) error\n");return NULL;}if(fclose(fp2)!=0){printf("fclose(fp2) error\n");return NULL;}flatg=1;return NULL;
}void *NextCopy(void *arg)
{if(flatg==0)sleep(1);FILE *fp1=NULL,*fp2=NULL;fp1=fopen("./myfile1","r");if(fp1==NULL){printf("fp1=fopen error\n");return NULL;}fp2=fopen("./myfile2","a");if(fp2==NULL){printf("fp2=fopen error\n");return NULL;}int size=*(int*)arg;fseek(fp1,size/2,SEEK_SET);for(int i=0;i<size/2;i++){char ch;ch=fgetc(fp1);fputc(ch,fp2);}if(fclose(fp1)!=0){printf("fclose(fp1) error\n");return NULL;}if(fclose(fp2)!=0){printf("fclose(fp2) error\n");return NULL;}flatg=2;return NULL;}int main(int argc, const char *argv[])
{pthread_t thread1,thread2;FILE *fp=fopen("./myfile1","r");if(fp==NULL)ERROR_MSG("fp=fopen error");fseek(fp,0,SEEK_END);int size=ftell(fp);if(fclose(fp)!=0)ERROR_MSG("fclose(fp) error");if(pthread_create(&thread1,NULL,PrevCopy,(void*)&size)!=0){	printf("pthread_create error\n");return -1;}if(pthread_create(&thread2,NULL,NextCopy,(void*)&size)!=0){	printf("pthread_create error\n");return -1;}while(1)if(flatg==2)return 0;
}

运行结果:



2.创建两个线程,一个线程实现字符串的逆置,另一个线程打印字符串,并要求打印顺序是

一正一反交替打印 flag

eg:

hello

olleh

hello

olleh

#include <myhead.h>int flag=0;typedef struct 
{char str[100];int len;
}str,*strptr;void *TurnStr(void *arg)
{int i,j;char ch;if(flag==1)sleep(1);while(1){for(i=0,j=((strptr)arg)->len-1;i<=((strptr)arg)->len/2;i++,j--){ch=((strptr)arg)->str[i];((strptr)arg)->str[i]=((strptr)arg)->str[j];((strptr)arg)->str[j]=ch;}flag=1;sleep(1);}return NULL;
}void *PutOut(void *arg)
{if(flag==0)sleep(1);while(1){fputs(((strptr)arg)->str,stdout);putchar(10);flag=0;sleep(1);}
}int main(int argc, const char *argv[])
{pthread_t thread1,thread2;str str1;puts("输入字符:");fgets(str1.str,sizeof(str1.str),stdin);putchar(10);str1.len=strlen(str1.str);if(pthread_create(&thread1,NULL,TurnStr,(void*)&str1)!=0){	printf("pthread_create error\n");return -1;}if(pthread_create(&thread2,NULL,PutOut,(void*)&str1)!=0){	printf("pthread_create error\n");return -1;}while(1);return 0;
}

运行结果:


3.牛客网

http://www.xdnf.cn/news/1254007.html

相关文章:

  • 【软考系统架构设计师备考笔记4】 - 英语语法一篇通
  • 【感知机】感知机(perceptron)模型与几何解释
  • 并发编程常见问题排查与解决:从死锁到线程竞争的实战指南
  • word2vector细致分解(CBOW, SKIP_GRAM, 层次soft Max, 负采样)
  • 【前端开发】三. JS运算符
  • 奔图P2500NW打印机手机无线连接方法
  • JavaScript 基础语法
  • Kubernetes中无法删除一个对象,持续处于Terminating状态的解决方案
  • Linux发行版分类与Centos替代品
  • 大数据存储域——HDFS存储系统
  • 进阶向:AI聊天机器人(NLP+DeepSeek API)
  • 【感知机】感知机(perceptron)学习策略
  • Git 乱码文件处理全流程指南:从识别到彻底清除
  • WebView 中控制光标
  • VINS-Fusion+UWB辅助算法高精度实现
  • Pytest项目_day05(requests加入headers)
  • 移动端跨平台框架(支持Harmony、iOS、Android)
  • cacti
  • vue3 find 数组查找方法
  • TrustZone技术详解————这篇是AI写的包括图
  • [Oracle] SIGN()函数
  • 大数据存储域——Hive数据仓库工具
  • 第14届蓝桥杯Scratch_选拔赛_初级及中级(STEMA)真题2022年12月18日
  • 碰撞问题的分析
  • 链式数据结构
  • 基于最大似然估计的卡尔曼滤波与自适应模糊PID控制的单片机实现
  • 北京-4年功能测试2年空窗-报培训班学测开-第六十九天-投简历第一天-从兴奋到害怕
  • 【图像处理基石】浅谈3D城市生成中的数据融合技术
  • 从零开始用 Eclipse 写第一个 Java 程序:HelloWorld 全流程 + 避坑指南
  • 如何设计一个开放授权平台?