Inheritance
A child process can inherit several properties and resources from its parent
process. You can also prevent a child process from inheriting properties from
its parent process. The following can be inherited:
- Open handles returned by the CreateFile function. This includes handles to files, console input buffers, console
screen buffers, named pipes, serial communication devices, and mailslots.
- Open handles to process, thread, mutex, event, semaphore, named-pipe,
anonymous-pipe, and file-mapping objects.
- Environment variables.
- The current directory.
- The console, unless the process is detached or a new console is created. A
child console process also inherits the parent's standard handles, as well as
access to the input buffer and the active screen buffer.
The child process does not inherit the following:
Inheriting Handles
To cause a handle to be inherited, you must do two things:
- Specify that the handle is to be inherited when you create, open, or duplicate
the handle.
- Specify that inheritable handles are to be inherited when you call the CreateProcess function.
This allows a child process to inherit some of its parent's handles, but not
inherit others. For example, creation functions such as
CreateProcess and
CreateFile take a security attributes argument that determines whether the handle can be
inherited. Open functions such as
OpenMutex and
OpenEvent take a handle inheritance flag that determines whether the handle can be
inherited. The
DuplicateHandle function takes a handle inheritance flag that determines whether the handle
can be inherited.
When a child process is created, the
fInheritHandles parameter of
CreateProcess determines whether the inheritable handles of the parent process are
inherited by the child process. An inherited handle refers to the same object in the
child process as it does in the parent process. It also has the same value and
access privileges. Therefore, when one process changes the state of the object,
the change affects both processes. To use a handle, the child process must
retrieve the handle value and "know" the object to which it refers. Usually, the
parent process communicates this information to the child process through its
command line, environment block, or some form of
interprocess communication.
The
DuplicateHandle function is useful if a process has an inheritable open handle that you do
not want to be inherited by the child process. In this case, use
DuplicateHandle to open a duplicate of the handle that cannot be inherited, then use the
CloseHandle function to close the inheritable handle. You can also use the
DuplicateHandle function to open an inheritable duplicate of a handle that cannot be
inherited.
Inheriting Environment Variables
A child process inherits the environment variables of its parent process by
default. However,
CreateProcess enables the parent process to specify a different block of environment
variables. For more information, see
Environment Variables.
Inheriting the Current Directory
The
GetCurrentDirectory function retrieves the current directory of the calling process. A child
process inherits the current directory of its parent process by default. However,
CreateProcess enables the parent process to specify a different current directory for the
child process. To change the current directory of the calling process, use the
SetCurrentDirectory function.
- Software for developers
-
Delphi Components
.Net Components
Software for Android Developers
- More information resources
-
MegaDetailed.Net
Unix Manual Pages
Delphi Examples
- Databases for Amazon shops developers
-
Amazon Categories Database
Browse Nodes Database