7.96 Mémoire partagée
7 Index des fonctions
Manuel PHP
. Introduction . Pré-requis . Installation . Configuration à l'exécution . Types de ressources . Constantes prédefinies . Exemples . shmop_close . shmop_delete ->shmop_open . shmop_read . shmop_size . shmop_write
|
7.96.10 shmop_open()
Crée ou ouvre un bloc de mémoire partagée
[ Exemples avec shmop_open ] PHP 4 >= 4.0.4
int
shmop_open (
int
key
,
string
flags
,
int
mode
,
int
size
)
shmop_open
peut créer ou ouvrir un bloc
de mémoire partagée.
shmop_open
prend 4 paramètres: la
clé, qui sera l'identifiant système pour le bloc.
Ce paramètre peut être passé comme
un décimal ou un hexadécimal. Le
deuxième paramètre est un groupe d'options :
-
"a" pour accès (utilise
IPC_EXCL
)
utilisez cette option pour ouvrir un bloc déjà existant.
-
"c" pour création (utilise
IPC_CREATE
)
utilisez cette option pour créer un nouveau bloc.
-
"w" pour accès en lecture et écriture. Utilisez
cette option lorsque vous devez accéder en lecture et
écriture à un segment de mémoire partagée.
C'est le cas le plus courant.
-
"n" crée un nouveau segment de mémoire partagée
(utilise
IPC_CREATE|IPC_EXCL
). Utilisez cette option
lorsque vous voulez créer un nouveau segment de mémoire
partagée sauf s'il en existe déjà un avec la
même option. Ceci est très pratique pour des raisons
de sécurité, pour éviter des trous de sécurité
qui exploiteraient la course aux ressources.
Le troisième paramètre est le mode, c'est à
dire les permissions que vous donnez à ce bloc. Ce sont
les mêmes que pour les fichiers. Ces permissions doivent
être passées sous forme d'octal (i.e. 0644).
Le dernier paramètre est la taille du bloc de mémoire,
en octets.
Note |
Les troisième et quatrième paramètres
doivent être passés à 0 si vous voulez ouvrir
un bloc de mémoire partagée déjà existant.
En cas de succès
shmop_open
retourne un
identifiant que vous pouvez utiliser pour accéder à
la mémoire que vous venez de créer.
|
Créer un nouveau bloc de mémoire partagée Shmop |
<?php $shm_id = shmop_open(0x0fff, "c", 0644, 100); ?>
|
Cet exemple ouvre un nouveau bloc de mémoire partagée,
dont l'identifiant est 0x0fff.
|