std::strtoimax, std::strtoumax
![]() |
This page has been machine-translated from the English version of the wiki using Google Translate.
The translation may contain errors and awkward wording. Hover over text to see the original version. You can help to fix errors and improve the translation. For instructions click here. |
definiert in Header <cinttypes>
|
||
std::intmax_t strtoimax(const char* nptr, char** endptr, int base); |
(seit C++11) | |
std::uintmax_t strtoumax(const char* nptr, char** endptr, int base); |
(seit C++11) | |
nptr
.nptr
.You can help to correct and verify the translation. Click here for instructions.
Function discards any whitespace characters until first non-whitespace character is found. Then it takes as many characters as possible to form a valid base-n (where n=base) integer number representation and converts them to an integer value. The valid integer value consists of the following parts:
- (optional) plus or minus sign
- (optional) prefix (
0
) indicating octal base (applies only when the base is 8) - (optional) prefix (
0x
or0X
) indicating hexadecimal base (applies only when the base is 16) - a sequence of digits
The set of valid digits for base-2 integer is 01
, for base-3 integer is 012
, and so on. For bases larger than 10
, valid digits include alphabetic characters, starting from Aa
for base-11 integer, to Zz
for base-36 integer. The case of the characters is ignored.
endptr
auf das Zeichen nach dem letzten Zeichen interpretiert zeigen. Wenn endptr
NULL ist, wird es ignoriert .endptr
to point to the character past the last character interpreted. If endptr
is NULL, it is ignored.You can help to correct and verify the translation. Click here for instructions.
nptr
ist leer oder nicht die erwartete Form, wird keine Konvertierung durchgeführt, und (wenn enptr
nicht NULL) der Wert nptr
im Objekt, auf das endptr
gespeichert .nptr
is empty or does not have the expected form, no conversion is performed, and (if enptr
is not NULL) the value of nptr
is stored in the object pointed to by endptr
.You can help to correct and verify the translation. Click here for instructions.
Inhaltsverzeichnis |
[Bearbeiten] Parameter
nptr | - | Zeiger auf die null-terminierte Byte-String interpretiert werden
Original: pointer to the null-terminated byte string to be interpreted The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. |
endptr | - | Zeiger auf einen Zeiger auf ein Zeichen .
Original: pointer to a pointer to character. The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. |
base | - | Base der interpretierten Integer-Wert
Original: base of the interpreted integer value The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. |
[Bearbeiten] Rückgabewert
- Wenn dies gelingt, ist ein ganzzahliger Wert entsprechend dem Inhalt des
str
zurückgegeben .Original:If successful, an integer value corresponding to the contents ofstr
is returned.The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions. - Wenn der umgewandelte Wert fällt außerhalb der Reichweite des zugehörigen Rückgabetyp, tritt ein Fehler Bereich (Einstellung [[cpp/error/errno|errno]] um ERANGE) und INTMAX_MAX, INTMAX_MIN, UINTMAX_MAX oder 0 zurückgegeben wird, entspricht .Original:If the converted value falls out of range of corresponding return type, a range error occurs (setting [[cpp/error/errno|errno]] to ERANGE) and INTMAX_MAX, INTMAX_MIN, UINTMAX_MAX or 0 is returned, as appropriate.The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions. - Wenn keine Umwandlung durchgeführt werden kann, wird zurückgegeben 0 .Original:If no conversion can be performed, 0 is returned.The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
[Bearbeiten] Beispiel
#include <iostream> #include <string> #include <cinttypes> int main() { std::string str = "helloworld"; std::intmax_t val = std::strtoimax(str.c_str(), nullptr, 36); std::cout << str << " in base 36 is " << val << " in base 10\n"; char* nptr; val = std::strtoimax(str.c_str(), &nptr, 30); if(nptr != &str[0] + str.size()) std::cout << str << " in base 30 is invalid." << " The first invalid digit is " << *nptr << '\n'; }
Output:
helloworld in base 36 is 1767707668033969 in base 10 helloworld in base 30 is invalid. The first invalid digit is w
[Bearbeiten] Siehe auch
(C++11) (C++11) |
wandelt eine breite Zeichenfolge std::intmax_t oder std::uintmax_t Original: converts a wide string to std::intmax_t or std::uintmax_t The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (Funktion) |
wandelt ein Byte-String in einen ganzzahligen Wert Original: converts a byte string to an integer value The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (Funktion) | |
wandelt ein Byte-String in einen vorzeichenlosen Integer-Wert Original: converts a byte string to an unsigned integer value The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (Funktion) | |
C documentation for strtoimax, strtoumax
|