草庐IT

adapt_struct

全部标签

c++ - boost spirit qi on_error 通过引用传递 error_handler struct

我又遇到了灵气障碍问题。我在一个名为error_handler的仿函数结构中实现了错误处理。这通过引用传递给语法构造函数(参见Qi的MiniC示例)。然后我有on_errors在语法的构造函数中定义:typedefboost::phoenix::function>error_handler_function;on_error(gr_instruction,error_handler_function(err_handler)(L"Error:Expecting",_4,_3));//moreon_errors...但是,我的error_handler有私有(private)成员。好像每

c++ - 使用 not2 时将 struct vs class 作为 STL 仿函数

学习STL我写了一个简单的程序来测试仿函数和修饰符。我的问题是关于使用CLASS或STRUCT编写仿函数并尝试使用函数适配器对其进行操作的区别。据我在C++中的理解,CLASS和STRUCT之间的区别在于,在最后一种情况下,默认情况下成员是公共(public)的。这也是我在该站点的答案中多次阅读的内容。所以请解释为什么即使我在尝试使用not2修饰符时将所有成员(只是一个函数重载())声明为public,这段短代码也会编译失败。(我还没有尝试过其他修饰符,例如粘合剂)#include#include#include#includeusingnamespacestd;templatevoi

C++ 错误 : forward declaration of 'struct. ..?

循环包含问题我转发声明其中一个类在另一个类的标题中,试图解决它们的循环包含问题。这是我的两个文件:第一个文件(Parameter.h):#pragmaonce#include"Token.h"`classExpression;classParameter{public:Parameter(){string=newToken();identifier=newToken();expr=newExpression();}Token*string;Token*identifier;Expression*expr;};第二个文件(Expression.h):#pragmaonce#include

论文阅读 - HOFA: Twitter Bot Detection with Homophily-Oriented Augmentation and Frequency Adaptive Atten

摘要        Twitter机器人检测已成为一项日益重要和具有挑战性的任务,以打击在线虚假信息,促进社会内容审查,并维护社会平台的完整性。        虽然现有的基于图表的Twitter机器人检测方法取得了最先进的性能,但它们都是基于同质性假设的,即假设拥有相同标签的用户更有可能被连接,这使得Twitter机器人很容易通过跟踪大量真实用户来伪装自己。        为了解决这个问题,我们提出了HOFA,一种新的基于图形的Twitter机器人检测框架,它使用面向同质性的图形增强模块(Homo-Aug)和频率自适应注意模块(FaAt)来对抗异种伪装的挑战。        具体来说,Homo

c++ - struct S { int align; 之间的区别}; (在 struct 关键字之后命名)和 struct { int align; } S; (结构定义后的名称)

#includestructHeader{unsignedlonglongintalignment;};intmain(void){structHeaderheader;//note:wecanloosethe'struct'inC++structHeader*pheader=&header;return0;}上面的程序在C和C++中都能完美编译。但是当我将Header结构更改为:struct{unsignedlonglongintalignment;}Header;它失败并在C中显示以下消息:错误:“Header”的存储大小未知在C++中:error:aggregate‘main()

c++ - 使用数组和某些方法来 memcpy struct 是否安全?

我想知道在包含数组和方法的结构上使用memcpy是否安全(只是一些getter和setter,因为数组的索引是不寻常的,我必须以某种方式映射它)。我知道它对POD是安全的,但我不确定我的结构是否会被视为POD? 最佳答案 您可以使用memcpy如果struct是TriviallyCopyable.您可以检查您的struct可以通过使用std::is_trivially_copyable轻松复制.此外,正如@JohanLundberg在评论中指出的那样,目标地址必须是0模std::alignment_of.您可以在http://en.

c++ - "Adapter"为成员变量

通常,适配器的目的是以修改后的格式进行函数调用。有没有办法对成员变量做同样的事情?也就是说,假设我有一个包含SomePoint的对象和另一个包含DifferentPoint的对象。SomePoint将其数据存储为大写的成员变量X和Y其中AnotherPoint将其数据存储为小写的成员变量x和x。所以问题是你不能写一个接受SomePoint或DifferentPoint的函数,因为你不能访问.x或.X(即使使用模板而不完全专门针对每个不同的点类型,在这种情况下,您也可以只重载点类型)。问题是有没有一种方法可以让适配器在请求.x时为SomePoint生成.X?这两种点类型都是库类,所以我不

c++ - 为什么 offsetof(member) 等于 sizeof(struct)?

我有一个结构定义为:structsmth{chara;intb[];};当我在此结构上调用sizeof和offsetof时:cout输出是:44为什么stuct的大小是4,char占用1个字节,int数组的偏移量是4?为什么会有某种填充?另外,为什么int数组根本不占用任何空间? 最佳答案 Howcomewhenthesizeofthestuctis4andcharisusing1byte,theoffsetoftheintarrayis4?Whyistheresomekindofpadding?有填充是因为C标准允许;编译器经常对

c++ - vector in struct 耗时吗?使用指针更好吗?

我在C++中有一个这样的结构:structMyStruct{someTypev1;someType2v2;someType3v3;someType4f1();std::vectormyVector;};它会经常以这样的形式使用://someprocess...afterwhichastd::vectorvec1isgeneratedMyStructmyStruct;myStruct.myVector=vec1;由于vec1比较大。我想知道通过执行分配myStruct.myVector=vec1;是否花费很多时间我是否应该在MyStruct中使用指向myVector的指针来使其更快?如何

C struct中的c++字符串是否非法?

structrun_male_walker_struct{stringmale_user_name;stringshow_name;};typedefstructrun_male_walker_structrun_male_walker_struct_t;在另一个函数中:run_male_walker_struct_t*p=malloc(sizeof(structrun_male_walker_struct));问题,违法吗?由于字符串是一个类,它的大小不能由sizeof()确定。 最佳答案 这是非法的,但不是出于您所想的原因。st