草庐IT

memory_compiler

全部标签

c++ - 为什么library API + compiler ABI就足以保证不同版本gcc对象之间的兼容性?

我遇到过这样一种情况,我可能想将使用一个版本的gcc编译的C++共享对象库与一些将使用另一个版本的gcc编译的代码一起使用。特别是,我想使用返回一些STL容器的方法,例如std::string和std::map。gccwebsite许多旧的stackoverflow帖子(例如here)讨论了这个问题。我目前的理解是关于此问题的大部分关注和帖子都是关于.so文件和.dll文件之间的交叉兼容性。由于不同的编译器ABI,这非常困难。对于使用不同版本的gcc(至少gcc版本>=3.4)编译的.so文件之间的交叉兼容性,您需要确保标准库API没有改变(并且,如果它有,有dualABI支持)。我的

c++ - 多线程程序中的 std::atomic<int> memory_order_relaxed VS volatile sig_atomic_t

volatilesig_atomic_t是否提供任何内存顺序保证?例如。如果我只需要加载/存储一个整数,可以使用吗?例如这里:volatilesig_atomic_tx=0;...voidf(){std::threadt([&]{x=1;});while(x!=1){/*waiting...*/}//done!}这是正确的代码吗?在某些情况下它可能不起作用?注意:这是一个过度简化的示例,即我不是在为给定的代码片段寻找更好的解决方案。我只想了解在根据C++标准的多线程程序中,我可以从volatilesig_atomic_t中得到什么样的行为。或者,如果是这种情况,请理解行为未定义的原因。

C++14 元编程 : Automagically build a list of types at compile/init time

使用C++14和CuriouslyRecurringTemplatePattern(CRTP)以及可能的Boost.Hana的某种组合(或boost::mpl如果您愿意),我可以在编译时(或静态初始化时)构建一个类型列表而无需显式声明吗?例如,我有这样的东西(在Coliru上查看):#include#include#includenamespace{structD1{staticconstexprautoval=10;};structD2{staticconstexprautoval=20;};structD3{staticconstexprautoval=30;};}intmain(

c++ - "Memory Fragmentation"这还是个问题吗?

关闭。这个问题需要更多focused.它目前不接受答案。想改进这个问题吗?更新问题,使其只关注一个问题editingthispost.关闭4年前。Improvethisquestion我有点困惑。在操作系统类(class)中,我们被告知所有操作系统都通过分页或分段处理内存碎片,并且根本没有连续的物理内存分配。操作系统使用不同级别的寻址(逻辑/物理)来避免连续的内存分配。现在here有很多关于它的讨论。我的问题是:这个问题在支持逻辑寻址的操作系统的C++编程中是否真实存在(是否有任何进程仅因为内存碎片而崩溃)?如果是,为什么首先每个操作系统都试图避免连续寻址?

java - OOP 访问修饰符 : Compile-time or Run-time

我听说访问修饰符Public、Private和Protected只是一些编译器的东西,它们实际上并不存在于编译的二进制代码中.现在我想知道它有多少是正确的?如果它是正确的,是否意味着封装在运行时不存在于二进制代码中?因此,如果您修改二进制文件以非法访问Private方法,理论上,没有任何东西可以检查您的权限,无论是任何OOP机制还是操作系统,对吧?我还标记了C++和Java的问题。我知道它们之间的区别,只是想看看它们处理访问修饰符有何不同。 最佳答案 访问修饰符只是C++中的一种编译时机制。然而,在Java中,它们也在运行时强制执行

c++ - 对原子类 : memory_order_relaxed 感到困惑

我正在研究这个网站:https://gcc.gnu.org/wiki/Atomic/GCCMM/AtomicSync,这对理解关于原子类的话题非常有帮助。但是这个放松模式的例子很难理解:/*Thread1:*/y.store(20,memory_order_relaxed)x.store(10,memory_order_relaxed)/*Thread2*/if(x.load(memory_order_relaxed)==10){assert(y.load(memory_order_relaxed)==20)/*assertA*/y.store(10,memory_order_rela

C++11:memory_order_relaxed 和 memory_order_consume 的区别

我现在正在学习C++11memoryordermodel并想了解memory_order_relaxed和memory_order_consume之间的区别。具体来说,我正在寻找一个无法将memory_order_consume替换为memory_order_relaxed的简单示例。有一个优秀的post它详细阐述了一个简单但非常具有说明性的示例,其中可以应用memory_order_consume。以下是文字复制粘贴。例子:atomicGuard(nullptr);intPayload=0;制作人:Payload=42;Guard.store(&Payload,memory_orde

c# - 谁知道mc.exe(Message Compiler)怎么用?

我正在尝试使用mc.exe为我的事件日志编写程序制作消息文件。但即使是samplemessagefile微软提供的不会编译。谁知道mc.exe可以编译的消息文件怎么写?编辑:我收到的错误信息是:msgs.mc(1):error:expectedkeyword-??编辑2:问题已解决。mc.exe只能支持Unicode或ANSI编码的源文件。我的文件编码为UTF8。就是这样。谢谢。 最佳答案 始终记录您收到的错误消息被迫猜测:如果您在第82行遇到错误,提示无效字符(0x2e),则在文本编辑器中打开文件,将光标放在.然后按Enter以换

解决:xxx has been compiled by a more recent version of the Java Runtime (class file version 55.0)

原因当前类是由jdk1.8版本编译,当前运行环境低于jdk1.8,故出现当前情况。javacode和name对应关系49=Java550=Java651=Java752=Java853=Java954=Java1055=Java1156=Java1257=Java1358=Java14解决方案升级当前项目jdk版本号,或者降低引用库编译的jdk版本号android{ ...compileOptions{sourceCompatibilityJavaVersion.VERSION_1_8targetCompatibilityJavaVersion.VERSION_1_8}}

c++ - 如何在中等规模的项目中诊断 g++ 错误 "cc1plus.exe: out of memory allocating 838860800 bytes"?

这个问题在这里已经有了答案:Running'gcc'onC++sourcefileonLinuxgives"cc1plus:outofmemoryallocating..."errormessage(2个答案)关闭6年前。我正在尝试移植我的C++library使用基本的g++makefile(它在VisualStudio中编译得很好)。我现在尝试编译的部分大约有45000行代码。库本身编译正常,但是当我尝试将它包含到控制台界面应用程序中时,编译器崩溃并显示以下消息,没有其他消息:cc1plus.exe:outofmemoryallocating838860800bytes当我包含项目的