Bitwise Operators

This topic describes bitwise operators that are available in F#.

Summary of Bitwise Operators

The following table describes the bitwise operators that are supported for unboxed integral types in F#.

Operator Notes
&&& Bitwise AND operator. Bits in the result have the value 1 if and only if the corresponding bits in both source operands are 1.
||| Bitwise OR operator. Bits in the result have the value 1 if either of the corresponding bits in the source operands are 1.
^^^ Bitwise exclusive OR operator. Bits in the result have the value 1 if and only if bits in the source operands have unequal values.
~~~ Bitwise negation operator. This is a unary operator and produces a result in which all 0 bits in the source operand are converted to 1 bits and all 1 bits are converted to 0 bits.
<<< Bitwise left-shift operator. The result is the first operand with bits shifted left by the number of bits in the second operand. Bits shifted off the most significant position are not rotated into the least significant position. The least significant bits are padded with zeros. The type of the second argument is int32.
>>> Bitwise right-shift operator. The result is the first operand with bits shifted right by the number of bits in the second operand. Bits shifted off the least significant position are not rotated into the most significant position. For unsigned types, the most significant bits are padded with zeros. For signed types with negative values, the most significant bits are padded with ones. The type of the second argument is int32.

The following types can be used with bitwise operators: byte, sbyte, int16, uint16, int32 (int), uint32, int64, uint64, nativeint, and unativeint.

See also