4

我想使用第三方函数,它通过一个充满函数指针的结构提供它的 API。例如:

struct S {
    using p_func1 = int(*)(int, int);
    p_func1 func1;
    using p_func2 = int(*)(char*);
    p_func2 func2;
}

第三方库初始化这个结构。需要检查这些函数(func1、func2)的返回值,我希望我能以某种方式体现在[[discard]]属性上以确保检查返回值。

有什么办法可以做到这一点,同时保持结构的 ABI?

编辑:到目前为止,我能想到的最好的方法是拥有另一个结构,如下所示:

struct S_wrap {
    S orig;
    [[nodiscard]] int func1(int a, int b){ return orig.func1(a, b); }
    [[nodiscard]] int func2(char* a){ return orig.func2(a); }
}

我希望有更好的东西

4

1 回答 1

2

您的包装器(或任何包装器)是唯一的方法。该属性适用于函数 declarator-id(它的名称),而不是函数的类型。所以在使用指针的时候会丢失,也不能应用到指针本身:

[dcl.attr.nodiscard]

1属性标记nodiscard可应用于函数声明中的 declarator-id 或类或枚举的声明。它在每个属性列表中最多出现一次,并且不应出现任何属性参数子句。

因此,如果函数指针返回一个int,则防止丢弃结果的唯一方法是使用某种包装器,该包装器带有operator()应用了该属性的命名函数(或 )。

于 2019-01-28T11:06:42.350 回答