这几天要在ABAP中实现 3DES 标准对称加密算法,与其他外部系统进行加密/解密操作。由于ABAP语言中没有 左移 <<、无符号右移 >>>  操作,只能自己实现
思路:
如果移动的位数bit是字节(8位)的整数倍,则直接使用  SHIFT <i> BY p PLACES RIGHT IN BYTE MODE.这样的语句搞定(这样效率会更高),如果非字节整数倍,则需要借助于SET BIT来完成,实现时,要注意整型的字节序格式,本人开发环境是低字节序(低位在前,高位在后),与人的阅读习惯是反的(但要注意的字节里面的是还是高位在前,低位在后),左右位移规则如下(同一种颜色为移动后所在位置):


DATA: BEGIN OF index_map OCCURS 0,
  index_inner TYPE i,
  index TYPE i,
  END OF  index_map .

FORM init .
  CLEAR: index_map[].
  index_map-index_inner = 1.
  index_map-index = 8.
  APPEND index_map.
  index_map-index_inner = 2.
  index_map-index = 7.
  APPEND index_map.
  index_map-index_inner = 3.
  index_map-index = 6.
  APPEND index_map.
  index_map-index_inner = 4.
  index_map-index = 5.
  APPEND index_map.
  index_map-index_inner = 5.
  index_map-index = 4.
  APPEND index_map.
  index_map-index_inner = 6.
  index_map-index = 3.
  APPEND index_map.
  index_map-index_inner = 7.
  index_map-index = 2.
  APPEND index_map.
  index_map-index_inner = 8.
  index_map-index = 1.
  APPEND index_map.
  index_map-index_inner = 9.
  index_map-index = 16.
  APPEND index_map.
  index_map-index_inner = 10.
  index_map-index = 15.
  APPEND index_map.
  index_map-index_inner = 11.
  index_map-index = 14.
  APPEND index_map.
  index_map-index_inner = 12.
  index_map-index = 13.
  APPEND index_map.
  index_map-index_inner = 13.
  index_map-index = 12.
  APPEND index_map.
  index_map-index_inner = 14.
  index_map-index = 11.
  APPEND index_map.
  index_map-index_inner = 15.
  index_map-index = 10.
  APPEND index_map.
  index_map-index_inner = 16.
  index_map-index = 9.
  APPEND index_map.
  index_map-index_inner = 17.
  index_map-index = 24.
  APPEND index_map.
  index_map-index_inner = 18.
  index_map-index = 23.
  APPEND index_map.
  index_map-index_inner = 19.
  index_map-index = 22.
  APPEND index_map.
  index_map-index_inner = 20.
  index_map-index = 21.
  APPEND index_map.
  index_map-index_inner = 21.
  index_map-index = 20.
  APPEND index_map.
  index_map-index_inner = 22.
  index_map-index = 19.
  APPEND index_map.
  index_map-index_inner = 23.
  index_map-index = 18.
  APPEND index_map.
  index_map-index_inner = 24.
  index_map-index = 17.
  APPEND index_map.
  index_map-index_inner = 25.
  index_map-index = 32.
  APPEND index_map.
  index_map-index_inner = 26.
  index_map-index = 31.
  APPEND index_map.
  index_map-index_inner = 27.
  index_map-index = 30.
  APPEND index_map.
  index_map-index_inner = 28.
  index_map-index = 29.
  APPEND index_map.
  index_map-index_inner = 29.
  index_map-index = 28.
  APPEND index_map.
  index_map-index_inner = 30.
  index_map-index = 27.
  APPEND index_map.
  index_map-index_inner = 31.
  index_map-index = 26.
  APPEND index_map.
  index_map-index_inner = 32.
  index_map-index = 25.
  APPEND index_map.
ENDFORM.

*&---------------------------------------------------------------------*
*&      Form  lshfit_i
*&---------------------------------------------------------------------*
*       整型左移
*----------------------------------------------------------------------*
*      -->I          待位移的数
*      -->PLACES     移几位
*      -->I2         位移后的数
*----------------------------------------------------------------------*
FORM lshfit_i USING i TYPE i places TYPE i i2 TYPE i.
  DATA: start1 TYPE i ,start2 TYPE i.
  DATA: b TYPE n.
  DATA: i3 TYPE i.
  FIELD-SYMBOLS: <i3> TYPE x.

  FIELD-SYMBOLS: <i> TYPE x.
  FIELD-SYMBOLS: <p> TYPE x.
  DATA: _31(4) TYPE x,p TYPE i.
  p = places.
  IF places < 0.
    _31 = '1F000000'.
    ASSIGN p TO <p> CASTING.
    <p> = <p> BIT-AND _31.
  ENDIF.

  i2 = i.
  ASSIGN i2 TO <i> CASTING.

  IF p = 24 OR p = 16 OR p = 8.
    p = p / 8.
    SHIFT <i> BY p PLACES RIGHT IN BYTE MODE.
  ELSE.
    ASSIGN i3 TO <i3> CASTING.
    start1 = 32 - p.

    WHILE  start1 >= 1.
      READ TABLE index_map INDEX start1.
      GET BIT index_map-index OF <i> INTO b.
      IF b = 1.
        start2 = start1 + p.
        READ TABLE index_map INDEX start2.
        SET BIT index_map-index OF <i3> TO b.
      ENDIF.
      start1 = start1 - 1.
    ENDWHILE.
    <i> = <i3>.
  ENDIF.
