草庐IT

memory-overhead

全部标签

c# - C#<->C++ DLLImport "Attempted to read or write protected memory."问题

我有一个C++dll,其中有一个函数,我试图从C#应用程序调用。这是C++头文件中的代码extern"C"_declspec(dllexport)intLabelStoringSSDsim(intdevNum,UCHARserial[40],UCHARwwn[40],UCHARConfigID[5],UCHARFrmRev[8],UCHARDevName[40],inteCode);这是C++源文件中的代码intLabelStoringSSDsim(intdevNum,UCHARserialLbl[40],UCHARwwnLbl[40],UCHARConfigID[5],UCHARFr

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

c++ - 如何避免 "unable to read memory"

我有一个结构:structa{a(){};a(intone,inttwo):a(one),b(two){};inta;intb;intc;}a*b;coutc;有时当我想读取(例如)c并且在debbuger中这个值被称为'unabletoreadmemory'然后我的程序崩溃了。现在,如何检查该值是否可读?最好的问候。 最佳答案 你还没有初始化指向任何东西的指针,所以它是无效的。通常,您无法测试指针是否指向有效对象。由您来确保它确实如此;例如:aobj(1,2);//anobjecta*b=&obj;//apointer,point

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++ - "Memory Fragmentation"这还是个问题吗?

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

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++ - 如何在中等规模的项目中诊断 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当我包含项目的

objective-c - Objective-C : Memory Leak due to 'Incorrect decrement of reference count'

在分析我的代码后,我遇到了以下内存泄漏警告。但是,警告并没有出现在我的代码中,无法准确告诉我泄漏发生的位置。任何人都可以告诉我通常是什么原因导致此泄漏以及我如何搜索我的代码以识别它? 最佳答案 http://developer.apple.com/library/mac/#documentation/cocoa/conceptual/MemoryMgmt/Articles/mmRules.html#//apple_ref/doc/uid/20000994-BAJHFBGH根据Cocoa命名约定,除了以init、new、copy或mu

EfficientViT: Memory Efficient Vision Transformer withCascaded Group Attention论文阅读

高效的记忆视觉transformer与级联的群体注意摘要。视觉transformer由于其高模型能力而取得了巨大的成功。然而,它们卓越的性能伴随着沉重的计算成本,这使得它们不适合实时应用。在这篇论文中,我们提出了一个高速视觉transformer家族,名为EfficientViT。我们发现现有的transformer模型的速度通常受到内存低效操作的限制,特别是在MHSA中的张量重塑和单元函数。因此,我们设计了一种具有三明治布局的新构建块,即在高效FFN层之间使用单个内存绑定的MHSA,从而提高了内存效率,同时增强了信道通信。此外,我们发现注意图在头部之间具有很高的相似性,从而导致计算冗余。为了