सी ++ लाइब्रेरी - <सीमा>

परिचय

यह एक न्यूमेरिक सीमा प्रकार है और यह विशिष्ट मंच में अंकगणितीय प्रकार (या तो अभिन्न या फ्लोटिंग-पॉइंट) के गुणों के बारे में जानकारी प्रदान करता है, जिसके लिए पुस्तकालय संकलित करता है।

घोषणा

निम्नलिखित std :: num_limits के लिए घोषणा है।

template <class T> numeric_limits;

सी ++ 11

template <class T> numeric_limits;

मापदंडों

T - यह एक प्रकार का वर्ग है।

उदाहरण

निम्न उदाहरण में std :: न्यूमेरिक_लिमिट्स के लिए।

#include <limits>
#include <iostream>

int main() {
   std::cout << "type\tlowest type\thighest type\n";
   std::cout << "int\t"
      << std::numeric_limits<int>::lowest() << '\t'
      << std::numeric_limits<int>::max() << '\n';
   std::cout << "float\t"
      << std::numeric_limits<float>::lowest() << '\t'
      << std::numeric_limits<float>::max() << '\n';
   std::cout << "double\t"
      << std::numeric_limits<double>::lowest() << '\t'
      << std::numeric_limits<double>::max() << '\n';
}

नमूना उत्पादन इस तरह होना चाहिए -

type	lowest type	highest type
int	-2147483648	2147483647
float	-3.40282e+38	3.40282e+38
double	-1.79769e+308	1.79769e+308

खाका तात्कालिकता

C ++ 98 के मौलिक अंकगणितीय प्रकार इस प्रकार होने चाहिए -

मौलिक अंकगणितीय प्रकार
अभिन्न प्रकार bool
char
wchar_t
signed char
short int
int
long int
unsigned char
unsigned short int
unsigned int
unsigned long int
फ्लोटिंग पॉइंट प्रकार float
double
long double

C ++ 11 का मौलिक अंकगणितीय प्रकार इस प्रकार होना चाहिए -

मौलिक अंकगणितीय प्रकार
अभिन्न प्रकार bool
char
char16_t
char32_t
wchar_t
signed char
short int
int
long int
long long int
unsigned char
unsigned short int
unsigned int
unsigned long int
unsigned long long int
फ्लोटिंग पॉइंट प्रकार float
double
long double

सदस्य

सदस्य प्रकार संपत्ति
is_specialized bool यह trueसभी के लिए है (यानी, जिनके लिएnumeric_limitsविशिष्ट है)। और falseअन्य सभी प्रकारों के लिए।
मिनट () टी

यह एक न्यूनतम परिमित मूल्य है।

विकृति के साथ फ्लोटिंग प्रकारों के लिए (घातांक बिट्स की चर संख्या): न्यूनतम सकारात्मक सामान्यीकृत मूल्य।

के बराबर CHAR_MIN, SCHAR_MIN, SHRT_MIN, INT_MIN, LONG_MIN, LLONG_MIN, FLT_MIN, BL_MIN, LDBL_MINया 0, प्रकार पर निर्भर करता है।

अधिकतम () टी

यह एक अधिकतम परिमित मूल्य है।

के बराबर CHAR_MAX, SCHAR_MAX, UCHAR_MAX, SHRT_MAX, USHRT_MAX, INT_MAX, UINT_MAX, LONG_MAX, ULONG_MAX, LLONG_MAX, ULLONG_MAX, UINT_LEAST16_MAX, UINT_LEAST32_MAX, FLT_MAX, DBL_MAX या LDBL_MAX, प्रकार पर निर्भर करता है।

सबसे कम () टी

यह एक न्यूनतम परिमित मूल्य है। (सी ++ 11 के बाद से)

अभिन्न प्रकारों के लिए: के रूप में ही मिनट ()

फ्लोटिंग-पॉइंट प्रकारों के लिए: कार्यान्वयन-निर्भर; आम तौर पर, के नकारात्मकअधिकतम ()

अंक पूर्णांक

यह पूर्णांक प्रकारों के लिए है: प्रतिनिधित्व में गैर-साइन बिट्स ( मूलांक आधार अंक) की संख्या।

फ्लोटिंग प्रकारों के लिए: मंटिसा में अंकों की संख्या ( मूलांक आधार में)FLT_MANT_DIG, DBL_MANT_DIG या LDBL_MANT_DIG)।

digits10 int

यह कई अंकों (दशमलव में बेस) है, जिसे बिना किसी बदलाव के दर्शाया जा सकता है।

