- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我使用 SIM800l 通过 AT commands 与 arduino UNO 通话.通过使用这个 library我使用 gprsTest.callUp(number)
函数进行调用。问题是它返回 true
即使数字错误或没有信用。
这部分代码从GPRS_Shield_Arduino.cpp library就很清楚了为什么会这样。它不检查 ATDnumberhere;
bool GPRS::callUp(char *number)
{
//char cmd[24];
if(!sim900_check_with_cmd("AT+COLP=1\r\n","OK\r\n",CMD)) {
return false;
}
delay(1000);
//HACERR quitar SPRINTF para ahorar memoria ???
//sprintf(cmd,"ATD%s;\r\n", number);
//sim900_send_cmd(cmd);
sim900_send_cmd("ATD");
sim900_send_cmd(number);
sim900_send_cmd(";\r\n");
return true;
}
ATDnumberhere;
在软件串口通信上的返回是:
如果号码错了 错误
如果没有信用
`MO CONNECTED //instant response
+COLP: "003069XXXXXXXX",129,"",0,"" // after 3 sec
OK`
来电无人接听
MO RING //instant response, it is ringing
NO ANSWER // after some sec
如果是来电挂断
MO RING //instant response
NO CARRIER // after some sec
如果接收方没有载波
ATD6985952400;
NO CARRIER
如果是来电,接听并挂断
MO RING
MO CONNECTED
+COLP: "69XXXXXXXX",129,"",0,""
OK
NO CARRIER
问题是如何通过此函数 gprsTest.callUp(number)
为每种情况使用不同的返回值,或者至少在响铃时如何返回 true ?
最佳答案
这个库代码乍一看似乎比我见过的最差的要好,但它仍然存在一些问题。最严重的是它的最终结果代码处理。
sim900_check_with_cmd
函数在概念上几乎已经存在,但是只检查 OK
是绝对不能接受的。它应该检查调制解调器可能发送的每一个可能的最终结果代码。从您的输出示例中,您有以下最终结果代码
但还有更多。您可以查看 atinout 的代码is_final_result_code
函数的示例(您还可以与 ST-Ericsson's U300 RIL 中的 isFinalResponseError
和 isFinalResponseSuccess
1 进行比较) .
GPRS::callUp
末尾的无条件return true;
是一个错误,但可能是故意的,因为缺乏实现更好的 API 的想法,所以调用客户端可以检查中间结果代码。但这是一种错误的做法。该库确实应该无一异常(exception)地执行所有有状态的命令行调用和最终结果代码解析。只在库中完成其中的一部分并将其中的一部分留给客户是糟糕的设计。
当客户端想要检查或操作命令行和最终结果代码之间的中间结果代码或信息文本时,正确的方法是让库将它从调制解调器接收到的所有内容“解帧”到单独的完整行,对于不是最终结果代码的所有内容,通过回调函数将其提供给客户端。
以下是我的 atinout 程序未完成的更新:
bool send_commandline(
const char *cmdline,
const char *prefix,
void (*handler)(const char *response_line, void *ptr),
void *ptr,
FILE *modem)
{
int res;
char response_line[1024];
DEBUG(DEBUG_MODEM_WRITE, ">%s\n", cmdline);
res = fputs(cmdline, modem);
if (res < 0) {
error(ERR "failed to send '%s' to modem (res = %d)", cmdline, res);
return false;
}
/*
* Adding a tiny delay here to avoid losing input data which
* sometimes happens when immediately jumping into reading
* responses from the modem.
*/
sleep_milliseconds(200);
do {
const char *line;
line = fgets(response_line, (int)sizeof(response_line), modem);
if (line == NULL) {
error(ERR "EOF from modem");
return false;
}
DEBUG(DEBUG_MODEM_READ, "<%s\n", line);
if (prefix[0] == '\0') {
handler(response_line, ptr);
} else if (STARTS_WITH(response_line, prefix)) {
handler(response_line + strlen(prefix) + strlen(" "), ptr);
}
} while (! is_final_result(response_line));
return strcmp(response_line, "OK\r\n") == 0;
}
您可以将其用作实现正确处理的基础。如果你想从函数中获取错误响应,添加一个额外的回调参数并更改为
success = strcmp(response_line, "OK\r\n") == 0;
if (!success) {
error_handler(response_line, ptr);
}
return success;
提示:阅读 V.250 中的第 5 章全部内容规范,它会教你几乎所有你需要知道的关于命令行、结果代码和响应处理的知识。例如,命令行也应该以 \r
only 结束。 , 不是 \r\n
-
1 请注意,CONNECT
不是最终结果代码,它是中间结果代码,因此名称 isFinalResponseSuccess 严格来说并不是 100% 正确。
关于c++ - 如何编辑SIM800l库保证通话建立,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39659117/
话说,尾部的++在这里没有实际作用? 最佳答案 l+l++ 未定义。您的表达式中没有序列点来分隔对 l 的访问和后增量。它可以做任何事情,包括具有与 l+l 相同的效果。 编辑:问题和答案在 Why
我正在研究成员资格算法,我正在研究这个特定问题,该问题说明如下: 展示一种算法,给定任何常规语言 L,确定 L 是否 = L* 所以,我的第一个想法是,我们有 L*,它是 L 的 Kleene 星并确
我试图弄清楚如何使用 Javascript 生成一个随机 11 个字符串,该字符串需要特定的字母/数字序列,以及位置。 ----------------------------------------
我一直在 LinqPad 中试验查询。我们有一个表 Lot,其中有一列 Side char(1)。当我编写 linq to sql 查询 Lots.Where(l => l.Side == 'A')
这个问题在这里已经有了答案: Iterate over all pairs of consecutive items in a list [duplicate] (7 个答案) 关闭 7 年前。 假
列表 ['a','a #2','a(Old)'] 应变为 {'a'} 因为 '# ' 和 '(Old)' 将被删除,并且不需要重复项列表。我努力用生成器开发列表理解,并决定这样做,因为我知道它会起作用
我正在为蛇和梯子制作一 block 板,到目前为止,我已经按降序打印了板。但是,我需要以正确的方式打印电路板。 编辑“螺旋下降”意味着 100...91 81...90 80...71 ...
字符串“Hello\n”等于 {'H','e','l','l','o','\','n','\0'} 或 {'H','e','l','l','o','\n','\0'}? 是否在字符串定义中添加转义序列
这个问题在这里已经有了答案: Different behaviour for list.__iadd__ and list.__add__ (3 个答案) 关闭 8 年前。 ls = [1,2,3]
当我在编写一个程序时,我在我的代码中看到了一个奇怪的行为。这是我所看到的。 >>> l = [1,2,3,4,5,6,7,8] >>> g = [] >>> for i in l: ... g
我明白了what a Y Combinator is , 但我不明白这个来自 Wikipedia page 的“新颖”组合子的例子: Yk = (L L L L L L L L L L L L L
Exception ParseException is not compatible with throws clause in Comparator.compare(L, L). 我在java 6上
期望的输出 我想要一个函数返回一个列表,这样,给定一个“困惑的”列表 l,每个元素都是 l 对应元素的索引,如果 l 已排序。 (抱歉,我想不出更简单的说法。) 示例 f([3,1,2]) = [2,
你好,我正在查看“假设一个排序数组在你事先不知道的某个枢轴旋转。(即 0 1 2 4 5 6 7 可能变成 4 5 6 7 0 1 2)”这个问题的 C++ 解决方案。你如何有效地在旋转数组中找到一个
让我们考虑这个简单的例子: import numpy as np a=np.arange(90) a=a.reshape(6,3,5) 我想得到一个数组 b形状 (6*5,3+1=4) 与 b[0:6
我正在编写一个 q 脚本,它在特定路径中加载一个数据库并对其进行一些处理。 db 的位置目前在脚本中是硬编码的,但我想将 db 路径作为参数传递并让它从变量中的路径加载。 目前它看起来像这样: q)
为什么我收到错误 Device: (3:9741) (0,l.useLinkBuilder) is not a function。 (在 '(0,l.useLinkBuilder)()' 中,'(0,
我有 ADT 版本 23.0.4 并安装了 Android 5.0 的 SDK 平台。 我读到 Android 5.0 Lolipop 的 API 级别为 21。但是在 Eclipse 的“新建应用程
我在 Google Play Store 中实现了一个抽屉导航,我想在 DrawerLayout 中设置列 TableView 的选定项目。但是后来发现在touch模式下无法选中item,有一个i
作为 C++ 的新手,我基本上有一个关于 g++ 编译器的问题,尤其是库的包含。考虑以下生成文件: CPPFLAGS= -I libraries/boost_1_43_0-bin/include/ -
我是一名优秀的程序员,十分优秀!