子进程 父进程 子线程 父线程之间的关系

子进程和父进程

在父进程中通过fork()函数可以创建子进程,如果返回值==0,为子进程;否则是为父进程。子进程得到的除了代码段是与父进程共享以外,其他所有的都是父进程的一个副本,子进程的所有资源都继承父进程,得到父进程资源的副本,但是二者并不共享地址空间。两个是单独的进程,继承了以后二者就没有什么关联,子进程单独运行。采用写时复制技术。

关于文件描述符:继承父进程的文件描述符时,相当于调用了dup函数,父子进程共享文件表项,即共同操作同一个文件,一个进程修改了文件,另一个进程也知道此文件被修改。

父进程通过wait()和waitpid()函数可以监控子进程。

守护进程创建及详解deamon 、 systemd 、自定义开机自启动

子线程和父线程

join()

join()函数是一个等待线程完成函数,主线程需要等待子线程运行结束了才可以结束。当构造线程时,入口函数的参数类型即使参数类型是引用,但是在线程中还是作为值传递。

复制代码
#include <iostream>
#include <thread>
using namespace std;

void func()
{
  for(int i = -10; i > -20; i--)
  {
    cout << "from func():" << i << endl;
  }
}

int main() //主线程
{
  cout << "mian()" << endl;
  cout << "mian()" << endl;
  cout << "mian()" << endl;
  thread t(func); //子线程
  t.join(); //等待子线程结束后才进入主线程
  return 0;
}



#include <iostream>
#include <thread>
using namespace std;

void func()
{
  for(int i = -10; i > -20; i--)
  {
    cout << "from func():" << i << endl;
  }
}

int main() //主线程
{
  thread t(func); //子线程
  cout << "mian()" << endl;
  cout << "mian()" << endl;
  cout << "mian()" << endl;
  t.join(); //等待子线程结束后才进入主线程
  return 0;
}
复制代码

 

复制代码
#include <iostream>
#include <thread>
using namespace std;

void func()
{
  for(int i = -10; i > -20; i--)
  {
    cout << "from func():" << i << endl;
  }
}

int main() //主线程
{
  thread t(func); //子线程
  t.join(); //等待子线程结束后才进入主线程
  cout << "mian()" << endl;
  cout << "mian()" << endl;
  cout << "mian()" << endl;
  return 0;
}
复制代码

 

 

detach()函数
称为分离线程函数,使用detach()函数会让线程在后台运行,即说明主线程不会等待子线程运行结束才结束
通常称分离线程为守护线程(daemon threads),UNIX中守护线程是指,没有任何显式的用户接口,并在后台运行的线程。这种线程的特点就是长时间运行;线程的生命周期可能会从某一个应用起始到结束,可能会在后台监视文件系统,还有可能对缓存进行清理,亦或对数据结构进行优化。另一方面,分离线程的另一方面只能确定线程什么时候结束,发后即忘(fire andforget)的任务就使用到线程的这种方式。

当构造线程时,入口函数的参数类型即使参数类型是引用,但是在线程中还是作为值传递。

 

复制代码
#include <iostream>
#include <thread>
using namespace std;

void func()
{
  for(int i = -10; i > -20; i--)
  {
    cout << "from func():" << i << endl;
  }
}

int main() //主线程
{
  cout << "mian()" << endl;
  cout << "mian()" << endl;
  cout << "mian()" << endl;
  thread t(func); //子线程
  t.detach(); //分离子线程
  return 0;
}
复制代码

 

 

 

 资料:

https://blog.csdn.net/qq_30242987/article/details/104579854

https://www.cnblogs.com/f-ck-need-u/p/7058920.html

join和detach

https://blog.csdn.net/qq_33001647/article/details/89761733

守护进程

 

posted @   小海哥哥de  阅读(2275)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
点击右上角即可分享
微信分享提示