草庐IT

external-sorting

全部标签

C++:extern "C"和类成员之间的命名空间冲突

我偶然发现了一个相当奇特的c++命名空间问题:浓缩示例:extern"C"{voidsolve(lprec*lp);}classA{public:lprec*lp;voidsolve(intfoo);}voidA::solve(intfoo){solve(lp);}我想在我的C++成员函数A::solve中调用c函数solve。编译器对我的意图不满意:errorC2664:'lp_solve_ilp::solve':cannotconvertparameter1from'lprec*'to'int'我可以在solve函数前加前缀吗?C::solve不起作用

c++ - 为什么 std::sort 不接受函数内声明的比较类

我当时正在工作,在一个函数中编写比较器(稍后移动,当我决定最好的地方时),并注意到了这个特性。我想了一会儿,意识到我不明白为什么如果我使用内部比较器代码将无法编译,但外部比较器很好。有什么解释吗?快速测试工具:#include#include#includeclassCompareMe{public:CompareMe(intin):toCompare(in){}inttoCompare;};classComparators{public:booloperator()(CompareMe*first,CompareMe*second){returnfirst->toComparetoC

c++ - qsort() vs std::sort,比较函数哲学差异

我想知道为什么在qsort(){Cversion}和std::sort()中有两种完全不同的方法来指定比较函数。qsort需要这样的比较函数:不知道为什么需要三种返回值-1、0、+1。intcomp(int*x,int*y){return*x-*y;}而std::sort()的比较函数对我来说看起来更一致,因为它是根据函数编写的,遵循不变量。即如果x小于y函数返回true,则x相对于y处于正确位置boolcomp(intx,inty){returnx当返回一个bool(或具有两个值0和1的int)更简单和干净时,为什么我们需要三个值-1,0,+1? 最佳答案

c++ - 在不使用 extern "C"的情况下从 C 调用 C++ 函数

是否可以从C代码调用C++DLL中的函数?该函数未声明extern"C"。仅适用于VisualStudio的丑陋的平台相关hack很好。调用约定不应该是一个主要问题,但我该如何处理名称修改。?例如,在VisualStudio中,带有签名voidf()的C++函数的名称被破坏了?f@@YAXXZ,这不是合法的C标识符。(您不需要告诉我应该将C++函数声明为extern"C"。我已经知道了。但我处于无法更改C++代码的情况。) 最佳答案 将违规函数包装在另一个C++函数中,并使用extern"C"声明它。无需为其创建特殊的DLL,只需在

c++ - 用 c 包装一个 c++ 库? (不要 "extern c")

是否可以将c++库包装到c中?我该怎么做?有现成的工具吗?(需要访问现有的c++库,但只能使用C) 最佳答案 您可以用C编写面向对象的代码,因此如果它是面向对象的C++库,则可以将其包装在C接口(interface)中。然而,这样做可能会非常乏味,尤其是当您需要支持继承、虚函数和诸如此类的东西时。如果C++库采用通用编程(模板),它可能会变得非常棘手(您需要提供所有需要的模板实例)并很快接近不值得这样做的地步。假设它是OO,下面是如何在C中实现OO的基本草图:C++类:classcpp{public:cpp(inti);voidf(

c++ - 什么时候使用 extern "C"?

我知道如何使用extern"C"但必须在什么条件下使用它?extern"C"tellstheC++compilernottoperformanyname-manglingonthecodewithinthebraces.ThisallowsyoutocallCfunctionsfromwithinC++.例如:#includeintmain(){chars[]="Hello";chard[6];strcpy_s(d,s);}虽然这在VC++上编译得很好。但有时这会写成:extern"C"{#include}我不明白这一点。你能举一个需要extern"C"的真实例子吗?

c++ - 在对对象的 vector 进行排序时使用 stable_sort

我有classPassanger有变量stringname;stringstation;stringticket;然后我有另一个类,在这个类中我有vectormyQueue;现在我想使用stable_sort排序myQueue.有没有可能,怎么说给stable_sort,应该是什么key,根据它排序myQueue?std::stable_sort(myQueue.begin(),myQueue.end(),maybeSomethingElse());? 最佳答案 std::stable_sort()过载接受自定义比较器作为其第三个参

c++ - Clrdump (C++) 错误 LNK2019 : unresolved external symbol __imp__RegisterFilter@8 referenced in function _main

我正在使用带有pvcs编译器的makefile系统(使用MicrosoftVisualC++,2008编译器),我收到了几个以下形式的链接错误:errorLNK2019:unresolvedexternalsymbol__imp__RegisterFilter@8referencedinfunction_main尽管使用了extern"C"声明,但还是会发生这种情况,即:extern"C"intCLRDUMP_APIRegisterFilter(LPCWSTRpDumpFileName,unsignedlongDumpType);此外,在makeexe.mak中,库链接如下:$(编译库

c++ - std:sort 与插入 std::set

我正在从cin读取一些线段。每条线段由起点和终点表示。2D。X和Y。输入未排序。它是随机排列的。(更新:但我需要它们先按X再按Y排序)我可以读取所有段,将它们存储在一个vector中,然后调用std::sort。另一方面,我可以创建一个空的std::set并在每个段到达时插入它。该集合将自动维护排序顺序。这两种方法哪种更有效?更新:输入的总大小(段数)是预先知道的。 最佳答案 您应该测量这两种方法的性能以确保确定,但可以安全地假设std::vector上的std::sort是way比插入std::set更快,因为局部效应和隐藏在树插

c++ - 为什么 std::sort 会在此代码上抛出段错误?

有人可以解释为什么下面的排序会导致段错误吗?这是g++(指针的排序vector)的已知错误吗?我正在使用g++4.5.2进行编译。#include#include#includeusingnamespacestd;typedefvectorA;boolface_cmp(constA*x,constA*y){returnx!=y;}intmain(intargc,char*argv[]){vectorvec;for(inti=0;i(i%100,i*i));}vector::iteratorit;sort(vec.begin(),vec.end(),face_cmp);returnEXI