在了解对齐问题等时,我意识到我对g ++ 4.9(macports OS X)的实现不支持std::align
。如果我尝试使用http://www.cplusplus.com/reference/memory/align/
-std=c++11
)此示例代码
// align example
#include <iostream>
#include <memory>
int main() {
char buffer[] = "------------------------";
void * pt = buffer;
std::size_t space = sizeof(buffer) - 1;
while ( std::align(alignof(int), sizeof(char), pt, space) ) {
char* temp = static_cast<char*>(pt);
*temp = '*'; ++temp; space -= sizeof(char);
pt = temp;
}
std::cout << buffer << '\n';
return 0;
}
编译器吐出错误
error: 'align' is not a member of 'std'
这看起来很奇怪,因为g ++似乎已经实现了对齐支持,因为g ++ 4.8,https://gcc.gnu.org/projects/cxx0x.html(N2341)
代码在clang ++下编译没有任何问题。
这是一个我不知道的g ++众所周知的问题吗?我测试的在线编译器(ideone和coliru)也拒绝了代码。
答案 0 :(得分:12)
是的,这是gcc已知的缺失功能:
std::align
缺少答案 1 :(得分:2)
作为替代方案,您可以编写自己的对齐代码,以匹配std::align
的行为。下一段代码由David Krauss在此处发现的帖子中编写:https://gcc.gnu.org/bugzilla/show_bug.cgi?id=57350
inline void *align( std::size_t alignment, std::size_t size,
void *&ptr, std::size_t &space ) {
std::uintptr_t pn = reinterpret_cast< std::uintptr_t >( ptr );
std::uintptr_t aligned = ( pn + alignment - 1 ) & - alignment;
std::size_t padding = aligned - pn;
if ( space < size + padding ) return nullptr;
space -= padding;
return ptr = reinterpret_cast< void * >( aligned );
}