草庐IT

return-address-labels

全部标签

C# 应用程序调用 C++ 方法,错误 : PInvoke: Cannot return variants

我正在尝试弄清楚如何将复杂对象从C++dll返回到调用C#应用程序。我有一个简单的方法,它返回一个工作正常的int。谁能告诉我我做错了什么?C#应用程序:classProgram{staticvoidMain(string[]args){//Erroronthisline:"PInvoke:Cannotreturnvariants"vartoken=LexerInterop.next_token();}}C#LexerInterop代码:publicclassLexerInterop{[DllImport("Lexer.dll")]publicstaticexternobjectnex

c++ - 该程序在 main() 上的 'return;' 之后需要很长时间才能关闭

这是我正在处理的代码:#include#includeusingnamespacestd;staticunsignedlongcollatzLength(unsignedlongn){staticstd::mapcollatzMap;intmapResult=collatzMap[n];if(mapResult!=0)returnmapResult;if(n==1){return1;}else{collatzMap[n]=1+collatzLength(n%2==0?n/2:3*n+1);returncollatzMap[n];}}intmain(){intmaxIndex=1;uns

c++ - return 语句是否为按值返回的函数创建一个临时对象?

在学习C++11右值引用和移动语义时,我开始对函数究竟如何返回值来初始化变量感到困惑。看下面的例子:WidgetmakeWidget(){Widgetw;…returnw;}Widgetw1=makeWidget();这里我假设没有RVO(即编译不会省略复制/移动)。当执行返回语句returnw;时,执行函数:1)在众所周知的位置(调用者知道的某个固定寄存器或内存位置)复制初始化一个临时对象,其值成为函数的返回值?然后调用者获取这个对象来复制初始化w1?或者2)函数获取w1的调用者传递的内存位置,函数的自动变量w用于复制初始化w1?(这已经是某种RVO了吗?还是某种内联函数行为?或者它

c++ - return *this 在 C++ 中安全吗?

我想知道从函数返回*this是否安全。this问题显示了一些你可以做到的方法,我的问题是这个例子:structtest{stringt;stringb;public:test&A(stringtest){this->t=test;return*this;}test&B(stringtest){this->b=test;return*this;}};intmain(){autoa=test().A("a").B("b").A("newa");return0;}会不会有内存泄漏? 最佳答案 isreturn*thissafeinc++基

c++ - 哪个更好 : returning tuple or passing arguments to function as references?

我创建的代码中有两个函数returnValues和returnValuesVoid。一个返回2个值的元组,另一个接受参数对函数的引用。#include#includestd::tuplereturnValues(constinta,constintb){returnstd::tuple(a,b);}voidreturnValuesVoid(int&a,int&b){a+=100;b+=100;}intmain(){auto[x,y]=returnValues(10,20);std::cout我读到了http://en.cppreference.com/w/cpp/language/st

c++ - 'unused' 的初始化被 'goto label' 跳过 - 为什么我为 std::string 而不是为 int 获取它?

我在某些代码中遇到了这个错误,经过一些试验后我偶然发现了这个怪异之处——我为std::string得到了它,但没有为int得到它。对于std::string我得到errorC2362:initializationof'unused'isskippedby'gotolabel':{gotolabel;std::stringunused;label:;}对于int我没有收到任何错误,但是:{gotolabel;intunused=10;label:;}为什么不同?是因为std::string有一个非平凡的析构函数吗? 最佳答案 这包含在

c++ - 多重继承 : Different Address same address

我写了一个示例程序。如果我打印pa和pb的地址都是不同的。你能告诉我为什么会这样吗?#includeusingnamespacestd;classA{intx;};classB{inty;};classC:publicA,publicB{intz;};intmain(){Cc;A*pa;B*pb;pa=&c;pb=&c;cout 最佳答案 作为KerrekSB把它,pa和pb在您的示例中,实际上并不指向c,而是指向A和Bc的子对象.通过多重继承,来自基类的数据本质上是一个接一个地堆叠起来。基类型指针只是偏移到该基类的数据。正因为如此

C++ 错误 : "taking address of temporary array"

我试图在if语句中声明一个数组。我以这种方式编写代码,以便在ifblock退出后对象保留在范围内,但现在我遇到了一个新问题:“获取临时数组的地址”。我怎样才能用另一种方式重写它,以便为maskArray分配正确的值?int*maskArray;if(conditional==true)maskArray=(int[9]){0,1,0,1,-4,1,0,1,0}; 最佳答案 假设您以后不打算修改maskArray指向的内容,那么最好/最简单的解决方案是:constint*maskArray;if(conditional==true){

c++ - 谷歌模拟 : Return() a list of values

通过GoogleMock的Return(),您可以返回调用模拟函数后将返回的值。但是,如果期望某个函数被调用多次,并且每次都希望它返回不同的预定义值。例如:EXPECT_CALL(mocked_object,aCertainFunction(_,_)).Times(200);如何让aCertainFunction每次都返回一个递增的整数? 最佳答案 使用sequences:using::testing::Sequence;Sequences1;for(inti=1;i 关于c++-谷歌模

c++ - 编译器警告 : lambda return type cannot be deduced

考虑这个例子:#include#includeintmain(){std::stringstr="abcde4fghijk4l5mnopqrs6t8uvwxyz";std::stringstr2;std::remove_copy_if(str.begin(),str.end(),std::back_inserter(str2),[](char&c){if(std::isdigit(c))returntrue;//使用GCC4.6.1,这可以很好地编译并打印出预期的输出(字母表),但我收到一条警告说“只有当return语句是函数体中的唯一语句时,才能推导出lambda返回类型”.现在,我