草庐IT

import_orders

全部标签

c++ - Windows 上 DLL Exporting/Importing 和 Extern 的问题

我有一些关于Windowsdll的快速问题。基本上我使用ifdefs来处理dllexport和dllimport,我的问题实际上是关于dllexports和dllimports以及extern关键字的放置。我将dllimports/dllexports放在头文件中,但我是否必须将dllexport和dllimports放在实际定义中?对于typedef呢?我是否将dllimport/dllexport放在前面?如dllexporttypedefmapst_map另外关于extern关键字,我看到它被这样使用:extern"C"{dllexportvoidfunc1();}我也看到它被这

c++ - 如何测试 std::memory_order_relaxed 的行为?

我已经阅读了std::memory_order_relaxed的文档.Relaxedordering的部分解释是......//Thread1:r1=y.load(memory_order_relaxed);//Ax.store(r1,memory_order_relaxed);//B//Thread2:r2=x.load(memory_order_relaxed);//Cy.store(42,memory_order_relaxed);//D对此的解释是……[It]isallowedtoproducer1==r2==42.Inparticular,thismayoccurifDisc

python - C++ python API : second call of PyImport_Import results in SIGSEGV

我正在尝试通过cApi从c++调用python,以获取c++中两个numpy数组的值。第一次调用我的程序callPython()时,一切似乎都运行良好,但第二次调用导致SIGSEGV时pModule=PyImport_Import(pName);被执行。在flebool的回答中,有一个比我的简单得多的最小示例代码,但有同样的错误。最小.cpp#include#includelongintgeTuple(PyObject*pValue,PyObject*objI,inti){objI=PyTuple_GetItem(pValue,i);longintn,M;double*xJ;if(ob

c++ - 如何将标准库与 C++ 模块一起使用? (例如 : `import std.io` )

HowdoIuseC++modulesinClang?中给出的基本示例对我有用,但不导入标准库(例如通过importstd.stdio;);过去之后http://clang.llvm.org/docs/Modules.html不清楚如何在C++模块中使用标准库,例如://foo.cppm:exportmodulefoo;//works:#include//noneofthesework:importstd.stdio;importstd.io;importstd;exportvoidtest_foo(){printf("helloworld\n");}这给出了一个错误:clang++-

C++0X memory_order 无围栏,应用,支持的芯片

作为我之前question的跟进,atomic类使用memory_order指定大多数操作范围。与栅栏相反,此内存顺序仅影响其操作的原子。据推测,通过使用几个这样的原子,您可以构建一个并发算法,其中其他内存的顺序并不重要。所以我有两个问题:有人能给我指出一个算法/情况的示例,该算法/情况可以从单个原子变量的排序中受益并且不需要需要栅栏吗?哪些现代处理器支持这种行为?也就是说,编译器不会只是将特定顺序转换为正常的围栏。 最佳答案 关于std::atomic操作的内存排序参数变量不会影响该操作本身的顺序,它会影响该操作与其他操作创建的顺

c++ - 为什么 memory_order_relaxed 在 x86 上使用原子(锁前缀)指令?

在VisualC++2013上,当我编译以下代码时#includeintmain(){std::atomicv(2);returnv.fetch_add(1,std::memory_order_relaxed);}我在x86上取回了以下程序集:51pushecxB802000000moveax,28D0C24leaecx,[esp]8701xchgeax,dwordptr[ecx]B801000000moveax,1F00FC101lockxadddwordptr[ecx],eax59popecxC3ret在x64上类似:B802000000moveax,287442408xchgea

c++ - LibCds:Michael Hashmap 和 Split Order List

我正在使用libcds他们实现了MichaelHashMap和Splitorderlist。根据我从文档中收集到的信息,我是如何实现它们的:包括:#include#includeusingnamespacecds;代码:classTestDs{public:virtualboolcontainsKey(intkey)=0;virtualintget(intkey)=0;virtualintput(intkey,intvalue)=0;virtualintremove(intkey)=0;virtualintsize()=0;virtualconstchar*name()=0;virtu

c++ - std::strong_ordering 和 std::weak_ordering 的实际意义

我一直在阅读一些关于C++20的consistentcomparison(即operator)但无法理解std::strong_ordering之间的实际区别是什么和std::weak_ordering(对于这种方式的_equality版本也是如此)。除了对类型的可替代性进行非常详细的描述之外,它是否真的会影响生成的代码?它是否对如何使用该类型添加了任何限制?很想看到一个真实的例子来证明这一点。 最佳答案 Doesitaddanyconstraintsforhowonecouldusethetype?一个非常重要的约束(原始论文并非

c++ - 在 iPhone/iPad 项目中 #import C++ 头文件时出现问题

我有一个我想在iPhone/iPad项目中使用的C++类。我以不同的方式创建了这个文件(比如使用“NewFile”=>C++),但错误总是一样的。当我在没有任何#import(.hC++类)的情况下编译项目时,没问题。但是一旦我在我的头文件objective-c文件中#import头文件,我就会收到如下错误:error:vector:Nosuchfileordirectory或error:expected'=',',',';','asm'or'attribute'before':'token"我尝试在文件信息中为文件类型(C++类)设置不同的值,在.mm中重命名我的objc类等,但它似

c++ - 用于取消标志的 std::atomic_bool:std::memory_order_relaxed 是正确的内存顺序吗?

我有一个从套接字读取并生成数据的线程。每次操作后,线程都会检查一个std::atomic_bool标志以确定它是否必须提前退出。为了取消操作,我将取消标志设置为true,然后在工作线程对象上调用join()。线程和取消函数的代码如下所示:std::threadwork_thread;std::atomic_boolcancel_requested{false};voidthread_func(){while(!cancel_requested.load(std::memory_order_relaxed))process_next_element();}voidcancel(){can