- 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++ function std::bitset::operator[] returns the value or a reference of a bit at the specified position.
This function has two polymorphic variants: the first returns the bit present at the specified position and the other returns a reference to the position of the bit specified in the parameter (You can find the syntaxes of all the variants below). The operator can be used for reading and writing binary values to the bitset.
Note that the index parameter is 0-based, meaning the first bit has an index of 0 and goes up to the size of the bitset minus 1.
Syntax
Following is the syntax for std::bitset::operator[] −
bool operator[] (size_t pos) const; or, reference operator[] (size_t pos);
Parameters
pos − Position of the bit whose value is to be accessed.
Return value
Returns the bit value or the reference to the bit value (which allows writing to the requested bit).
Example 1
The following example shows the usage of std::bitset::operator[] function by returning the value of the bits.
We are creating a bitset object "b" of size "4" with the binary value "1001". We are then iterating through each bit of the bitset using a for loop and printing the value of each bit using operator[].
#include <iostream>
#include <bitset>
using namespace std;
int main(void) {
bitset<4> b("1001");
for (int i = 0; i < 4; ++i)
cout << "In bitset b[" << i << "] = " << b[i] << endl;
return 0;
}
Output
Let us compile and run the above program, this will produce the following result −
In bitset b[0] = 1 In bitset b[1] = 0 In bitset b[2] = 0 In bitset b[3] = 1
Example 2
The following example shows the usage of std::bitset::operator[] function by returning the reference of a bit at the specified position.
We are creating a bitset object "b" of size of "4" with all bits set to "0". We are then setting the 2nd and 4th bit of the bitset to 1 using operator[].
#include <iostream>
#include <bitset>
using namespace std;
int main(void) {
bitset<4> b;
cout << "Initial value of bitset = " << b << endl;
b[1] = 1;
b[3] = 1;
cout << "Value of bitset after setting few bits = " << b << endl;
return 0;
}
Output
If we run the above code it will generate the following output −
Initial value of bitset = 0000 Value of bitset after setting few bits = 1010
Example 3
Here, we are trying to check if the bit is set to 1 using operator[].
In the following example, we are creating a bitset object "bits" of size "8" with the value of "170" (which is 10101010 in binary). Then, we use the if statement to check if the 3rd bit (counting from 0) is set to 1 using the operator[].
#include <iostream>
#include <bitset>
int main() {
std::bitset<8> bits(170);
if (bits[2]) {
std::cout << "The 3rd bit is set to 1" << std::endl;
} else {
std::cout << "The 3rd bit is set to 0" << std::endl;
}
return 0;
}
Output
Following is an output of the above code −
The 3rd bit is set to 0
Example 4
Now, we are trying to flip a bit using operator[].
We are creating a bitset object "bits" of size "8" with the value 255 (which is 11111111 in binary). We are then using the flip() function in conjunction with operator[] on the 5th bit (counting from 0) to flip the bit from 1 to 0.
#include <iostream>
#include <bitset>
int main() {
// initializes all bits to 1
std::bitset<8> bits(255);
// flips the 5th bit from 1 to 0
bits[4].flip();
std::cout << "Value of bitset after flipping bit 4 = " << bits << std::endl;
return 0;
}
Output
Output of the above code is as follows −
Value of bitset after flipping bit 4 = 11101111