C - 使用位移运算符进行基本转换

bry*_*891 5 c bit-manipulation shift

我正在尝试将一些数据从十六进制转换为C中的base64,我在网上找到了一个算法,但我真的想知道它是如何工作的,而不仅仅是实现它并将其解雇.如果有人可以解释以下是如何工作的,我将不胜感激.我一直在阅读有关班次操作员的内容,我似乎并没有像我想象的那样理解它们...它并不是很适合我.

for (x = 0; x < dataLength; x += 3) 
{
  /* these three 8-bit (ASCII) characters become one 24-bit number */
  n = data[x] << 16;

  if((x+1) < dataLength)
     n += data[x+1] << 8;

  if((x+2) < dataLength)
     n += data[x+2];

  /* this 24-bit number gets separated into four 6-bit numbers */
  n0 = (uint8_t)(n >> 18) & 63;
  n1 = (uint8_t)(n >> 12) & 63;
  n2 = (uint8_t)(n >> 6) & 63;
  n3 = (uint8_t)n & 63;
Run Code Online (Sandbox Code Playgroud)

这段代码来自Wikibooks,它不是我的,我只是想了解位移和它如何允许我转换数据.

谢谢你的帮助,我真的很感激.

资料来源:Base64

int*_*jay 5

首先,输入数据不是十六进制,如你所说.它只是存储为字节的数据.该代码将会给你它的Base64表示(虽然你发布的代码没有将其映射的一部分n0,n1,n2,n3可打印的ASCII字符).

假设输入的前三个字节是(以二进制表示,每个字母代表0或1):

abcdefgh, ijklmnop, qrstuvwx
Run Code Online (Sandbox Code Playgroud)

代码的第一部分将它们组合成一个24位数字.这是通过将第一个16位向左移位而第二个向左移动8位并添加:

  abcdefgh0000000000000000      (abcdefgh << 16)
+ 00000000ijklmnop00000000      (ijklmnop << 8)
  0000000000000000qrstuvwx
  ------------------------
  abcdefghijklmnopqrstuvwx
Run Code Online (Sandbox Code Playgroud)

然后通过移位和移动将它分成四个6位数.例如,第二个数字是通过向右移动12位并且用111111进行计算来计算的

n     =   abcdefghijklmnopqrstuvwx

n>>12 =   000000000000abcdefghijkl
63    =   000000000000000000111111

And'ing gives:
          000000000000000000ghijkl
Run Code Online (Sandbox Code Playgroud)