草庐IT

any_cast

全部标签

c++ - 比较 boost::any 内容

我正在使用一个容器来保存指向任何内容的指针列表:structExample{std::vectorelements;}为了在这个容器中插入元素,我写了几个辅助函数(structExample的成员):voidadd_any(boost::any&a){elements.push_back(a);}templatevoidadd_to_list(T&a){boost::anybany=&a;add_any(bany);}现在,我只想插入不存在于此容器中的元素。为此,我认为我只需要使用适当的比较器函数在elements上调用search。但是,我不知道如何比较boost::any实例。我的

mockito - <reified T> 和 <reified T : Any> in Kotlin? 有什么不同

下面的测试类,通过。classSimpleClassTest{privateinlinefunanyObject():T{returnMockito.anyObject()}lateinitvarsimpleObject:SimpleClass@MocklateinitvarinjectedObject:InjectedClass@BeforefunsetUp(){MockitoAnnotations.initMocks(this)}@TestfuntestSimpleFunction(){simpleObject=SimpleClass(injectedObject)simpleOb

mockito - <reified T> 和 <reified T : Any> in Kotlin? 有什么不同

下面的测试类,通过。classSimpleClassTest{privateinlinefunanyObject():T{returnMockito.anyObject()}lateinitvarsimpleObject:SimpleClass@MocklateinitvarinjectedObject:InjectedClass@BeforefunsetUp(){MockitoAnnotations.initMocks(this)}@TestfuntestSimpleFunction(){simpleObject=SimpleClass(injectedObject)simpleOb

c++ - 在 Clang 中禁用 "cast from pointer to smaller type uint32_t"错误

我正在从事一个学校项目,该项目涉及在实验硬件上移植一大段C++代码。不幸的是,该硬件是64位的,并且代码包含许多指针算术实例,这些实例期望指针是32位的,即它通常是reinterpret_cast(ptr)。.一个一个地浏览它们会非常乏味,而且由于无论如何这是一个实验项目,我很乐意接受一个“hackish”的解决方法。因此,我修改了malloc的实现,以确保它永远不会分配超过4GB限制的内存。因此,从技术上讲,这些类型转换应该是有效的。问题是,我该如何向Clang解释这一点?我得到的错误是:error:castfrompointertosmallertype'uint32_t'(aka

c++ - 以下使用 const_cast 是未定义的行为吗?

这个问题在这里已经有了答案:Isconst-castingawayconst-nessofreferencestoactualconstobjectspermittediftheyarenevermodifiedthroughthem?(2个答案)关闭2年前。这是一个语言律师问题,不是一个好的实践问题。以下代码是有效的还是未定义的行为?一个const对象最终会调用一个非常量函数,但它实际上并没有修改对象的状态。structBob{Bob():a(0){}int&GetA(){returna;}constint&GetA()const{returnconst_cast(*this).Ge

c++ - 错误 : out-of-line definition of 'test' does not match any declaration in 'B<dim>'

我有一个小问题让我很烦!!我不知道下面的代码似乎有什么问题。我应该能够实现从父类(superclass)继承的功能,不是吗?但我得到error:out-of-linedefinitionof'test'doesnotmatchanydeclarationin'B'templateclassA{public:virtualdoubletest()const;};templateclassB:publicA{};templatedoubleB::test()const{return0;}我在Mac上使用clang(AppleLLVM5.1版)。 最佳答案

c++ - reinterpret_cast 与严格别名

我正在阅读有关严格别名的内容,但它仍然有点模糊,我不确定定义/未定义行为的界限在哪里。最详细post我发现专注于C。所以如果你能告诉我这是否被允许以及自C++98/11/...以来发生了什么变化,那就太好了#include#includetemplateTtransform(Tt);structmy_buffer{chardata[128];unsignedpos;my_buffer():pos(0){}voidrewind(){pos=0;}templatevoidpush_via_pointer_cast(constT&t){*reinterpret_cast(&data[pos]

c++ - 为什么我们使用 static_cast 为 NULL

当我尝试研究QP/CPP代码时,我遇到了以下行。QTimeEvt*t;//...if(t==static_cast(0)){为什么他们要做0的static_cast?如果他们想检查NULL,我们可以直接这样做吗?这个源代码你可以在中找到http://www.state-machine.com/qpcpp/qf__time_8cpp_source.html 最佳答案 是的,这是不必要的,尽管它可能是某些风格指南为了“清晰”而强制要求的,或者它可能是为了让过度热心的静态分析工具沉默。当然,如今,我们只需编写nullptr就可以了。

c++ - C++ 中的 const_cast 规则

structfoo{constintA;intB;foo():A(10),B(20){}};voidmain(){foof1;const_cast(f1.A)=4;//line1constfoof2;const_cast(f2.B)=4;//line2}第1行和第2行是否都表现出未定义的行为?如果f1和f2是上面代码中列出的类型的shared_ptr,行为会有所不同吗? 最佳答案 两者的行为const_cast(f1.A)=4和const_cast(f2.B)=4未定义。如果一个对象最初定义为const,然后你扔掉了const-ne

C++我们什么时候应该更喜欢使用两个链接的static_cast而不是reinterpret_cast

首先,这不是Whydowehavereinterpret_castinC++whentwochainedstatic_castcandoit'sjob?的拷贝.我知道我们甚至不能使用两个链式static_cast来实现的情况,reinterpret_cast所做的。但是在任何情况下我应该更喜欢两个链接的static_cast而不是简单且更具可读性的reinterpret_cast? 最佳答案 reinterpret_cast应该是一个巨大的闪烁符号,表示这看起来很疯狂,但我知道我在做什么。不要因为懒惰而使用它。reinterpret