Portál AbcLinuxu, 10. května 2025 22:22
int str2int(string value) { int number; if(sscanf(value.c_str(), "%d", &number) == EOF) { cerr << "Input file is not in correct format" << endl; exit(EXIT_FAILURE); } return number; }Ta funguje v poradku, pokud prevadim napr. "123", pokud do teto funkce ale poslu napriklad retezec "xxx", vrati mi nejake zaporne cislo (misto toho, aby skoncila chybou). Jak tedy mohu tuto funkci opravit, aby mi v pripade nevalidniho vstupu tuto skutecnost opravdu zahlasila?
Řešení dotazu:
number
na hodnotu, ktorú to má vrátiť, keď sa vstup na číslo skonvertovať nedá. Alebo výsledok sscanf()
kontroluj nielen na EOF ale aj na nulu.
sscanf()
a bude ti to jasné hned. Zřejmě je chybou ji testovat na konstantu EOF
, když na konec souboru nenarazila.
V jakém je to vlastně jazyku?
==EOF
bude <=0
, tak by to mělo fungovat.
Na příkladu je vidět, jak nebezpečné může být používání neinicializovaných proměnných.
<1
, pokud očekávám jednu hodnotu, <3
, pokud očekávám 3 hodnoty apod.
!= 1
, to je přesnější.C++
, ne jen C+
, tak by to mohlo být třeba takto:
int str2int(std::string value) { std::istringstream iss(value); int number; if((iss >> number).fail()) { std::cerr << "The input number is in a invalid format" << std::endl; exit(3);//or throw a exception… } return number; }
Tiskni
Sdílej:
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.