【发布时间】:2018-04-20 14:43:35
【问题描述】:
我编写的一个简单的例程,用于将ASCII 字符串转换为对应的7-bit GSM 编码方案:
#include <stdio.h>
#include <process.h>
#include <stdbool.h>
#include <string.h>
#include <stdlib.h>
#include <inttypes.h>
/* convert ascii input string to 7-bit GSM alphabet */
bool ascii_to_gsm(const char* in, uint8_t len, uint8_t* out, uint8_t start_indx) {
if (in == NULL || out == NULL || len == 0)
return false;
uint8_t nshift = 7;
memcpy(out + start_indx, in, len);
for (size_t i = 0; i < len - 1; i++) {
nshift = (nshift == 255) ? 7 : nshift;
uint16_t l = out[start_indx + i];
uint16_t h = out[start_indx + i + 1];
h = (h << nshift--) | l;
out[start_indx + i] = h;
out[start_indx + i + 1] = h >> 8;
}
return true;
}
int main() {
char data[] = "ASCIIASCII";
uint8_t buff[sizeof(data) - 1];
memset(buff, 0, sizeof(buff));
ascii_to_gsm(data, sizeof(buff), buff, 0);
for (size_t i = 0; i < sizeof(buff); i++) {
printf("\n buff[%d]=%02x", i, buff[i]);
}
system("pause");
return 0;
}
对于像ASCII 或TEST 这样的字符串,它工作正常,输出分别为C1E9309904 和D4E2940A。
但是对于字符串ASCIIASCII,一些输出字节是错误的:
C1E930990C4E87498024
结果应该是:C1E930990C4E87C924
不知道是哪一部分,我错了。
关于GSM编码的概念可以在here找到。
我使用this在线编码器比较结果
【问题讨论】:
-
为什么这段代码不起作用对于 SO 来说是题外话。
-
嗯,输出的“字节”长度在
C1E930990C4E87498024和C1E930990C4E87C924之间是不同的。 -
看起来您的代码为每一个字节的输入生成一个字节的输出。 (实际上,它似乎为每个输入字节生成 两个 字节的输出,但它似乎覆盖了其中的一半,您可能想要查看。)但是如果 GSM 是 7 位编码,我猜您希望平均为每个输入字节生成 7/8 个字节,或者为每 8 个输入字节生成 7 个字节的输出。 “ASCIIASCII”是10个字节长,你生成10个字节的输出,正确答案是9个字节的输出。
-
@SteveSummit。是的,这非常正确,
GSM编码中最大 140 字节的SMS可能是 160 个字符长度。