|
| БЕСПЛАТНАЯ ежедневная online лотерея! Выигрывай каждый день БЕСПЛАТНО! |
|
|
Sharing Files and Memory
File mapping can be used to share a file or memory between two or more processes. To share a file or memory, all of the processes must use the name or the handle of the same file-mapping object.
To share a file, the first process creates or opens a file by using the CreateFile function. Next, it creates a file-mapping object by using the CreateFileMapping function, specifying the file handle and a name for the file-mapping object. The names of event, semaphore, mutex, and file-mapping objects share the same name space. Therefore, the CreateFileMapping and OpenFileMapping functions fail if they specify a name that is in use by an object of another type.
To share memory that is not associated with a file, a process must use the CreateFileMapping function and specify (HANDLE)0xFFFFFFFF as the hfile parameter instead of an existing file handle. The corresponding file-mapping object accesses memory backed by the system paging file. You must specify a size greater than zero when you specify an hfile of (HANDLE)0xFFFFFFFF in a call to CreateFileMapping. The easiest way for other processes to obtain a handle of the file-mapping object created by the first process is to use the OpenFileMapping function and specify the object's name. This is referred to as named shared memory. If the file-mapping object does not have a name, the process must obtain a handle to it through inheritance or duplication. For more information on inheritance and duplication, see Processes and Threads and Handles and Objects.
Processes that share files or memory must create file views by using the MapViewOfFile or MapViewOfFileEx function. They must coordinate their access using semaphores, mutexes, events, or some other mutual exclusion technique. For more information, see Synchronization. A shared file-mapping object will not be destroyed until all processes that use it close their handles to it by using the CloseHandle function.
| Пригласи друзей и счет твоего мобильника всегда будет положительным! |
| Пригласи друзей и счет твоего мобильника всегда будет положительным! |
Разделение Файлов и Памяти
Файловое распределение может быть использовано, чтобы распространять файл или память между двумя или больше процессов. Для того, чтобы распространять файл или память, все процессы должны использовать имя или ручка того же самого файлового распределения объекта.
Чтобы распространять файл, первый процесс создает или открывает файл используя функцию CreateFile. Затем, это создает файловое распределение объекта используя функцию CreateFileMapping, определяющую файловую ручку и называть в честь файлового распределения объекта. Имена случая, семафора, mutex, и акции файлового распределения объектов то же пространство имени. Следовательно, CreateFileMapping и функции OpenFileMapping терпят неудачу если они определяют имя, которое используется объектом другого типа.
Чтобы распространять память, что не связан файлом, процесс должен использовать функцию CreateFileMapping и определять (HANDLE)0xFFFFFFFF как параметр hfile вместо существующей файловой ручки. Файловое распределение соответствующего объекта имеет доступ к памяти возвращался системным файлом подкачки. Вы должны определить размер больше, чем нуль когда Вы определяете hfile (HANDLE)0xFFFFFFFF на вызове на CreateFileMapping. Легчайший путь для других процессов, чтобы получать ручку файлового распределения объекта созданного первым процессом должен использовать функцию OpenFileMapping и определять объектное имя. Это называется поименованным распространившее память. Если файловое распределение объекта нет имеет имя, процесс должен получить ручку, чтобы это через наследство или дублирование. Более подробно в наследстве и дублировании, смотри Процессы и Резьбу и Ручки и Объекты.
Процессы, которые распространяют файлы или память должна создать файловые виды используя MapViewOfFile или функция MapViewOfFileEx. Они должны скоординировать свой доступ, использовавший семафоры, mutexes, события, или некоторая другая взаимная техника исключения. Более подробно, смотри Синхронизацию. Файловое распределение коллективного объекта не будет уничтожено до всех процессов, которые используют это закрывать их ручки этому используя функцию CloseHandle.
|
|
|
|
| |