3

cppreference 网站有一个描述事务性内存 c++ 代码的(正在进行的工作)页面。这是页面上的第一个示例

#include <iostream>
#include <vector>
#include <thread>
int f()
{
    static int i = 0;
    synchronized { // begin synchronized block
        std::cout << i << " -> ";
        ++i;       // each call to f() obtains a unique value of i
        std::cout << i << '\n';
        return i; // end synchronized block
    }
}
int main()
{
    std::vector<std::thread> v(10);
    for(auto& t: v)
        t = std::thread([]{ for(int n = 0; n < 10; ++n) f(); });
    for(auto& t: v)
        t.join();
}

在该页面的底部,有迹象表明这是建立在 gcc ( // GCC assembly with the attribute:) 之上的。

我无法在 g++ 5.3.1 上构建它:

$ g++ --std=c++11 -fgnu-tm -lpthread trx.cpp 
trx.cpp: In function ‘int f()’:
trx.cpp:7:5: error: ‘synchronized’ was not declared in this scope
     synchronized { // begin synchronized block
     ^

$ g++ --help | grep transaction

$ g++ --version
g++ (Ubuntu 5.3.1-14ubuntu2.1) 5.3.1 20160413

gcc 文档确实一个关于 transactional memory 的页面,但是原语是不同的(例如,原子块是__transaction_atomic)。相反,cppreference.com 上的页面似乎与N3919相关,并使用那里的原语。

如何使用 g++ 构建此代码?

4

1 回答 1

6

您首先提到的transactional_memory链接说:

编译器支持

GCC 从 6.1 版开始支持此技术规范(需要-fgnu-tm启用)。

所以你需要GCC 6(可能 -std=c++1z需要-fgnu-tm......)

于 2016-08-05T10:14:16.850 回答