- 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::test() Function
The C++ function std::bitset::test() tests whether the bit at the specified position is set.
The test() function takes a single integer argument, which represents the index of the bit to be tested, and returns a boolean value indicating whether the bit is set (i.e., has a value of 1) or not (i.e., has a value of 0).
The bitset class is a container that represents a fixed-size sequence of bits. Each bit in the bitset can have a value of either 0 or 1. The bitset class provides a number of member functions to manipulate individual bits of the bitset.
Syntax
Following is the syntax for std::bitset::test() function −
bool test (size_t pos) const;
Parameters
pos − Position of the bit whose value is to be tested.
Return value
Returns true if Nth bit is set; otherwise false.
Example 1
The following example shows the usage of std::bitset::test() function by checking the state of a single bit in a bitset.
We are creating a bitset object "b" of size 4 with the binary value "1010". We are then using the test() function to check the state of the first and second bits.
#include <iostream>
#include <bitset>
using namespace std;
int main(void) {
bitset<4> b(1010);
if (b.test(1))
cout << "1st bit is set." << endl;
if (b.test(0))
cout << "0th bit is set." << endl;
else
cout << "0th bit is not set." << endl;
return 0;
}
Output
Let us compile and run the above program, this will produce the following result −
1st bit is set. 0th bit is not set.
Example 2
Here, we are checking multiple bits in a loop whether they are set using the test() function.
We are creating a bitset object "b" of size "4" with the binary value "1010". We are then using a loop to iterate over all the bits in the bitset and checking whether each bit is set using the test() function.
#include <iostream>
#include <bitset>
using namespace std;
int main() {
bitset<4> b("1010");
for (int i = 0; i < b.size(); i++) {
if (b.test(i)) {
cout << "Bit " << i << " is set." << endl;
} else {
cout << "Bit " << i << " is not set." << endl;
}
}
}
Output
If we run the above code it will generate the following output −
Bit 0 is not set. Bit 1 is set. Bit 2 is not set. Bit 3 is set.
Example 3
Now, we are testing if any bit is set in the bitset using the test() function.
In the example given below, we are using the any() function to check if any bit in the bitset is set, and if so, the program loops through the bitset to retrieve the position of the set bits.
#include <iostream>
#include <bitset>
using namespace std;
int main() {
bitset<7> b("0000100");
if (b.any()) {
cout << "At least one bit is set." << endl;
for (int i = 0; i < 7; i++) {
if (b.test(i)==1) {
cout << "Bit " << i << " is set." << endl;
} else {
cout << "No bits are set." << endl;
}
}
}
}
Output
Following is an output of the above code −
At least one bit is set. No bits are set. No bits are set. Bit 2 is set. No bits are set. No bits are set. No bits are set. No bits are set.
Example 4
In here, we are checking whether bits of a bitset are set using bitwise AND operator.
In the following example, we are creating two bitset objects "b" and "mask" of size "8" with the binary values "10101010" and "11111010" respectively. We are then performing a bitwise AND operation between "b" and "mask", and storing the result in a new bitset object "isSet". Then, we are checking if all the bits in "isSet" are set to 1 using the all() function in conjunction with the test() function to retrieve the position of the unset bits.
#include <iostream>
#include <bitset>
using namespace std;
int main() {
bitset<8> b("10101010");
bitset<8> mask("11111010");
bitset<8> isSet = (b & mask);
if (isSet.all()== true){
for (int i = 0; i < 8; i++) {
if (isSet.test(i) == 1) {
cout << "All the bits of isSet are 1." << endl;
} else {
for (int i = 0; i < 8; i++) {
if (isSet.test(i) == 0) {
cout << "Bit " << i << " is not set." << endl;
}
}
}
}
}
}
Output
Output of the above code is as follows −
Bit 0 is not set. Bit 2 is not set. Bit 4 is not set. Bit 6 is not set.