GNU/Linux >> Tutoriales Linux >  >> Linux

Específicamente, ¿cómo maneja fork() la memoria asignada dinámicamente desde malloc() en Linux?

Cada página que se asigna para el proceso (ya sea una página de memoria virtual que tiene la pila o el montón) se copia para que el proceso bifurcado pueda acceder a ella.

En realidad, no se copia desde el principio, se establece en Copiar en escritura, lo que significa que una vez que uno de los procesos (principal o secundario) intenta modificar una página, se copia para que no se dañen entre sí. y aún tener todos los datos desde el punto de fork() accesibles para ellos.

Por ejemplo, las páginas de códigos, aquellas a las que se asignó el ejecutable real en la memoria, generalmente son de solo lectura y, por lo tanto, se reutilizan entre todos los procesos bifurcados; no se volverán a copiar, ya que nadie escribe allí, solo lee, y así nunca será necesaria la copia en escritura.

Hay más información disponible aquí y aquí.


Después de una bifurcación, el hijo es completamente independiente del padre, pero puede heredar ciertas cosas que son copias del padre. En el caso del montón, el hijo conceptualmente tendrá una copia del montón de los padres en el momento de la bifurcación. Sin embargo, las modificaciones al encabezado en el espacio de dirección del niño solo modificarán la copia del niño (por ejemplo, a través de copia en escritura).

En cuanto a la documentación:he notado que la documentación generalmente indica que todo se copia, excepto para bla, bla, bla.


La respuesta corta es 'sucio al escribir'; la respuesta más larga es... mucho más larga.

Pero para todos los propósitos y propósitos, el modelo de trabajo que en el nivel C es seguro asumir es que justo después de la bifurcación () los dos procesos son absolutamente idénticos, es decir, el niño obtiene una copia exacta al 100% (pero por un poquito bit alrededor del valor de retorno de fork()) - y luego comienza a divergir a medida que cada lado modifica su memoria, pila y montones.

Por lo tanto, su conclusión está un poco equivocada:el niño comienza con los mismos datos que el padre copiado en su propio espacio, luego los modifica y los ve como modificados, mientras que el padre continúa con su propia copia.

En realidad, las cosas son un poco más complejas, ya que intenta evitar una copia completa haciendo algo sucio; evitando copiar hasta que sea necesario.

Dw.


Linux
  1. ¿Cómo funciona internamente copy_from_user del kernel de Linux?

  2. cómo verificar el tamaño del montón asignado para jvm por linux

  3. ¿Cómo acceder a direcciones físicas desde el espacio de usuario en Linux?

  4. ¿Cómo puedo reservar un bloque de memoria del kernel de Linux?

  5. ¿Cómo maneja copy-on-write en fork() múltiples bifurcaciones?

Cómo acceder a las particiones de Linux desde Windows 10

Cómo borrar la memoria de intercambio en Linux

Cómo quitar un comando del historial en Linux

Cómo instalar software desde la fuente en Linux

Cómo quitar (^M) caracteres de un archivo en Linux

¿Cómo funciona el intercambio de memoria en Linux?