ENDFORM.                    "lshfit_i

*&---------------------------------------------------------------------*
*&      Form  rshfit_i
*&---------------------------------------------------------------------*
*       整型右移
*----------------------------------------------------------------------*
*      -->I          待位移的数
*      -->PLACES     移几位
*      -->I2         位移后的数
*----------------------------------------------------------------------*
FORM rshfit_i USING i TYPE i places TYPE i i2 TYPE i.
  DATA: start1 TYPE i ,start2 TYPE i.
  DATA: b TYPE n.
  DATA: i3 TYPE i.
  FIELD-SYMBOLS: <i3> TYPE x.
  FIELD-SYMBOLS: <i> TYPE x.
  FIELD-SYMBOLS: <p> TYPE x.
  DATA: _31(4) TYPE x,p TYPE i.
  DATA multiplier TYPE i.

  p = places.
  IF p < 0.
    _31 = '1F000000'.
    ASSIGN p TO <p> CASTING.
    <p> = <p> BIT-AND _31.
  ENDIF.

  i2 = i.

  ASSIGN i2 TO <i> CASTING.

  IF p = 24 OR p = 16 OR p = 8.
    p = p / 8.
    SHIFT <i> BY p PLACES LEFT IN BYTE MODE.
  ELSE.
    IF i >= 0 AND p < 31 .
      multiplier = 2 ** p.
      i2 = i DIV multiplier.
    ELSE.
      ASSIGN i3 TO <i3> CASTING.

      start1 = p + 1.

      WHILE  start1 <= 32.
        READ TABLE index_map INDEX start1.
        GET BIT index_map-index OF <i> INTO b.
        IF b = 1.
          start2 = start1 - p.
          READ TABLE index_map INDEX start2.
          SET BIT index_map-index OF <i3> TO b.
        ENDIF.
        start1 = start1 + 1.
      ENDWHILE.
      <i> = <i3>.
    ENDIF.
  ENDIF.
ENDFORM.                    "rshfit_i

*&---------------------------------------------------------------------*
*&      Form  c2int
*&---------------------------------------------------------------------*
*       字符转整型
*----------------------------------------------------------------------*
*      -->C1         text
*      -->I          text
*----------------------------------------------------------------------*
FORM c2int USING c1 TYPE c i TYPE i.
  FIELD-SYMBOLS <c1> TYPE x.
  FIELD-SYMBOLS: <i> TYPE x.
  ASSIGN c1 TO <c1> CASTING.
  ASSIGN i TO <i> CASTING.
  <i> = <c1>.
ENDFORM.    

*&---------------------------------------------------------------------*
*&      Form  lshfit_c
*&---------------------------------------------------------------------*
*       字符左移
*----------------------------------------------------------------------*
*      -->C1         待位移的字符
*      -->PLACES     移几位
*      -->I          位移后的结果
*----------------------------------------------------------------------*
FORM lshfit_c USING c1 TYPE c places TYPE i i TYPE i.
  PERFORM c2int USING c1 i.
  PERFORM lshfit_i USING i places i.
ENDFORM.                    "lshfit

*&---------------------------------------------------------------------*
*&      Form  rshfit_c
*&---------------------------------------------------------------------*
*       字符右移
*----------------------------------------------------------------------*
*      -->C1         待位移的字符
*      -->PLACES     移几位
*      -->I          位移后的结果
*----------------------------------------------------------------------*
FORM rshfit_c USING c1 TYPE c places TYPE i i TYPE i.
  PERFORM c2int USING c1 i.
  PERFORM rshfit_i USING i places i.
ENDFORM.                    "rshfit_c
 
 

