为什么std :: swap不能用于std :: bitset <n>内容?

jpo*_*o38 8 c++ swap bitset c++11

考虑这个单元测试:

std::bitset<8> temp( "11010100" );
reverseBitSet( temp );
CPPUNIT_ASSERT( temp == std::bitset<8>( "00101011" ) );
Run Code Online (Sandbox Code Playgroud)

此实现有效:

template<size_t _Count> static inline void reverseBitSet( std::bitset<_Count>& bitset )
{
    bool val;
    for ( size_t pos = 0; pos < _Count/2; ++pos )
    {
        val = bitset[pos];
        bitset[pos] = bitset[_Count-pos-1];
        bitset[_Count-pos-1] = val;
    }
}
Run Code Online (Sandbox Code Playgroud)

虽然这个没有:

template<size_t _Count> static inline void reverseBitSet( std::bitset<_Count>& bitset )
{
    for ( size_t pos = 0; pos < _Count/2; ++pos )
    {
        std::swap( bitset[pos], bitset[_Count-pos-1] );
    }
}
Run Code Online (Sandbox Code Playgroud)

结果是"11011011"而不是"00101011"

为什么交换做错了?

Bar*_*rry 7

这个:

std::swap( bitset[pos], bitset[_Count-pos-1] );
Run Code Online (Sandbox Code Playgroud)

应该实际上无法编译.operator[]对于a std::bitset不返回引用,它返回一个代理对象.该代理对象不是一个左值,因此它不能绑定到T&std::swap.我假设它在const某种程度上编译你正在使用MSVC,它具有允许将临时绑定到非引用的扩展- 此时你可能只是交换代理而不是代理实际引用的内容至.


附注:该名称_Count由标准保留,任何其他名称以后_跟大写字母开头.

  • 提到关闭这个引起错误的功能所需的标志可能是一个好主意.(`/ Za`) (2认同)