C++ 11 ilk olarak, kullanıcı tanımlı hazır bilgi aracılığıyla C++ içine yeni hazır bilgi tanımlamak için destek tanıttı. C++ 11 veya üstü ayrıca <cstdint>
'daki türler için sabit genişlikli tamsayı hazırlıkları için ekleri önceden tanımlar mı?C++ 'da sabit genişlikli tamsayı değişmezleri mi?
cevap
sayılı standarda göre tanımlanan C++, 14, sadece hazır ekleri arasında gibi standart kütüphane <chrono>
, <complex>
ve <string>
başlıkları ile sağlanmaktadır. <chrono>
başlık h
, min
, s
, ms
, us
, zaman süreleri için ns
ekleri, <complex>
hayali sayılar için i
, il
ve if
ekleri tanımlar tanımlar ve <string>
basic_string
hazır için s
eki tanımlar.
Ancak, bir kolaylıkla böyle kendi sabit genişlikli değişmezleri tanımlayabilirsiniz:
#include <cstdint>
constexpr std::int8_t operator "" _int8(unsigned long long v)
{ return static_cast<std::int8_t>(v); }
constexpr std::uint8_t operator "" _uint8(unsigned long long v)
{ return static_cast<std::uint8_t>(v); }
constexpr std::int16_t operator "" _int16(unsigned long long v)
{ return static_cast<std::int16_t>(v); }
constexpr std::uint16_t operator "" _uint16(unsigned long long v)
{ return static_cast<std::uint16_t>(v); }
constexpr std::int32_t operator "" _int32(unsigned long long v)
{ return static_cast<std::int32_t>(v); }
constexpr std::uint32_t operator "" _uint32(unsigned long long v)
{ return static_cast<std::uint32_t>(v); }
constexpr std::int64_t operator "" _int64(unsigned long long v)
{ return static_cast<std::int64_t>(v); }
constexpr std::uint64_t operator "" _uint64(unsigned long long v)
{ return static_cast<std::uint64_t>(v); }
constexpr std::int_fast8_t operator "" _int_fast8(unsigned long long v)
{ return static_cast<std::int_fast8_t>(v); }
constexpr std::uint_fast8_t operator "" _uint_fast8(unsigned long long v)
{ return static_cast<std::uint_fast8_t>(v); }
constexpr std::int_fast16_t operator "" _int_fast16(unsigned long long v)
{ return static_cast<std::int_fast16_t>(v); }
constexpr std::uint_fast16_t operator "" _uint_fast16(unsigned long long v)
{ return static_cast<std::uint_fast16_t>(v); }
constexpr std::int_fast32_t operator "" _int_fast32(unsigned long long v)
{ return static_cast<std::int_fast32_t>(v); }
constexpr std::uint_fast32_t operator "" _uint_fast32(unsigned long long v)
{ return static_cast<std::uint_fast32_t>(v); }
constexpr std::int_fast64_t operator "" _int_fast64(unsigned long long v)
{ return static_cast<std::int_fast64_t>(v); }
constexpr std::uint_fast64_t operator "" _uint_fast64(unsigned long long v)
{ return static_cast<std::uint_fast64_t>(v); }
constexpr std::int_least8_t operator "" _int_least8(unsigned long long v)
{ return static_cast<std::int_least8_t>(v); }
constexpr std::uint_least8_t operator "" _uint_least8(unsigned long long v)
{ return static_cast<std::uint_least8_t>(v); }
constexpr std::int_least16_t operator "" _int_least16(unsigned long long v)
{ return static_cast<std::int_least16_t>(v); }
constexpr std::uint_least16_t operator "" _uint_least16(unsigned long long v)
{ return static_cast<std::uint_least16_t>(v); }
constexpr std::int_least32_t operator "" _int_least32(unsigned long long v)
{ return static_cast<std::int_least32_t>(v); }
constexpr std::uint_least32_t operator "" _uint_least32(unsigned long long v)
{ return static_cast<std::uint_least32_t>(v); }
constexpr std::int_least64_t operator "" _int_least64(unsigned long long v)
{ return static_cast<std::int_least64_t>(v); }
constexpr std::uint_least64_t operator "" _uint_least64(unsigned long long v)
{ return static_cast<std::uint_least64_t>(v); }
constexpr std::intmax_t operator "" _intmax(unsigned long long v)
{ return static_cast<std::intmax_t>(v); }
constexpr std::uintmax_t operator "" _uintmax(unsigned long long v)
{ return static_cast<std::uintmax_t>(v); }
constexpr std::intptr_t operator "" _intptr(unsigned long long v)
{ return static_cast<std::intptr_t>(v); }
constexpr std::uintptr_t operator "" _uintptr(unsigned long long v)
{ return static_cast<std::uintptr_t>(v); }
Uyarı: Yukarıdaki kod sessizce yanlış sonuç verecektir unsigned long long
sığmayan değişmezleri üzerinde kullanılırsa Ayrıca, gerçek değerin istenen türden birine sığmaması durumunda, örneğin taşma 999_int8
. Bir better implementation (GPL-3 lisanslı) muhtemelen, this gibi taşma üzerine karakter karakterli karakter ve static_assert
'u ayrıştırmak zorunda kalacaktır.
Kullanıcı tanımlı değişmezleri kullanmanın dezavantajı, altkümesi olmayan soneklerin §17.6.4.3.4'e göre gelecekteki standardizasyon için ayrılmasından dolayı eklerin bir alt çizgi _
ile önekinin yapılması gerektiğidir.
[Taşma konusunda bir istisna atma, derleme başarısızlığı yapma] nasıl olur (http://stackoverflow.com/a/8626450/256138)? – rubenvb