zoukankan      html  css  js  c++  java
  • 静态变量与多进程

    全局变量是静态变量,在整个程序的生命周期都存在,那么多进程能否通过全局变量(即静态变量)进行通信?

    答案是不可以

    首先我们先回顾子进程的诞生和其运行原理。

    父进程通过fork来复制出一个子进程的副本,根据原理,子进程拥有父进程的一份完整数据拷贝。

    同时由于fork时按页复制数据太耗时,于是子进程在刚被fork出来的时候,读取的其实是父进程中的内存数据(所以,这时候也可以说静态变量是共享的)

    但是, 当父子进程中的一方对静态变量(其实不只是静态变量,任何内存中的东西都是这样)进行写入操作时,就会触发写时复制机制,这个变量将在子进程中产生一个新的空间来存放,于是变量不再共享。

    所以,父进程和子进程中的变量是不可以被共享的,在程序员和进程的角度来看,每个进程的内存空间都是属于它自己的。

  • 相关阅读:
    SAMBA服务初学练习
    NFS与AutoNFS实例
    NTP服务简介
    DHCP服务简单搭建步骤
    HBase文档操作--练习篇
    Hadoop体系结构管理
    HBase表结构设计--练习篇
    HBase备份恢复练习
    MongoDB管理练习
    24_BlockingQueue接口
  • 原文地址:https://www.cnblogs.com/shenlinken/p/10210795.html
Copyright © 2011-2022 走看看