के बराबर FLT_DIG, DBL_DIG या LDBL_DIG अस्थायी प्रकारों के लिए।

max_digits10 int यह अंकों की एक संख्या है (दशमलव आधार में), यह सुनिश्चित करने के लिए आवश्यक है कि मान जो हमेशा भिन्न होते हैं।
is_signed bool true यदि हस्ताक्षरित है।
is_integer bool true यदि प्रकार पूर्णांक है।
is_exact bool true यदि प्रकार सटीक अभ्यावेदन का उपयोग करता है।
सूत्र int

यह पूर्णांक प्रकारों के लिए है: प्रतिनिधित्व का आधार।

अस्थायी प्रकारों के लिए: प्रतिनिधित्व के प्रतिपादक का आधार (इसके समतुल्य) FLT_RADIX)।

एप्सिलॉन () टी

यह एक मशीन एप्सिलॉन (1 और 1 के बीच कम से कम मूल्य के बीच का अंतर जो कि प्रतिनिधित्व योग्य है)।

के बराबर FLT_EPSILON, DBL_EPSILON या LDBL_EPSILON अस्थायी प्रकारों के लिए।

round_error () टी यह अधिकतम गोलाई की त्रुटि को मापता है।
min_exponent int

यह कम से कम नकारात्मक पूर्णांक मान ऐसी है कि है मूलांक उठाया (min_exponent-1)एक सामान्यीकृत फ्लोटिंग प्वाइंट संख्या उत्पन्न करता है।

के बराबर FLT_MIN_EXP, DBL_MIN_EXP या LDBL_MIN_EXP अस्थायी प्रकारों के लिए।

min_exponent10 int

यह एक न्यूनतम नकारात्मक पूर्णांक मान है जैसे कि उस शक्ति पर उठाया गया 10 सामान्यीकृत फ्लोटिंग-पॉइंट संख्या उत्पन्न करता है।

के बराबर FLT_MIN_10_EXP, DBL_MIN_10_EXP या LDBL_MIN_10_EXP अस्थायी प्रकारों के लिए।

max_exponent int

यह एक अधिकतम पूर्णांक मान है, जो कि मूलांक(max_exponent-1) एक प्रतिनिधित्व योग्य परिमित फ्लोटिंग-पॉइंट संख्या उत्पन्न करने के लिए उठाया जाता है।

के बराबर FLT_MAX_EXP, DBL_MAX_EXP या LDBL_MAX_EXP अस्थायी प्रकारों के लिए।

max_exponent10 int

यह अधिकतम पूर्णांक मान है जैसे कि उस पावर पर उठाया गया 10 सामान्यीकृत परिमित फ्लोटिंग-पॉइंट नंबर उत्पन्न करता है।

के बराबर FLT_MAX_10_EXP, DBL_MAX_10_EXP या LDBL_MAX_10_EXP अस्थायी प्रकारों के लिए।

has_infinity bool true यदि प्रकार में सकारात्मक अनंत के लिए एक प्रतिनिधित्व है।
has_quiet_NaN bool true यदि प्रकार में एक शांत (गैर-सिग्नलिंग) "नॉट-ए-नंबर" के लिए एक प्रतिनिधित्व है।
has_signaling_NaN bool true यदि प्रकार में "नॉट-ए-नंबर" सिग्नलिंग के लिए एक प्रतिनिधित्व है।
has_denorm float_denorm_style

यह एक असामान्य मान है (घातांक बिट्स की एक चर संख्या के साथ प्रतिनिधित्व)। एक प्रकार के निम्नलिखित एनम मान हो सकते हैं -

denorm_absent, अगर यह मूल्यविहीन मूल्यों की अनुमति नहीं देता है।

denorm_present, अगर यह मानों को अनुमति देता है।

denorm_indeterminate, यदि संकलन समय पर अनिश्चित हो।

has_denorm_loss bool trueयदि सटीकता के नुकसान को एक परिणाम के बजाय एक अपभ्रंश नुकसान के रूप में पाया जाता है।
अनंत () टी यह सकारात्मक अनंत का प्रतिनिधित्व करता है , यदि उपलब्ध हो।
quiet_NaN () टी यह उपलब्ध होने पर शांत (गैर-संकेतन) "नॉट-ए-नंबर" का प्रतिनिधित्व करता है।
signaling_NaN () टी यह उपलब्ध होने पर सिग्नलिंग "नॉट-ए-नंबर" का प्रतिनिधित्व करता है।
denorm_min () टी

न्यूनतम सकारात्मक मूल्य वर्धित मूल्य।

