- memory[meta header]
- function template[meta id-type]
- std[meta namespace]
- cpp26[meta cpp]
namespace std {
template<size_t Alignment, class T>
bool is_sufficiently_aligned(T* ptr);
}
ポインタ値が指定したアライメントを満たすか否かを返す。
ポインタp
が、T
に類似(similar)した型のオブジェクトX
を指すこと。
X
が少なくともAlignment
でアライメントされるならばtrue
。そうでなければfalse
。
投げない
この関数テンプレートは<mdspan>
ヘッダへのaligned_accessor
導入に伴って必要とされた機能である。
一方で、ポインタ値のアライメント要件を検査するユースケースは一般的と考えられたため、汎用ユーティリティとして<memory>
ヘッダに対して機能追加された。
#include <cassert>
#include <memory>
#include <new>
int main()
{
int *ptr = new(std::align_val_t{32}) int;
assert( std::is_sufficiently_aligned<32>(ptr) );
delete ptr;
}
- std::is_sufficiently_aligned[color ff0000]
- std::align_val_t[link /reference/new/align_val_t.md]
// 提案文書P2897R7より引用
template<size_t ByteAlignment, class ElementType>
bool is_sufficiently_aligned(ElementType* p)
{
return bit_cast<uintptr_t>(p) % ByteAlignment == 0;
}
- bit_cast[link /reference/bit/bit_cast.md]
- C++26
- Clang: ??
- GCC: ??
- Visual C++: ??