我可以获取标准库中定义的函数的地址吗?
标准 C 函数是强大的工具,但它们与语法的交互像 std::invoke 有时会揭示意想不到的行为。考虑以下代码:
#include <cctype> #include <functional> #include <iostream> int main() { std::invoke(std::boolalpha, std::cout); // #1 using ctype_func = int(*)(int); char c = std::invoke(static_cast<ctype_func>(std::tolower), 'A'); // #2 std::cout << c << "\n"; }
第一次使用 std::boolalpha 调用 std::invoke 按预期工作,导致调用 std::cout.setf(std::ios_base::boolalpha )并设置布尔输出格式。然而,第二次使用 std::tolower 的调用引起了关注。
预期输出有保证吗?
不幸的是,这段代码的预期输出不保证在 C 20 中保证。根据[namespace.std](https://en.cppreference.com/w/cpp/header/namespace/std),获取标准库函数的地址(除非它被指定为可寻址)是未定义的行为。 std::tolower 函数就属于这一类。
这是为什么?
原因在于 C 标准库头文件
结论
总而言之,即使std::tolower 的行为与 C 代码片段中具有可寻址属性的标准库函数类似,其作为 C 函数的底层实现使其地址具有未定义的行为。此行为并非特定于 std::tolower,而是适用于未明确指定为可寻址的任何标准库函数。
以上是我可以获取像'std::tolower”这样的标准库函数的地址吗?的详细内容。更多信息请关注PHP中文网其他相关文章!