Prototype
BOOL EValue::MaskAddEx( T tMaskToAdd );

Cette fonction applique le masque tMaskToAdd sur la variable membre m_tValue en utilisant l'opérateur de bits |.

Cette fonction se différencie de la fonction EValue::MaskAdd car elle retourne TRUE ou FALSE si la variable membre m_tValue a été modifiée par l'appel.

 

Argument

T tMaskToAdd

valeur à appliquer comme masque de l'opérateur de bits |.

 

Retour

BOOL

si la variable membre m_tValue est différente d'avant l'appel de la fonction, elle retourne TRUE, sinon FALSE.

 

Exemple

Description :

• Instancier d'un objet EValue de type ushort,
• Ajouter le masque de bits 0x0FF0 (00011111 1110000) avec stockage de la valeur de retour,
• Ajouter le masque de bits 0x0FF0 (00011111 1110000) avec stockage de la valeur de retour,
• Afficher si l'application du premier masque de bits a modifié l'objet eValue,
• Afficher si l'application du second masque de bits a modifié l'objet eValue.

Code :

EValue <ushort> eValue;
BOOL bChange0, bChange1;
TCHAR *psztNoYes[]={ _T("Non"), _T("Oui") };

eValue.TraceEx( _T("eValue") );
bChange0 = eValue.MaskAddEx( 0x0FF0 );
eValue.TraceEx( _T("eValue") );
bChange1 = eValue.MaskAddEx( 0x0FF0 );
eValue.TraceEx( _T("eValue") );

ETrace::DoEx( _T("Changement lors du premier appel de la fonction MaskAddEx = %s.\n"), psztNoYes[bChange0] );
ETrace::DoEx( _T("Changement lors du second appel de la fonction MaskAddEx = %s.\n"), psztNoYes[bChange1] );

Sortie :

### Object EValue 'eValue' Trace #
# Object address='0x0012F480', size of='2' byte(s) ('16' bits).
# Value:
# Decimal='0'(signed) '0'(unsigned), Hexadecimal='0x0000'.
# Binary = 00000000 00000000
# Equal. = ======== ========
# Pos maj= 00000000 00000000
# Pos min= FEDCBA98 76543210
### End #

### Object EValue 'eValue' Trace #
# Object address='0x0012F480', size of='2' byte(s) ('16' bits).
# Value:
# Decimal='4080'(signed) '4080'(unsigned), Hexadecimal='0x0FF0'.
# Binary = 00001111 11110000
# Equal. = ======== ========
# Pos maj= 00000000 00000000
# Pos min= FEDCBA98 76543210
### End #

### Object EValue 'eValue' Trace #
# Object address='0x0012F480', size of='2' byte(s) ('16' bits).
# Value:
# Decimal='4080'(signed) '4080'(unsigned), Hexadecimal='0x0FF0'.
# Binary = 00001111 11110000
# Equal. = ======== ========
# Pos maj= 00000000 00000000
# Pos min= FEDCBA98 76543210
### End #

Changement lors du premier appel de la fonction MaskAddEx = Oui.
Changement lors du second appel de la fonction MaskAddEx = Non.

Vue :

0F 0E 0D 0C 0B 0A 09 08 07 06 05 04 03 02 01 00

Champs de bits

0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 Valeur originale

0F 0E 0D 0C 0B 0A 09 08 07 06 05 04 03 02 01 00

Champs de bits

0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 Valeur originale
0 0 0 0 1 1 1 1 1 1 1 1 0 0 0 0 Ajout 0FF0
0 0 0 0 1 1 1 1 1 1 1 1 0 0 0 0 Résultat

0F 0E 0D 0C 0B 0A 09 08 07 06 05 04 03 02 01 00

Champs de bits

0 0 0 0 1 1 1 1 1 1 1 1 0 0 0 0 Valeur originale
0 0 0 0 1 1 1 1 1 1 1 1 0 0 0 0 Ajout 0FF0
0 0 0 0 1 1 1 1 1 1 1 1 0 0 0 0 Résultat

 

Voir aussi
void EValue::MaskAdd( T tMaskToAdd );

 

Minimum
Version 1.0.0