यह उन प्रकारों के लिए है, जो मानों को मानने की अनुमति नहीं देते हैं: समान min()

is_iec559 bool

true यदि प्रकार IEC-559 / IEEE-754 मानक का पालन करता है।

एक आईईसी -559 प्रकार हमेशा होता है has_infinity, has_quiet_NaN तथा has_signaling_NaNके लिए सेट true; तथाअनन्तता, quiet_NaN तथा signaling_NaN कुछ गैर-शून्य मान लौटाएं।

क्या घिरा हुआ है bool true यदि प्रकार द्वारा दर्शाए गए मानों का समूह परिमित है।
is_modulo bool trueयदि प्रकार modulo है। एक प्रकार modulo है यदि दो सकारात्मक संख्याओं को जोड़ना संभव है और एक परिणाम है कि लगभग एक तिहाई संख्या के लिए लपेटता है जो कम है।
जाल bool true यदि फँसाने को प्रकार के लिए लागू किया जाता है।
tinyness_before bool true यदि गोलाई से पहले छोटेपन का पता लगाया जाता है।
round_style float_round_style

यह एक गोल शैली है। एक प्रकार के निम्नलिखित एनम मान हो सकते हैं -

round_toward_zero, अगर यह शून्य की ओर गोल है।

round_to_nearest, अगर यह निकटतम प्रतिनिधित्व योग्य मूल्य के लिए गोल है।

round_toward_infinity, अगर यह अनंत की ओर गोल है।

round_toward_neg_infinity, अगर यह नकारात्मक अनंत की ओर गोल है।

round_indeterminate, अगर संकलन शैली संकलन समय पर अनिश्चित है।

उन सभी प्रकारों के लिए जो मौलिक अंकगणितीय प्रकार नहीं हैं, डिफ़ॉल्ट टेम्पलेट परिभाषा का उपयोग किया जाता है -

सी ++ 98

template <class T> class numeric_limits {
   public:
      static const bool is_specialized = false;
      static T min() throw();
      static T max() throw();
      static const int digits = 0;
      static const int digits10 = 0;
      static const bool is_signed = false;
      static const bool is_integer = false;
      static const bool is_exact = false;
      static const int radix = 0;
      static T epsilon() throw();
      static T round_error() throw();

      static const int min_exponent = 0;
      static const int min_exponent10 = 0;
      static const int max_exponent = 0;
      static const int max_exponent10 = 0;

      static const bool has_infinity = false;
      static const bool has_quiet_NaN = false;
      static const bool has_signaling_NaN = false;
      static const float_denorm_style has_denorm = denorm_absent;
      static const bool has_denorm_loss = false;
      static T infinity() throw();
      static T quiet_NaN() throw();
      static T signaling_NaN() throw();
      static T denorm_min() throw();

      static const bool is_iec559 = false;
      static const bool is_bounded = false;
      static const bool is_modulo = false;

      static const bool traps = false;
      static const bool tinyness_before = false;
      static const float_round_style round_style = round_toward_zero;
};

सी ++ 11

template <class T> class numeric_limits {
   public:
      static constexpr bool is_specialized = false;
      static constexpr T min() noexcept { return T(); }
      static constexpr T max() noexcept { return T(); }
      static constexpr T lowest() noexcept { return T(); }
      static constexpr int digits = 0;
      static constexpr int digits10 = 0;
      static constexpr bool is_signed = false;
      static constexpr bool is_integer = false;
      static constexpr bool is_exact = false;
      static constexpr int radix = 0;
      static constexpr T epsilon() noexcept { return T(); }
      static constexpr T round_error() noexcept { return T(); }

      static constexpr int min_exponent = 0;
      static constexpr int min_exponent10 = 0;
      static constexpr int max_exponent = 0;
      static constexpr int max_exponent10 = 0;

      static constexpr bool has_infinity = false;
      static constexpr bool has_quiet_NaN = false;
      static constexpr bool has_signaling_NaN = false;
      static constexpr float_denorm_style has_denorm = denorm_absent;
      static constexpr bool has_denorm_loss = false;
      static constexpr T infinity() noexcept { return T(); }
      static constexpr T quiet_NaN() noexcept { return T(); }
      static constexpr T signaling_NaN() noexcept { return T(); }
      static constexpr T denorm_min() noexcept { return T(); }

      static constexpr bool is_iec559 = false;
      static constexpr bool is_bounded = false;
      static constexpr bool is_modulo = false;

      static constexpr bool traps = false;
      static constexpr bool tinyness_before = false;
};