草庐IT

memory_limit

全部标签

C++ 原子 : would function call act as memory barrier?

我正在阅读这篇文章MemoryOrderingatCompileTime从中说:Infact,themajorityoffunctioncallsactascompilerbarriers,whethertheycontaintheirowncompilerbarrierornot.Thisexcludesinlinefunctions,functionsdeclaredwiththepureattribute,andcaseswherelink-timecodegenerationisused.Otherthanthosecases,acalltoanexternalfunction

c++ - memory_order_seq_cst 如何与非原子操作同步?

如果使用单个原子变量和std::memory_order_seq_cst,是否保证非原子操作不会被重新排序?例如,如果我有std::atomicquux={false};voidfoo(){bar();quux.store(true,std::memory_order_seq_cst);moo();}是bar()保证在调用store之后不会重新排序,并且moo()在调用之前不会重新排序store,只要我使用std::memory_order_seq_cst,至少从另一个线程的角度来看?或者,换句话说,如果从另一个线程运行,以下假设是否有效?if(quux.load(std::memor

c++ - std::atomic::compare_exchange 与两个 memory_order 参数一起使用的真实示例

您能否给出一个真实世界的例子,其中出于某种原因使用了std::atomic::compare_exchange的两个memory_order参数版本(因此一个memory_order参数版本是不够的)? 最佳答案 在许多情况下,compare_exchange上的第二个内存排序参数设置为memory_order_relaxed。在这些情况下,省略它通常并没有错,只是可能效率较低。这里是一个简单的无锁列表/堆栈示例,它需要compare_exchange_weak上的第二个不同的排序参数,以便避免数据竞争。调用push可以并发执行,但

c++ - 如何使用大 vector 初始化来避免 "compiler limit: compiler stack overflow"?

在我的单元测试中,我得到以下编译器错误:Theerrormessageindicatesasfollows:'fatalerrorC1063:compilerlimit:compilerstackoverflow'这是由一些生成的header引起的,其中包含:std::vectorGetTestData(){return{0x1,0x2,0x3};//Verylarge500kbofdata}如何在不使MSVC崩溃的情况下以这种方式使用vector?请注意,代码在clang和gcc中构建正常。 最佳答案 尝试将您的数据放入一个常量静

c++ - C/C++ : Bitwise operators on dynamically allocated memory

在C/C++中,是否有一种简单的方法可以将按位运算符(特别是左移/右移)应用于动态分配的内存?例如,假设我这样做了:unsignedchar*bytes=newunsignedchar[3];bytes[0]=1;bytes[1]=1;bytes[2]=1;我想要一种方法来做到这一点:bytes>>=2;(那么“字节”将具有以下值):bytes[0]==0bytes[1]==64bytes[2]==64为什么值应该是这样的:分配后,字节如下所示:[00000001][00000001][00000001]但我希望将字节视为一长串位,如下所示:[000000010000000100000

c++ - 用 body_limit 提升野兽信息

我的出发点是从boosthttp_client_async的boostbeasthttp_client_async示例创建一个简单的下载程序代码.在这种情况下,我想将接收到的正文写入文件。所以我将字符串主体交换为文件主体,以写入接收到的数据:http::response_parserres_;然后将on_write方法重写为voidon_write(boost::system::error_codeec,std::size_tbytes_transferred){boost::ignore_unused(bytes_transferred);if(ec)returnfail(ec,"w

c++ - 什么是 __asm volatile ("pause"::: "memory");做?

我正在查看具有以下代码结构的开源C++项目:while(true){//Dosomethingworkif(some_condition_becomes_true)break;__asmvolatile("pause":::"memory");}最后一条语句是做什么的?我知道__asm意味着它是一个汇编指令,我发现一些关于pause指令的帖子说线程有效地暗示核心释放资源并给其他线程更多资源(在超线程的上下文中)。但是:::和memory有什么作用呢? 最佳答案 它是_mm_pause()和一个编译内存屏障,包装在一个GNUCExte

c++ - x86_64 和 ARM 上的原子 CAS 操作是否始终使用 std::memory_order_seq_cst?

作为AnthonyWilliamssaid:some_atomic.load(std::memory_order_acquire)doesjustdropthroughtoasimpleloadinstruction,andsome_atomic.store(std::memory_order_release)dropsthroughtoasimplestoreinstruction.众所周知,在x86上,操作load()和store()内存屏障memory_order_consume,memory_order_acquire,memory_order_release,memory_o

c++ - 编译器 : limitation of lexical analysis

在经典的编译器理论中,前两个阶段是词法分析和语法分析。他们正在筹备中。词法分析将标记识别为解析的输入。但是我遇到了一些在词法分析中很难被正确识别的情况。例如下面关于C++模板的代码:map>>>在“常规”词法分析中会被认为是按位右移,但这是不正确的。我的感觉是很难将这种语法的处理分为两个阶段,词法分析工作必须在解析阶段完成,因为要正确解析>>。依赖于语法,而不仅仅是简单的词汇规则。我想知道关于这个问题的理论和实践。另外,我想知道C++编译器如何处理这种情况? 最佳答案 C++标准要求实现在解析阶段之前执行词法分析以生成标记流。根据词

c++ - 为什么 numeric_limits<int>::min() 有不同的定义?

要检索最小值,我必须使用numeric_limits::min()我想最小的整数是-2147483648,在我的机器上测试显示了这个结果。但是一些C++引用,如OpenGroupBaseSpecifications和cplusplus.com用值-2147483647定义它。我问这个问题是因为在我实现negaMax框架时(游戏树搜索)值最小整数*(-1)必须明确定义。是的,使用minimalint=(numeric_limits::min()+2)在任何情况下我都是安全的,因此我的问题更具理论性,但我认为还是很有趣。 最佳答案 如果