The bit is the most basic unit of information in computing and digital communications. In real all operators are mainly based on Bit Operations which are also called Bitwise Operations. In computer programming, a Bitwise Operation operates on a bit string, a bit array, or a binary numeral (considered as a bit string) at the level of its individual bits, 1s, and 0s. The Bitwise Operation is basic to the higher-level arithmetic operations and it is a fast and simple action because it is directly supported by the processors. Most bitwise operations are presented as two-operand instructions where the result replaces one of the input operands.
Because of all these basics of the microarchitecture of computers, it is very important to know Bitwise Operators. C Programming language is one of the oldest programming languages and a lot of operands, operators in other programming languages got inspiration from this language. C and C++ have the same operators and most of them are the same in other programming languages. We have explained well about operators in general in this Learn How To Use Operators In C++ post before. Now let’s see Bit Shifting and Encoding – Decoding examples.
In this post, you’ll learn about the fastest data encoding and decoding methods; how to secure data using the fastest method; how to encode or decode data using shifting, and how to use shifting on Strings or Binaries data. By learning more about bit shifting, it will help you to easily build C++ applications using the C++ IDE.
Table of Contents
Bit Shifting Data
One of the Bitwise Operand is the Bit Shifting, the Left Shifting with ‘<<‘ operand, and the Right Shifting ‘>>‘ operand. Bit operations are the fastest operations in machine codes and in C++ because of the microarchitecture of computers as explained above. There are many encoding and decoding methods, also hash coding methods. One of the easiest and the fastest encoding method is Bit Shifting Data. We can use this method to encode and decode data files.
Left Shifting and Right Shifting
For example if c is char we can encode and decode this char as below,
1 2 3 4 |
c = c << 1; // Encoding with Left Bit Shifting c = c >> 1; // Decoding with Right Bit Shifting |
This works well in lower than 127 char numbers. When shifting we lost the frontier bits (when shifting left we lost left bit or bits and when shifting right we lost right bit or bits). To hold all these bits in a binary data we should do Circular Bit Shifting,
Circular Left Shifting and Circular Right Shifting
If you we use Circular Bit Shifting, we never loose any bits when we encode or decode our data. If we want to shift 2 bits from maximum of 8 bits we can do left and right circular bit shifting as below,
1 2 3 4 |
c =(c << 2)|(c >> (8 - 2); // Encoding with Circular Left 2 Bits Shifting c =(c >> 2)|(c << (8 - 2); // Decoding with Circular Right 2 Bits Shifting |
Circular Left Shifting and Circular Right Shifting with Complexity
We can add complexity to number of shifting by adding (1+i%7) for example,
1 2 3 4 |
c =(c << (1+i%7))|(c >> (8 - (1+i%7)); // Encoding by Circular Left Bits Shifting with Complexity c =(c >> (1+i%7))|(c << (8 - (1+i%7)); // Decoding by Circular Right Bits Shifting with Complexity |
Bit Shifting Data Files
For example we can use this shifting method to encode and decode data files as in this example below,
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 |
#include <iostream> #include <fstream> #include <cstdlib> #include <string> int main() { unsigned char c; // std::bitset<8> x; unsigned int i=0; std::ifstream indata; std::ofstream outdata; // ENCODING mytest.txt to mytest.data // --------------------------------------------------------- indata.open("D:\\mytest.txt", std::fstream::binary); if(!indata) { std::cerr << "Error: Input file could not be opened\n";; exit(1); } outdata.open("D:\\mytest.dat", std::fstream::binary); if(!outdata) { std::cerr << "Error: Output file could not be opened\n";; exit(1); } std::cout << "\nEncoding..\n"; i=0; while ( !indata.eof() ) { c=indata.get(); // get the next char of data or indata.get(); // c = c << 1; // Encoding with Left Bit Shifting c =(c << (1+i%7))|(c >> (8 - (1+i%7))); // Encoding by Circular Left Bit Shifting with Complexity outdata.put(c); // out the encoded char std::cout << c; i++; } indata.close(); outdata.close(); // DECODING mytest.dat to mytest2.txt // --------------------------------------------------------- indata.open("D:\\mytest.dat", std::fstream::binary); if(!indata) { std::cerr << "Error: Input file could not be opened\n";; exit(1); } outdata.open("D:\\mytest2.txt", std::fstream::binary); if(!outdata) { std::cerr << "Error: Output file could not be opened\n";; exit(1); } i=0; std::cout << "\nDecoding..\n"; while ( !indata.eof() ) { c= indata.get(); // get the next char of data //c = c >> 1; // Decoding with Right Bit Shifting c =(c >> (1+i%7))|(c << (8 - (1+i%7))); // Decoding by Circular Right Bit Shifting with Complexity outdata.put(c); // out the encoded char std::cout << c; i++; } indata.close(); outdata.close(); getchar(); return 0; } |
Bit shifting is the fastest data manipulation. We could use this bit shifting method to protect our data, user names, etc. and similar sensitive items as a fun exercise but bit shifting in this way is a form of security through obscurity. We can use this with the support of a second industrial security system There are industry standard security practices such as salting passwords and using industry standard encryption that provide real security.
We can also hash this Encoded String by using powerful Cryptographic Hash Functions In Modern C++ On Windows (SHA, SHA2, MD5, BobJenkins, etc.). So you can put another dimension to your data systems. See this Learn To Use Powerful Cryptographic Hash Functions In Modern C++ On Windows (SHA, SHA2, MD5, BobJenkins)
RAD Studio is a powerful and modern IDE for C++. Why not download a trial copy today and see what it can do for you?
Design. Code. Compile. Deploy.
Start Free Trial
Free C++Builder Community Edition