ABAP语言实现 左移 <<、无符号右移 >>> 位移操作的更多相关文章

  1. Java负整数的左移、右移、无符号右移

    转自  Java负整数的左移.右移.无符号右移 Java负整数的左移.右移.无符号右移.正数的位移没有涉及到符号,而且正数的原码.反码.补码都是一样的,所以相对简单,但是对于负整数的位移,往往容易混淆 ...

  2. 原码,反码,补码 与(&) 或(|) 非(~) 异或(^) 左移 << 右移 >> 无符号右移 >>>

    原码 数字在计算机中以二进制表示,8位的字长,最高位是符号位, 正数为0,负数为1.比如,3为0000 0011: -3为1000 0011. 注意,Java中int为32位.3的16进制表示为3,- ...

  3. java的<<左移,>>右移,>>>无符号右移

    >>右移 右移,道在二进制中,假设用一个32位的Int表示一个64,那么高位就都是0,所以当我们把整个二进制数右移,如0100000 >> 2 = 0001000,可以看到右移 ...

  4. java移位运算符:<<(左移)、>>(带符号右移)和>>>(无符号右移)。

    1. 左移运算符 左移运算符<<使指定值的所有位都左移规定的次数. 1)它的通用格式如下所示: value << num num 指定要移位值value 移动的位数. 左移的规 ...

  5. 分析轮子(二)- << ,>>,>> (左移、右移、无符号右移)

    前言:写 分析轮子(一)-ArrayList.java 的时候看到源码中有 int newCapacity = oldCapacity + (oldCapacity >> 1); 这样的代 ...

  6. [JAVA]移位运算(左移<<,右移>>和无符号右移>>>)

    一.背景知识 整数在内存中是以二进制的形式存在的,而且存的是该整数的补码.最高位代表符号位,正数为0,负数为1 正数的补码是其二进制本身,负数的补码则是 符号位保持1不变,其他位按位取反再加1,+0和 ...

  7. java移位运算符实验程序:&lt;&lt;(左移)、&gt;&gt;(带符 号右移)和&gt;&gt;&gt;(无符号右移)

    public class txs { static void leftbit(){ int i;               //整型长度为32位                           ...

  8. Java,C 位移运算符 有符号右移>>与无符号右移>>>

    个人博客 地址:https://www.wenhaofan.com/a/20181029232749 有符号右移 正数有符号右移 首先计算4>>2 将4转为二进制 0000 0100 右移 ...

  9. PHP实现无符号右移(js中的 >>>)

    移位包括有符号左移(<<).有符号右移(>>).无符号右移(>>>),其中 js 支持三种移位,PHP只支持前两种移位(没查到第三种),恰好需要PHP进行无符 ...

随机推荐

  1. python 格式话-占位符

    格式化输出:name = qjage = 30job = itsalary = 6000例1:字符串拼接方法,不建议,因为会在内存中开辟多块内存空间. info = '''---------- inf ...

  2. scrapy meta不用pipe用命令-o

    1. spider代码: # -*- coding: utf-8 -*- import scrapy from tencent1.items import Tencent1Item import js ...

  3. 爬虫3 requests基础2 代理 证书 重定向 响应时间

    import requests # 代理 # proxy = { # 'http':'http://182.61.29.114.6868' # } # res = requests.get('http ...

  4. HDU-1013的解题报告

    题目来源:hdu-1013 题意:正整数的数字根是通过求整数的整数而求出的.如果结果值是一个位数,那么这个数字就是数字根.如果结果值包含两个或多个数字,则将这些数字相加并重复该过程.只要需要获得一个数 ...

  5. ZOJ 1610 Count the Colors 【线段树】

    <题目链接> 题目大意: 在[0,8000]这个区间内,不断进行一些操作,将其中的一些区间染成特定颜色,如果区间重复的话,后面染的色块会覆盖前面染的色块,问最终[0,8000]这个区间内每 ...

  6. C++ 中递归实现 二项式展开式(a+b)^ n 的表达式

    C++ 中递归实现 二项式展开式 的表达式 前几天,一个数学系读研的同学来问有什么软件可以来求 (a+b)^n 这种表达式类型的展开式,我随口一说了 Octave , 毕竟这个开源的还是可以的,后来他 ...

  7. 上海市2019年公务员录用考试笔试合格人员笔试成绩(A类)

    考试类别:A类 注册编号 总成绩 注册编号 总成绩 注册编号 总成绩 注册编号 总成绩 4016574 127.4 5112479 145.9 5125732 124.3 5141074 159.9 ...

  8. ubantu 14.04中安装npm+node.js+react antd

    今天折腾了半天,各种安装问题,最终还是装上了: 1.安装npm $ sudo apt install npm 2.升级npm $ sudo npm install npm@latest -g 输入np ...

  9. Windows 7 下如何配置 java 环境变量

    安装 JDK.从Oracel官方网站上下载,下载完成后安装. http://www.oracle.com/technetwork/java/javase/downloads/jdk8-download ...

  10. 2019-1-23IntelliJ IDEAget的使用教程及出现的问题

    第一条:快捷键: Ctrl+Alt+h:显示调用当前方法的所有位置. Ctrl+Alt+B:跳转到方法实现处 自动修正,我这是 Alt + L Ctrl+Enter,导入包,自动修正Ctrl+Alt+ ...