Accueil > > > UNE CLASSE POUR L'UTILISATION DE LA MÉMOIRE PARTAGÉE
UNE CLASSE POUR L'UTILISATION DE LA MÉMOIRE PARTAGÉE
Information sur la source
Description
Permet de définir par un nom une zone mémoire qui pourra être ensuite partagée entre plusieurs applications.
Source
- *!* Objet : Utilisation de la mémoire partagée pour la communication entre applications
- *!* Auteur : C.Chenavier
- *!* Version : 1.00 - 20/01/2005
- *!*
- *!* Exemple d'utilisation :
- *!*
- *!* oSharedMem = CREATEOBJECT("SharedMemory", "Nom_de_partage")
- *!* oSharedMem.Write("ceci est la chaîne à transférer")
- *!*
- *!* Application 2 :
- *!* oSharedMem = CREATEOBJECT("SharedMemory", "Nom_de_partage")
- *!* MessageBox(oSharedMem.Read())
- *!*
- *!* Note : par défaut le buffer est de 4Ko.
- *!* Pour le passer par exemple à 32K faire :
- *!* oSharedMem = CREATEOBJECT("SharedMemory", "Nom_de_partage", 32*1024)
-
- #DEFINE INVALID_HANDLE_VALUE -1
- #DEFINE PAGE_READWRITE 0x04
-
- #DEFINE SECTION_QUERY 0x0001
- #DEFINE SECTION_MAP_WRITE 0x0002
- #DEFINE SECTION_MAP_READ 0x0004
- #DEFINE SECTION_MAP_EXECUTE 0x0008
- #DEFINE SECTION_EXTEND_SIZE 0x0010
-
- #DEFINE STANDARD_RIGHTS_REQUIRED 0x000F0000
-
- #DEFINE SECTION_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED+SECTION_QUERY+;
- SECTION_MAP_WRITE + ;
- SECTION_MAP_READ + ;
- SECTION_MAP_EXECUTE + ;
- SECTION_EXTEND_SIZE)
-
- DEFINE CLASS SharedMemory AS CUSTOM
-
- hMapFile = 0
- cSharedName = ''
-
- HIDDEN Buf_Size
- Buf_Size = 4*1024
-
-
- PROCEDURE Init
- LPARAMETERS cSharedName, nSize
-
- LOCAL nLibs
- LOCAL ARRAY aLibs(1,3)
-
- THIS.Name = SYS(2015)
-
- THIS.cSharedName = IIF(EMPTY(M.cSharedName), '', M.cSharedName)
-
- M.nLibs = ADLLS(aLibs)
- IF ASCAN(aLibs,"CreateFileMapping",1,0,1,7)=0
- DECLARE INTEGER CreateFileMapping IN kernel32 ;
- INTEGER hFile, ;
- INTEGER lpAttributes, ;
- INTEGER flProtect, ;
- LONG dwMaximumSizeHi, ;
- LONG dwMaximumSizeLo, ;
- STRING lpName
-
- DECLARE INTEGER OpenFileMapping IN kernel32 ;
- INTEGER flProtect, ;
- INTEGER wInherit, ;
- STRING lpName
-
- DECLARE LONG MapViewOfFile IN kernel32 ;
- INTEGER hFileMappingObject, ;
- INTEGER dwDesiredAccess, ;
- LONG dwFileOffsetHi, ;
- LONG dwFileOffsetLo, ;
- LONG dwNumberOfBytesToMap
-
- DECLARE INTEGER UnmapViewOfFile IN kernel32;
- LONG lpBaseAddress
- ENDIF
- IF ASCAN(aLibs,"CloseHandle",1,0,1,7)=0
- DECLARE INTEGER CloseHandle IN kernel32;
- INTEGER hObject
- ENDIF
- IF NOT THIS.Open()
- THIS.New(M.nSize)
- ENDIF
- ENDPROC
-
-
- FUNCTION New
- LPARAMETERS nSize
-
- IF NOT EMPTY(M.nSize)
- THIS.Buf_Size = M.nSize
- ENDIF
-
- THIS.hMapFile = CreateFileMapping( ;
- INVALID_HANDLE_VALUE, ;
- 0, ;
- PAGE_READWRITE, ;
- 0, ;
- THIS.Buf_Size, ;
- THIS.cSharedName)
-
- RETURN (THIS.hMapFile > 0)
-
- ENDPROC
-
-
-
- FUNCTION Open
- THIS.hMapFile = OpenFileMapping( ;
- SECTION_ALL_ACCESS, ;
- 0, ;
- THIS.cSharedName)
-
- RETURN (THIS.hMapFile > 0)
-
- ENDPROC
-
-
-
- FUNCTION Read
-
- LOCAL pBuf, cString
-
- M.cString = ''
- IF THIS.hMapFile > 0
- pBuf = MapViewOfFile(THIS.hMapFile, ;
- SECTION_ALL_ACCESS, ;
- 0, 0, THIS.Buf_Size)
- IF pBuf > 0
- M.cString = SYS(2600, pBuf, THIS.Buf_Size)
- UnmapViewOfFile(pBuf)
- ENDIF
- ENDIF
-
- RETURN M.cString
- ENDPROC
-
-
-
- FUNCTION Write
-
- LPARAMETERS cString
-
- LOCAL nStringLen, pBuf, lOK
-
- IF THIS.hMapFile > 0
- M.cString = M.cString + CHR(0)
- M.nStringLen = MIN(LEN(M.cString), THIS.Buf_Size)
- pBuf = MapViewOfFile(THIS.hMapFile, ;
- SECTION_ALL_ACCESS, ;
- 0, 0, THIS.Buf_Size)
- IF pBuf > 0
- SYS(2600, pBuf, M.nStringLen, M.cString)
- UnmapViewOfFile(pBuf)
- M.lOK = .T.
- ENDIF
- ENDIF
-
- RETURN M.lOK
- ENDPROC
-
-
-
- PROCEDURE Destroy
-
- IF THIS.hMapFile > 0
- CloseHandle(THIS.hMapFile)
- ENDIF
-
- ENDPROC
-
- ENDDEFINE
*!* Objet : Utilisation de la mémoire partagée pour la communication entre applications
*!* Auteur : C.Chenavier
*!* Version : 1.00 - 20/01/2005
*!*
*!* Exemple d'utilisation :
*!*
*!* oSharedMem = CREATEOBJECT("SharedMemory", "Nom_de_partage")
*!* oSharedMem.Write("ceci est la chaîne à transférer")
*!*
*!* Application 2 :
*!* oSharedMem = CREATEOBJECT("SharedMemory", "Nom_de_partage")
*!* MessageBox(oSharedMem.Read())
*!*
*!* Note : par défaut le buffer est de 4Ko.
*!* Pour le passer par exemple à 32K faire :
*!* oSharedMem = CREATEOBJECT("SharedMemory", "Nom_de_partage", 32*1024)
#DEFINE INVALID_HANDLE_VALUE -1
#DEFINE PAGE_READWRITE 0x04
#DEFINE SECTION_QUERY 0x0001
#DEFINE SECTION_MAP_WRITE 0x0002
#DEFINE SECTION_MAP_READ 0x0004
#DEFINE SECTION_MAP_EXECUTE 0x0008
#DEFINE SECTION_EXTEND_SIZE 0x0010
#DEFINE STANDARD_RIGHTS_REQUIRED 0x000F0000
#DEFINE SECTION_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED+SECTION_QUERY+;
SECTION_MAP_WRITE + ;
SECTION_MAP_READ + ;
SECTION_MAP_EXECUTE + ;
SECTION_EXTEND_SIZE)
DEFINE CLASS SharedMemory AS CUSTOM
hMapFile = 0
cSharedName = ''
HIDDEN Buf_Size
Buf_Size = 4*1024
PROCEDURE Init
LPARAMETERS cSharedName, nSize
LOCAL nLibs
LOCAL ARRAY aLibs(1,3)
THIS.Name = SYS(2015)
THIS.cSharedName = IIF(EMPTY(M.cSharedName), '', M.cSharedName)
M.nLibs = ADLLS(aLibs)
IF ASCAN(aLibs,"CreateFileMapping",1,0,1,7)=0
DECLARE INTEGER CreateFileMapping IN kernel32 ;
INTEGER hFile, ;
INTEGER lpAttributes, ;
INTEGER flProtect, ;
LONG dwMaximumSizeHi, ;
LONG dwMaximumSizeLo, ;
STRING lpName
DECLARE INTEGER OpenFileMapping IN kernel32 ;
INTEGER flProtect, ;
INTEGER wInherit, ;
STRING lpName
DECLARE LONG MapViewOfFile IN kernel32 ;
INTEGER hFileMappingObject, ;
INTEGER dwDesiredAccess, ;
LONG dwFileOffsetHi, ;
LONG dwFileOffsetLo, ;
LONG dwNumberOfBytesToMap
DECLARE INTEGER UnmapViewOfFile IN kernel32;
LONG lpBaseAddress
ENDIF
IF ASCAN(aLibs,"CloseHandle",1,0,1,7)=0
DECLARE INTEGER CloseHandle IN kernel32;
INTEGER hObject
ENDIF
IF NOT THIS.Open()
THIS.New(M.nSize)
ENDIF
ENDPROC
FUNCTION New
LPARAMETERS nSize
IF NOT EMPTY(M.nSize)
THIS.Buf_Size = M.nSize
ENDIF
THIS.hMapFile = CreateFileMapping( ;
INVALID_HANDLE_VALUE, ;
0, ;
PAGE_READWRITE, ;
0, ;
THIS.Buf_Size, ;
THIS.cSharedName)
RETURN (THIS.hMapFile > 0)
ENDPROC
FUNCTION Open
THIS.hMapFile = OpenFileMapping( ;
SECTION_ALL_ACCESS, ;
0, ;
THIS.cSharedName)
RETURN (THIS.hMapFile > 0)
ENDPROC
FUNCTION Read
LOCAL pBuf, cString
M.cString = ''
IF THIS.hMapFile > 0
pBuf = MapViewOfFile(THIS.hMapFile, ;
SECTION_ALL_ACCESS, ;
0, 0, THIS.Buf_Size)
IF pBuf > 0
M.cString = SYS(2600, pBuf, THIS.Buf_Size)
UnmapViewOfFile(pBuf)
ENDIF
ENDIF
RETURN M.cString
ENDPROC
FUNCTION Write
LPARAMETERS cString
LOCAL nStringLen, pBuf, lOK
IF THIS.hMapFile > 0
M.cString = M.cString + CHR(0)
M.nStringLen = MIN(LEN(M.cString), THIS.Buf_Size)
pBuf = MapViewOfFile(THIS.hMapFile, ;
SECTION_ALL_ACCESS, ;
0, 0, THIS.Buf_Size)
IF pBuf > 0
SYS(2600, pBuf, M.nStringLen, M.cString)
UnmapViewOfFile(pBuf)
M.lOK = .T.
ENDIF
ENDIF
RETURN M.lOK
ENDPROC
PROCEDURE Destroy
IF THIS.hMapFile > 0
CloseHandle(THIS.hMapFile)
ENDIF
ENDPROC
ENDDEFINE
Sources du même auteur
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
mémoire tampon [ par jee0404 ]
bonjour, Je voudrais pouvoir stoker des informations programmaticilement dans la mémoire tampon. C'est comme si je ferais CTRL+C . Est-ce poss
code compléte d'une classe [ par jee0404 ]
bonjour, Je me demande si quelqu'un connaiterai le moyen de voir le code complet d'une classe qui est utiliser par défaut ? peut-on le voir ?
surcharge class et méthode [ par gregorian ]
Bonjour, J'aurais voulu savoir si il était possible de surcharger une classe et une méthode en visual fox proExemple: En vb.net, on peut écrire le con
Message d'erreur mémoire insuffisante sous Foxpro 8.0 [ par sebfox69 ]
Bonjour,J'ai developpé une application sous Visual Foxpro 8.0 et j'ai un problème lié à la mémoire .A l'intérieur de mes programmes, j'ai des requêtes
Mémoire insuffisante [ par pierreprj ]
Bonjour,L'un d'entre vous aura peut être la solution à mon problème :Je suis en vfp6quand je demande de genérer éxécutable j'obtiens une fenêtre avec
|
Derniers Blogs
[MIX 2010] - TELECHARGEZ INTERNET EXPLORER 9 EN PREVIEW ![MIX 2010] - TELECHARGEZ INTERNET EXPLORER 9 EN PREVIEW ! par redo
La Preview de Windows Explorer 9 est maintenant disponible à l'adresse suivante : http://ie.microsoft.com/testdrive/ Cette version ne nécessite pas un redémarrage de votre machine pour être exploitée . Cette version est fonctionnelle mais reste cependant ...
Cliquez pour lire la suite de l'article par redo [MIX 2010] - KEYNOTE DAY 2 ONLINE : WINDOWS INTERNET EXPLORER 9, JQUERY, ODATA ET DALLAS CTP2 ![MIX 2010] - KEYNOTE DAY 2 ONLINE : WINDOWS INTERNET EXPLORER 9, JQUERY, ODATA ET DALLAS CTP2 ! par redo
Dans la lignée du premier keynote, retrouvez la vidéo du second keynote en ligne : Visionnez la vidéo à l'url suivante : http://www.microsoft.com/presspass/events/mix/VideoGallery.aspx Vous y retrouverez ainsi les speakers Scott Guthrie, Dean Hachamovitch...
Cliquez pour lire la suite de l'article par redo [MIX 2010] - RETOUR D'EXPéRIENCE DéVELOPPEMENT SEESMIC SUR WINDOWS PHONE 7[MIX 2010] - RETOUR D'EXPéRIENCE DéVELOPPEMENT SEESMIC SUR WINDOWS PHONE 7 par redo
En avant première, Loic le retour d'expérience de Loïc Le Meur du portage de l'application http://seesmic.com/ sur plateforme Windows Phone 7 . c'était d'ailleurs une des rares opportunités de tester, voir toucher le nouveau device . voyez par vous-même :...
Cliquez pour lire la suite de l'article par redo [MIX 2010] - LE KEYNOTE DAY 1 DISPONIBLE ONLINE ![MIX 2010] - LE KEYNOTE DAY 1 DISPONIBLE ONLINE ! par redo
Si tout comme moi, vous avez manqué de peu le premier keynote du Microsoft Mix 2010, je vous invite à prendre deux heure et le consulter ci-dessous . Visionnez le Keynote à l'url suivante : http://www.microsoft.com/Presspass/events/mix/videoGallery.aspx?c...
Cliquez pour lire la suite de l'article par redo VISUAL STUDIO TALK SHOW: EF4VISUAL STUDIO TALK SHOW: EF4 par Matthieu MEZIL
La semaine dernière, j'étais à Montréal pour y animer des conférences sur Entity Framework. J'en ai profité pour enregister un podcast Visual Studio Talk Show que vous pouvez retrouver ici ....(read more) ...
Cliquez pour lire la suite de l'article par Matthieu MEZIL
Forum
RE : TXT VERS DBFRE : TXT VERS DBF par MichelAtoutFox
Cliquez pour lire la suite par MichelAtoutFox RE : TXT VERS DBFRE : TXT VERS DBF par MichelAtoutFox
Cliquez pour lire la suite par MichelAtoutFox
Logiciels
Xilisoft Convertisseur Vidéo Ultimate (5.1.39.0305)XILISOFT CONVERTISSEUR VIDéO ULTIMATE (5.1.39.0305)Xilisoft Convertisseur Vidéo Ultimate est un outil puissant de conversion vidéo, facile à utilise... Cliquez pour télécharger Xilisoft Convertisseur Vidéo Ultimate Xilisoft DVD Ripper Ultimate (5.0.64.0304)XILISOFT DVD RIPPER ULTIMATE (5.0.64.0304)Xilisoft DVD Ripper Ultimate est un logiciel excellent pour copier et convertir DVD vers presque ... Cliquez pour télécharger Xilisoft DVD Ripper Ultimate Rigs of Rods (63.3)RIGS OF RODS (63.3)c'est un jeu de multi-simulation camions,autobus voitures, avions, bateaux, hélicoptère avec défo... Cliquez pour télécharger Rigs of Rods Konvertor (4.00)KONVERTOR (4.00)Le logiciel est un gestionnaire multimedia affichant, jouant et convertissant plus de 2000 format... Cliquez pour télécharger Konvertor
|