草庐IT

dynamic-invoke

全部标签

c++ - 你能合法地将dynamic_cast转换为多态类的非多态基类吗

在thisanswer,出现了以下场景:#includestructA{};structB{virtual~B(){}};structAA{};templatestructC:A,T{};intmain(){B*b=newC;AA*aa=newC;assert(dynamic_cast(b));assert(dynamic_cast(aa));//thislinedoesn'tcompile,asexpected}在g++4.8.4(Ubuntu)上,它编译并且断言通过。我的问题是,这真的合法吗?我觉得您根本不应该将dynamic_cast转换为非多态类,但我坦率地承认,我不是这里发生

c# - 从 C++、反向 P/Invoke、混合模式 DLL 和 C++/CLI 调用 C#

据我了解,我可以使用反向P/Invoke从C++调用C#。反向P/Invoke只是以下情况:创建托管(c#)类。创建一个c++/cli(以前托管的c++)类库项目。使用它来调用托管c#类(可能通过引用)。从原生c++调用c++/cli代码。问题:这是正确的吗?在第2步创建的DLL是否称为混合模式DLL?就MS而言,C++/CLI是否已完全取代托管C++?是否完全避免使用这种方法?将在什么时候创建和运行CLR,由谁创建和运行?提前致谢 最佳答案 以下是我所知的最佳答案:是的是的,它是一个混合模式DLL(事实上,您可以管理您的原生C++

c++ - 避免 dynamic_cast 的模式

我有一个类:classA{public:virtualvoidfunc(){…}virtualvoidfunc2(){…}};还有一些派生类,比如B、C、D...在95%的情况下,我想遍历所有对象并调用func或func2(),因此我将它们放在一个vector,例如:std::vector>myVec;…for(autoit=myVec.begin();it!=myVec.end();++it)(*it).func();但是,在其余5%的情况下,我想根据它们的子类对类做一些不同的事情。我的意思是完全不同的,比如调用带有其他参数的函数,或者根本不调用某些子类的函数。我已经想到了一些解决这

c++ - dynamic_cast 的正确用例是什么?

我多次被告知(并且在实践中看到我自己)使用dynamic_cast通常意味着糟糕的设计,因为它可以而且应该用虚函数代替。例如,考虑以下代码:classBase{...};classDerived:publicBase{...};...Base*createSomeObject();//MightcreateaDerivedobject...Base*obj=createSomeObject();if(dynamic_cast(obj)){//dostuffinoneway}else{//dostuffinsomeotherway}可以很容易地看出,我们可以将一个虚函数doStuff()

c++ - shared_dynamic_cast 和 dynamic_pointer_cast 的区别

谁能给我解释一下:shared_dynamic_cast和dynamic_pointer_cast来自Boost库?在我看来它们可能是等价的。 最佳答案 给定一个shared_ptr,这两个函数确实是等价的。区别在于shared_dynamic_cast仅适用于shared_ptr的,而dynamic_pointer_cast适用于任何类型的指针(通过重载)。这使您可以对任何指针concept执行动态转换,而不管该指针实际上是如何构成的:#include#includestructfoo{};structbar:foo{voidf(

c++ - 什么是 C++ 中的 std::invoke?

我刚刚阅读了有关std::thread和std::bind的内容,我遇到了Callable概念和std::invoke。我在cppreference上阅读了有关std::invoke的信息但我不明白它在说什么。这是我的问题:什么是std::invoke、std::function、std::bind和Callable的概念?它们之间又是什么关系? 最佳答案 std::invoke接受一些可调用的东西,以及调用它的参数,然后进行调用。std::invoke(f,args...)是键入f(args...)的一个小泛化,它还处理一些其他情

用于类比较的 C++ dynamic_cast vs typeid

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:C++equivalentofinstanceof我想知道dynamic_cast和typeid之间的区别仅在于类比较(除了dynamic_cast允许访问子类的方法和typeid仅对类比较有用)。我发现一个两年前的StackOverflow也在问同样的问题:C++equivalentofjava'sinstanceof.但是,它已经有两年了,我不想删除旧帖子(我不确定typeid什么时候出来),所以我想重新问同样的问题,但略有不同。基本上,我有类A和类B,它们都是抽象类C的子类。类C被作为方法的参数接收,我

C++:使用 boost::dynamic_pointer_cast 时出现 "... is not a polymorphic type"

为什么我会收到以下代码的以下错误?1>C:\Libs\boost_1_44\boost/smart_ptr/shared_ptr.hpp(259):errorC2683:'dynamic_cast':'my_namespace::A'isnotapolymorphictype1>D:\[location]\[header_filename].h(35):seedeclarationof'my_namespace::A'1>C:\Libs\boost_1_44\boost/smart_ptr/shared_ptr.hpp(522):seereferencetofunctiontempla

c++ - static_cast 与 dynamic_cast

这个问题在这里已经有了答案:关闭13年前.PossibleDuplicate:Regularcastvs.static_castvs.dynamic_cast我不太明白何时使用静态类型转换和何时使用动态类型转换。请问有什么解释吗? 最佳答案 从基类类型转换为派生类类型时使用dynamic_cast。它检查被强制转换的对象实际上是派生类类型,如果对象不是所需类型,则返回一个空指针(除非你正在强制转换为引用类型——然后它会抛出一个bad_cast异常)。如果不需要此额外检查,请使用static_cast。正如Arkaitz所说,由于dy

node.js - Passport Facebook : how to dynamically set callbackURL?

我正在按照这个例子来设置一个FacebookStrategy-https://github.com/jaredhanson/passport-facebook/blob/master/examples/login/app.js我想动态设置callbackURL,即:用户访问/posts/34,所以回调将是/posts/34/callback我怎样才能实现这样的目标? 最佳答案 我找到了解决方案,auth重定向路由和回调路由都应该用function(req,res,next)包装passport.authenticate()。我按照h