- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在编译 C++ 构建时遇到了一些问题:我收到了来自编译器的两条警告。
connection.c(813): warning C4715: 'd2cs_conn_set_addr' : not all control paths return a value
这是代码指向我的地方:
extern int d2cs_conn_set_addr(t_connection * c, unsigned int addr)
{
ASSERT(c,-1);
c->addr = addr;
}
fdwatch_iocp.c(246): warning C4700: uninitialized local variable 'ret' used
这篇文章的要点:
if ((rw & fdwatch_type_read) && !(rw & fdwatch_type_accept) && !(orig_state & fdwatch_type_read))
{
memset(tmpev, 0, sizeof(WSAOVERLAPPED));
ret = WSARecv(fdw_fd(fdw_fds + idx), &wsaBuf, 1, &dummy1, &dummy2, (LPWSAOVERLAPPED)tmpev, NULL);
if ((ret == -1) && (err = GetLastError()) != 997)
{
eventlog(eventlog_level_fatal, __FUNCTION__, "cannot update iocp sock %d with read state: %d", fdw_fd(fdw_fds + idx), err);
//printf("Error %d on WSARecv\n", err);
}
if (fdw_rw(cfd) & fdwatch_type_read && pending_ev->events == fdwatch_type_read)
{
if (hnd(fdw_data(cfd), fdwatch_type_read) == -2)
{
return;
}
memset(tmpev, 0, sizeof(WSAOVERLAPPED));
WSARecv(fdw_fd(fdw_fds + idx), &wsaBuf, 1, &dummy1, &dummy2, (LPWSAOVERLAPPED)tmpev, NULL);
if ((ret == -1) && (err = GetLastError()) != 997)
{
eventlog(eventlog_level_fatal, __FUNCTION__, "cannot update iocp sock %d with read state: %d", fdw_fd(fdw_fds + idx), err);
//printf("Error %d on WSARecv\n", err);
}
我没有编写代码,我只是想编译没有错误。
最佳答案
第一个警告很明确:函数被声明为返回一个 int
,但不返回任何内容。如果它被调用,它将导致程序的未定义行为 (UB)。
对于第二个警告,UB是否会发生取决于这两个条件之间的关系:
(rw & fdwatch_type_read) && !(rw & fdwatch_type_accept) && !(orig_state & fdwatch_type_read)
fdw_rw(cfd) & fdwatch_type_read && pending_ev->events == fdwatch_type_read
如果第二个暗示第一个,一切都很好,可以安全地忽略警告。如果第一个为假而第二个为真,这种情况将再次调用 UB(因为 ret
仅在第一个为真时才初始化)。
分析到此为止,得出结论。
如果不了解程序应该做什么,我们就不可能说出如何修复这些警告。从技术上讲,最直接的修复方法是从 d2cs_conn_set_addr
返回 something1,并将 ret
初始化为 其他功能中的某物2。
让我们先看看ret
。
由于涉及 ret
的两个条件似乎都将 -1
视为错误值,因此对于 something2 来说是一个很好的值。/em> 可以是 -1
(基本上,将其初始化为错误状态)。
但是,仔细查看代码会发现您发布的两种情况下的代码之间存在差异。最上面的一个调用 WSARecv
并将其返回值分配给 ret
,而第二个简单地调用 WSARecv
并忽略返回值。因此,更可能的正确解决方法是将第二条这样的行从
WSARecv(fdw_fd(fdw_fds + idx), &wsaBuf, 1, &dummy1, &dummy2, (LPWSAOVERLAPPED)tmpev, NULL);
到
ret = WSARecv(fdw_fd(fdw_fds + idx), &wsaBuf, 1, &dummy1, &dummy2, (LPWSAOVERLAPPED)tmpev, NULL);
(这顺便说明了为什么只在需要的地方声明变量是个好主意)
现在为 d2cs_conn_set_addr
。
这个比较棘手。如果你想找到合适的返回值,你需要检查调用点(调用该函数的地方)并查看他们期望的返回值。他们可能会期望一个成功/失败的返回值,可能是非零与 0
,或者 0
与 -1
,或者其他别的。这样的检查会告诉你应该返回什么。这可能是成功代码,因为该函数不会以任何明显的方式失败。
当然除非 ASSERT(c, -1)
的使用实际上扩展为
if (!c) return -1;
或类似的,这会给它一个失败模式(并且还建议正确的返回值可以是 0
或“-1
以外的任何值”或“任何值非负数”)。
因此,除了调用 d2cs_conn_set_addr
的代码之外,还要检查 ASSERT
的定义,希望能更好地理解如何修复它。
总而言之:这段代码完全错误,如果这种程度的错误设法潜入其中,谁知道那里还潜伏着什么其他问题。如果可能的话,您应该避开它并且不要使用它。
如果您坚持使用它,则需要对潜在问题进行非常彻底的检查。
关于c++ - 警告 C4715 : 'd2cs_conn_set_addr' : not all control paths return a value,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39633899/
这是我的作业 What does echo PATH $PATH \$PATH do? 我不知道它是如何工作的。 echo PATH打印“路径” $PATH创建一个“PATH”变量......也许?
我想弄清楚两者之间的区别 路径=路径+[节点1] 路径+=[节点1] path.append(node1) 我得到的是 path = path + [node1] 的正确路径,但不是其他两个。 def
我使用 Robot 框架在 Ride 中创建了一个测试用例。运行时出现错误。 我更新了python的路径。我更新了库和 Ride。我换了文件夹还是不行 *** Settings *** Documen
我尝试使用额外的功能自定义 pathlib.Path()。特别是,我真的很喜欢使用上下文管理器作为移入和移出目录的方法。我一直在使用它,但我似乎在让 Path() 与自定义上下文管理器一起工作时遇到错
编辑:基于 Ulf Rompe 的评论,重要的是使用“1”而不是“0”,否则您将破坏 sys.path . 我已经做 python 很长一段时间了(一年多),我总是很困惑为什么人们建议你使用 sys.
我有兴趣这样做的原因是因为我的路径中有一部分将保持不变,但我希望将其与其所有父部分一起删除。 所以如果我们说, some/unknown/path/foo/bar/baz 我想回去 bar/baz 但
在几个 SO 的问题中,有这些行可以访问代码的父目录,例如os.path.join(os.path.dirname(__file__)) returns nothing和 os.path.join(o
我已经在我的 Linux 中安装了 anaconda 来导入 python 包。 安装 anaconda 后,我无法在 python 中使用 anaconda,经过一番搜索后我发现输入此命令我能够使用
哪个更好用,为什么?我的意思是这两个命令在哪些方面不同以及如何不同?性能、可读性…… new FileInfo(path).Name 或 Path.GetFileName(path) 最佳答案 因为您
这不适用于某些设备。 在三星设备中,他们不允许使用下载管理器下载文件。 我已经在 list 中定义了权限并获得了运行时权限。 DownloadManager downloadManager = (Do
我想知道在这个例子中使用 Paths.get() 和 Path.resolve 有什么区别: public static void main(String[] args) { Path p1
目前我正在开发一个转换由 Inkscape 创建的 svg-paths 的应用程序。现在我不清楚关于绝对和相对路径组合的路径规范。规范是否说明了同时包含相对和绝对坐标的路径定义? 特别是关于绝对贝塞尔
我正在编写脚本,我需要在用户的 $PATH 上查找命令并获取该命令的完整路径。问题是我不知道用户的登录 shell 是什么,或者他们的 do 文件中可能有什么奇怪的东西。我将 bourne shell
Metalsmith 的文档对 path() 函数没有太多解释:#path(paths...): Resolve any amount of paths... relative to the work
我知道我可以通过 regedit 更改我的 wine PATH,但实际上我只需要为一次运行更改 PATH。 例如,我的软件名为frontend.exe,这取决于example/mylib.dll,我需
因此,绝对路径是一种到达某个文件或位置的方法,描述了它的完整路径、完整路径,并且它依赖于操作系统(Windows 和 Linux 的绝对路径,例如,不同)。另一方面,相对路径是从当前位置 ..(两个点
我对编程有点陌生(不是真的,但我仍在学习 - 我们不是吗?)。虽然我了解 Java 和 Python,并且了解 C、C++、JS、C#、HTML、CSS 等(并且我可以在终端中很好地导航),但我不熟悉
我对编程有点陌生(不是真的,但我仍在学习 - 我们不是吗?)。虽然我了解 Java 和 Python,并且了解 C、C++、JS、C#、HTML、CSS 等(并且我可以在终端中很好地导航),但我不熟悉
这个问题不太可能对任何 future 的访客有帮助;它只与一个较小的地理区域、一个特定的时间点或一个非常狭窄的情况相关,通常不适用于全世界的互联网受众。如需帮助使此问题更广泛适用,visit the
使用环境变量(如 PATH)作为 $PATH 或 ${PATH} 有什么区别? 最佳答案 在大多数情况下没有区别。唯一重要的是你是否想在扩展后包含尾随文本。例如,假设您的 PATH 包含字符串 FOO
我是一名优秀的程序员,十分优秀!