jjzjj

atomically

全部标签

java - 如何在 java.util.concurrent.atomic 包中定义的类中实现原子性?

我正在浏览java.util.concurrent.atomic.AtomicInteger的源代码,以了解该类提供的原子操作是如何实现原子性的。例如AtomicInteger.getAndIncrement()方法源码如下publicfinalintgetAndIncrement(){for(;;){intcurrent=get();intnext=current+1;if(compareAndSet(current,next))returncurrent;}}我无法理解在无限循环中编写操作序列的目的。它在Java内存模型(JMM)中是否有任何特殊用途。请帮我找到一个描述性的理解。提

javascript - Ctrl+单击 Atom 编辑器中的函数名称并跳转到其中

我一直在想一个更好的方法来给这个问题起标题,但不幸的是我不知道如何解释它。此外,我还没有在堆栈溢出时发现它(出于与上述相同的原因)。在Eclipse中,我曾经在方法调用的名称中Ctrl+Click(在java中)。我的光标会跳转到我的方法函数的定义。问题一:有人知道这种行为的名称吗?我的意思是,也许它被称为函数跳跃或类似的东西。我也在Atom编辑器中寻找这样的插件。因为我已经尝试过很多次(坏习惯)并且没有用。问题2:在Atom中执行此操作的插件名称?不知道它是否有帮助,但我目前正在Atom编辑器中使用JavaScript进行编码。 最佳答案

java - Java 中 java.util.concurrent.atomic 包中类的确切用途是什么?

我是比较新的java。我试图了解包中类的用法:java.util.concurrent.atomic我试图了解这个包的javaDoc以掌握它。但是当我应该使用这些类时,它真的没有任何意义。有人可以用简单的话举例和更多描述吗?谢谢 最佳答案 考虑10个线程递增inti(初始化为0)并将值输出到控制台。你可以得到这样的东西:12233566810例如,AtomicInteger可确保每个线程都可以原子地递增或递减值,从而确保写入操作以同步方式发生,对于10个线程,输出始终为:12345678910

seo - 站点地图/RSS/Atom,搜索引擎优化

关闭。这个问题不符合StackOverflowguidelines.它目前不接受答案。这个问题似乎与helpcenter中定义的范围内的编程无关。.关闭8年前。Improvethisquestion所以,我正准备为我的站点制作一个常规的sitemap.xml,然后我看到Google和Bing都接受Atom和RSS作为站点地图。我的站点是一个论坛,因此会非常频繁地创建新页面。使用RSS/Atom提要是否会比使用常规sitemap.xml更快地索引新页面?一种方法与另一种方法相比有哪些SEO优势?

c++ - 编译错误 : undefined reference to‘__atomic_fetch_add_4’

#includeusingnamespacecv;intmain(){Matimg=imread("cornea.jpg");imshow("src",img);waitKey(0);return0;}然后我编译它:g++main.cpp-omain`pkg-configopencv--cflags--libs`或g++main.cpp-omain-I/usr/local/opencv-3.1.0/include/opencv-I/usr/local/opencv-3.1.0/include-L/usr/local/opencv-3.1.0/lib-lopencv_shape-lope

c++ - 使用 atomic<bool> 的简单自旋锁中的数据竞争

这个问题在这里已经有了答案:C++11ImplementationofSpinlockusingheader``(2个答案)关闭7年前。#include#include#include#include#include#includeusingnamespacestd;classspinlock{private:atomicflag;public:spinlock():flag(false){}voidlock(){booltemp=false;while(!flag.compare_exchange_weak(temp,true,std::memory_order_seq_cst)&&

c++ - 使用 clang 对 std::atomic 函数的调用不明确

我正在尝试使用clang编译我的代码,我之前使用的是g++。我在编译以下代码时遇到错误:#includetypedefvoid(*my_func)();intmain(intargc,char**argv){std::atomic_func;_func();return0;}错误是:a.cpp:23:3:error:calltoobjectoftype'std::atomic'isambiguous_func();^~~~~/usr/bin/../lib/gcc/x86_64-linux-gnu/4.8/../../../../include/c++/4.8/atomic:304:7:

c++ - atomic<bool> 与受互斥锁保护的 bool

假设我们有一个内存区域,某个线程正在向其中写入数据。然后它将注意力转移到别处并允许任意其他线程读取数据。然而,在某个时间点,它想要重用该内存区域并再次写入。写入器线程提供了一个bool标志(valid),它表示内存仍然有效,可以从中读取(即他还没有重新使用它)。在某个时候,他会将此标志设置为false,并且再也不会将其设置为true(它只会翻转一次,就是这样)。在顺序一致性的情况下,编写者和读者分别使用这两个代码片段应该是正确的:...valid=false;...和...if(valid){}else{}...我们显然需要做一些事情来确保顺序一致性,即插入必要的获取和释放内存屏障。我

c++ - 如果 volatile 是不必要的,为什么 std::atomic 方法提供 volatile 重载?

thisgoodanswer说:volatileiscompletelyunnecessarywhenusedwithstd::atomic.然而,std::atomic_fecth_sub提供重载函数:templateTatomic_fetch_sub(volatilestd::atomic*obj,typenamestd::atomic::difference_typearg)noexcept;我的问题是:如果volatile对于std::atomic来说完全没有必要,为什么C++标准要为它提供一个重载函数? 最佳答案 Ifvo

c++ - std::atomic_compare_exchange_* 等如何与任意指针一起使用?

InterlockedCompareExchange在Windows中,以及__sync_val_compare_and_swap在gcc中采用指针,因此我可以传入任何地址,例如指向这些函数的共享内存块。对于非x86架构,我可能必须确保内存对齐以确保正确性,对于x86(可能还有其他),我可能希望确保缓存行对齐以提高性能,尽管正确性应该不是问题(->x86LOCK前缀)。为了摆脱我的代码中一些平台相关的东西(WindowsVC++与GCC),我查看了C++11的atomic_compare_exchange_weak。和friend。但它们都对std::atomic*类型的变量起作用.有