Prototype
BOOL EValue::MaskInvertEx( T tMaskToInvert );

Cette fonction inverse tous les bits posés du masque tMaskToAdd sur la variable membre m_tValue.

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

 

 

Argument

T tMaskToInvert

valeur à utiliser pour inverser les bits de la variable membre m_tValue.

 

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 un objet EValue de type uchar initialisé avec la valeur 0xAA (10101010),
• Inverser le masque de bits 0x3C (00111100) avec stockage de la valeur de retour,
• Inverser le masque de bits 0x00 (00000000) 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 <uchar> eValue( 0xAA );
BOOL bChange0, bChange1;
TCHAR *psztNoYes[]={ _T("Non"), _T("Oui") };

eValue.TraceEx( _T("eValue") );
bChange0 = eValue.MaskInvertEx( 0x3C );
eValue.TraceEx( _T("eValue") );
bChange1 = eValue.MaskInvertEx( 0 );
eValue.TraceEx( _T("eValue") );

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

Sortie :

### Object EValue 'eValue' Trace #
# Object address='0x0012F483', size of='1' byte(s) ('8' bits).
# Value:
# Decimal='-86'(signed) '170'(unsigned), Hexadecimal='0xAA'.
# Binary = 10101010
# Equal. = ========
# Pos maj= 00000000
# Pos min= 76543210
### End #

### Object EValue 'eValue' Trace #
# Object address='0x0012F483', size of='1' byte(s) ('8' bits).
# Value:
# Decimal='-106'(signed) '150'(unsigned), Hexadecimal='0x96'.
# Binary = 10010110
# Equal. = ========
# Pos maj= 00000000
# Pos min= 76543210
### End #

### Object EValue 'eValue' Trace #
# Object address='0x0012F483', size of='1' byte(s) ('8' bits).
# Value:
# Decimal='-106'(signed) '150'(unsigned), Hexadecimal='0x96'.
# Binary = 10010110
# Equal. = ========
# Pos maj= 00000000
# Pos min= 76543210
### End #

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

Vue :

07 06 05 04 03 02 01 00

Champs de bits

1 0 1 0 1 0 1 0 Valeur originale

07 06 05 04 03 02 01 00

Champs de bits

1 0 1 0 1 0 1 0 Valeur originale
0 0 1 1 1 1 0 0 Inversion 3C
1 0 0 1 0 1 1 0 Résultat

07 06 05 04 03 02 01 00

Champs de bits

1 0 0 1 0 1 1 0 Valeur originale
0 0 0 0 0 0 0 0 Inversion 00
1 0 0 1 0 1 1 0 Résultat

 

Voir aussi
void EValue::Invert( void );
void EValue::MaskInvert( T tMaskToInvert );

 

Minimum
Version 1.0.0