- C++ Home
- C++ Overview
- C++ Environment Setup
- C++ Basic Syntax
- C++ Comments
- C++ Hello World
- C++ Omitting Namespace
- C++ Tokens
- C++ Constants/Literals
- C++ Keywords
- C++ Identifiers
- C++ Data Types
- C++ Numeric Data Types
- C++ Character Data Type
- C++ Boolean Data Type
- C++ Variable Types
- C++ Variable Scope
- C++ Multiple Variables
- C++ Input Output Operations
- C++ Basic Input/Output
- C++ Cin
- C++ Cout
- C++ Manipulators
- Type System & Data Representation
- C++ Modifier Types
- C++ Storage Classes
- C++ Constexpr Specifier
- C++ Numbers
- C++ Enumeration
- C++ Enum Class
- C++ References
- C++ Date & Time
- C++ Operators
- C++ Operators
- C++ Arithmetic Operators
- C++ Relational Operators
- C++ Logical Operators
- C++ Bitwise Operators
- C++ Assignment Operators
- C++ sizeof Operator
- C++ Conditional Operator
- C++ Comma Operator
- C++ Member Operators
- C++ Casting Operators
- C++ Pointer Operators
- C++ Operators Precedence
- C++ Unary Operators
- C++ Scope Resolution Operator
- C++ Control Statements
- C++ Decision Making
- C++ if Statement
- C++ if else Statement
- C++ Nested if Statements
- C++ switch Statement
- C++ Nested switch Statements
- C++ Loop Types
- C++ while Loop
- C++ for Loop
- C++ do while Loop
- C++ Foreach Loop
- C++ Nested Loops
- C++ Jump Statements
- C++ break Statement
- C++ continue Statement
- C++ goto Statement
- C++ Return Values
- C++ Strings
- C++ Strings
- C++ Loop Through a String
- C++ String Length
- C++ String Concatenation
- C++ String Comparison
- C++ Functions
- C++ Functions
- C++ Multiple Function Parameters
- C++ Recursive Function
- C++ Function Overloading
- C++ Function Overriding
- C++ Default Arguments
- C++ Arrays
- C++ Arrays
- C++ Multidimensional Arrays
- C++ Pointer to an Array
- C++ Passing Arrays to Functions
- C++ Return Array from Functions
- C++ Array Decay
- C++ Structure & Union
- C++ Structures
- C++ Unions
- C++ Class and Objects
- C++ Object Oriented
- C++ Classes & Objects
- C++ Class Member Functions
- C++ Class Access Modifiers
- C++ Static Class Members
- C++ Static Data Members
- C++ Static Member Function
- C++ Inline Functions
- C++ this Pointer
- C++ Friend Functions
- C++ Pointer to Classes
- C++ Constructors
- C++ Constructor & Destructor
- C++ Default Constructors
- C++ Parameterized Constructors
- C++ Copy Constructor
- C++ Constructor Overloading
- C++ Constructor with Default Arguments
- C++ Delegating Constructors
- C++ Constructor Initialization List
- C++ Dynamic Initialization Using Constructors
- C++ Destructors
- C++ Virtual Destructor
- C++ Inheritance
- C++ Inheritance
- C++ Multiple Inheritance
- C++ Multilevel Inheritance
- C++ Object-oriented
- C++ Overloading
- C++ Polymorphism
- C++ Abstraction
- C++ Encapsulation
- C++ Interfaces
- C++ Virtual Function
- C++ Pure Virtual Functions & Abstract Classes
- C++ Override Specifiers
- C++ Final Specifiers
- C++ Design Patterns
- C++ Creational Design Patterns
- C++ Singleton Design Pattern
- C++ Factory Method Design Pattern
- C++ Abstract Factory Pattern
- C++ Prototype Design Pattern
- C++ Structural Design Patterns
- C++ Facade Design Pattern
- C++ Iterator Design Pattern
- C++ Mediator Design Pattern
- C++ Memento Design Pattern
- C++ Observer Design Pattern
- C++ State Design Pattern
- C++ Strategy Design Pattern
- C++ Template Method Design Pattern
- C++ Visitor Design Pattern
- C++ Behavioural Design Pattern
- C++ File Handling
- C++ Files and Streams
- C++ Reading From File
- C++ Advanced
- C++ Exception Handling
- C++ Dynamic Memory
- C++ Move Semantics
- C++ Namespaces
- C++ Templates
- C++ Preprocessor
- C++ Signal Handling
- C++ Multithreading
- C++ Web Programming
- C++ Socket Programming
- C++ Concurrency
- C++ Advanced Concepts
- C++ Lambda Expression
- C++ nullptr
- C++ unordered_multiset
- C++ Chain of Responsibility
- C++ Structural Design Patterns
- C++ Adapter Pattern
- C++ Bridge Pattern
- C++ Composite Pattern
- C++ Decorator Pattern
- C++ Command Pattern
- C++ Proxy Pattern
- C++ Useful Resources
- C++ Questions and Answers
- C++ Quick Guide
- C++ Cheatsheet
- C++ STL Tutorial
- C++ Standard Library
- C++ Useful Resources
- C++ Discussion
- C++ Online Compiler
C++ Bitset::operator>> Function
The C++ std::bitset::operator>> performs bitwise right SHIFT operation on the current bitset object. It stores the result in another (new) bitset object.
The bitwise right SHIFT operator shifts the bits of the operand to the right by the specified number of positions. The rightmost bits of the bitset object are discarded and a 0 bit is appended to the start of the resultant binary value. The number of times we need to append a 0 bit depends on the number of positions that the bits are shifted.
A bitwise operator operates on individual bits of a binary number, rather than the whole number. It can be used to perform different operations, such as setting and clearing specific bits, checking if a bit is set or not, and manipulating data packed into bit fields.
Syntax
Following is the syntax for std::bitset::operator>> −
bitset operator>>(size_t pos) const;
Parameters
pos − Number of bits to be shifted.
Return value
Returns new bitset object which contains shifted bits.
Example 1
The following example shows the usage of std::bitset::operator>> function on a single bitset operand.
Here, we are creating a bitset "b" of size "4" with the binary value "1000". Then, we are shifting the bits of "b" one position to the right using the bitwise right shift operator and storing the result in a new variable "result".
#include <iostream>
#include <bitset>
using namespace std;
int main(void) {
bitset<4> b("1000");
auto result = b >> 1;
cout << result << endl;
return 0;
}
Output
Let us compile and run the above program, this will produce the following result −
0100
Example 2
Here, we are reducing an integer value to its half using the operator>>.
In the following example, we are creating an integer variable "x" with an initial value of "10". Then, we are using the bitwise right shift operator to shift its bits to the right by one position, effectively dividing the value of "x" by "2". We are then storing the result in a new variable "res".
#include <iostream>
#include <bitset>
using namespace std;
int main(void) {
int x = 10;
int res = x >> 1;
cout << res << endl;
return 0;
}
Output
If we run the above code it will generate the following output −
5
Example 3
Now, we are setting a bit in a binary representation using the operator >>.
In the example given below, we are creating a 32-bit unsigned integer (non-negative values) variable called "mask" and assigning it with the hexadecimal value "0x08" (binary 1000). Then, we are using the bitwise right shift operator to move the binary digits of the original value to the right by "3" positions, effectively dividing it by 23. We are then storing the result in a new variable "value".
#include <iostream>
#include <bitset>
using namespace std;
int main(void) {
uint32_t mask = 0x08;
auto value = mask >> 3;
cout << value << endl;
return 0;
}
Output
Following is an output of the above code −
1
Example 4
In here, we are shifting multiple values in an array to the right.
In the example below, we are creating an integer array "arr" with values "{16, 32, 64, 128}" (each value is formed by raising 2n). We are then creating an empty array "res" of size "4" to store the result in it. Then, we are shifting each element of the "arr" to the right by "4" bits using the bitwise right shift operator.
#include <iostream>
#include <bitset>
using namespace std;
int main(void) {
int arr[] = {16, 32, 64, 128};
int res[4];
for (int i = 0; i < 4; i++) {
// Shift right by 4 bits
res[i] = arr[i] >> 4;
cout << res[i] << " ";
}
return 0;
}
Output
We can see that each value in the array is divided by 2 raised to the power of 4 (i.e. 16), effectively decreasing the value by a factor of 16 in the following output −
1 2 4 8