Prototype |
E_RTN | EMemory::BlockFind( | ulonglong | *pullOffsetFound, |
void | *pBlockToFind, | ||
ulonglong | ullBlockToFindSize, | ||
ulonglong | ullOffset = 0, | ||
ulonglong | ullOffsetSize = EMemory::SizeUpToEnd ); |
Cette fonction cherche dans l'intervalle de travail un bloc d'octets ayant les valeurs de pBlockToFind.
Argument |
ulonglong *pullOffsetFound adresse d'une variable de type ulonglong où sera stocké l'offset du bloc d'octets trouvé. Si le bloc d'octets n'a pas été trouvé et si cet argument n'est pas NULL alors la valeur EMemory::DataNotFound y est copiée (*pullOffsetFound = EMemory::DataNotFound). Si cette information ne vous intéresse pas cet argument peut être NULL (la fonction ne retournera pas d'erreur à ce propos). |
void *pBlockToFind adresse du bloc d'octets à chercher. |
ulonglong ullBlockToFindSize taille du bloc d'octets à chercher. |
ulonglong ullOffset = 0 offset de départ de l'intervalle de travail de recherche. |
ulonglong ullOffsetSize = EMemory::SizeUpToEnd étendue de l'intervalle de travail de recherche. |
Retour |
E_RTN voir la section retour de la librairie Eclat. |
Exemple 1 |
Description : Recherche et affichage d'offset de tous les blocs d'octets ayant pour valeurs contigues 0x42, 0x43 et 0x42 ("BCB" en ASCII) dans un objet EMemory alloué de 14 octets d'espace de travail contenant les données 0x42, 0x43, 0x42, 0x43, 0x42, 0x43, 0x42, 0x43, 0x42, 0x43, 0x42, 0x43, 0x42 et 0x43 ("BCBCBCBCBCBCBC" en ASCII). |
Code :
|
Sortie :
|
Vue :
|
Exemple 2 |
Description : Cet exemple est un peu plus complexe que le précédente. Il fait la même chose mais avec un intervalle de travail qui s'étand de l'offset 1 sur une taille de 12 octets (un surcroît de code est nécessaire pour ajuster la taille de recherche). |
Code :
|
Sortie :
|
Vue :
|
Voir aussi |
Minimum |
Version | 1.0.0 |