Inhaltsverzeichnis
Frageninhalt
Lösung
Heim Backend-Entwicklung Golang Kann man mit Sicherheit davon ausgehen, dass alle von strconv.Parse*-Funktionen zurückgegebenen Fehler auf fehlerhafte Eingabedaten zurückzuführen sind?

Kann man mit Sicherheit davon ausgehen, dass alle von strconv.Parse*-Funktionen zurückgegebenen Fehler auf fehlerhafte Eingabedaten zurückzuführen sind?

Feb 15, 2024 am 11:30 AM
Standardbibliothek

可以安全地假设从 strconv.Parse* 函数返回的任何错误一定是由于错误的输入数据造成的吗?

Kann man mit Sicherheit davon ausgehen, dass ein von der Funktion strconv.Parse zurückgegebener Fehler auf fehlerhafte Eingabedaten zurückzuführen sein muss? Bei dieser Frage geht es um das Verständnis der Fehlerbehandlung der Funktion strconv.Parse. Normalerweise wird der von der Funktion strconv.Parse zurückgegebene Fehler tatsächlich dadurch verursacht, dass die Eingabedaten nicht das erwartete Format haben. Es gibt jedoch einige besondere Umstände, die berücksichtigt werden müssen. Einige Fehler können auf den falschen Typ der Eingabedaten zurückzuführen sein, z. B. wenn eine Zeichenfolge in eine Ganzzahl konvertiert wird und die Zeichenfolge nicht numerische Zeichen enthält. Darüber hinaus gibt es Grenzfälle wie einen Ganzzahlüberlauf oder einen Verlust der Gleitkommagenauigkeit, die ebenfalls zu fehlerhaften Rückgabewerten führen können. Daher können wir bei Fehlern, die von der Funktion strconv.Parse zurückgegeben werden, nicht vollständig davon ausgehen, dass sie durch falsche Eingabedaten verursacht werden, sondern müssen andere mögliche Faktoren berücksichtigen.

Frageninhalt

Bei einer kürzlich durchgeführten Codeüberprüfung fragte mich der Prüfer, wie ich mit dem Fehler von strconv.ParseUint() 返回的错误提出了疑问。该函数被记录为返回转换后的 uint 值和 *strconv.NumError 具体类型的错误。文档提到了可以返回的该类型的两个哨兵错误(ErrSyntaxErrRange) umgegangen sei, was beides bedeutete, dass ihm falsche Daten zugeführt wurden. Abhängig von der Schnittstelle der Funktion kann auch jeder andere Fehler auftreten.

Für meinen Anwendungsfall muss ich wissen, ob es sich lohnt, den String-Wert, den ich habe, in einen uint-Wert umzuwandeln. Ein Fehler, wenn ParseUint 返回错误,并且它是哨兵错误之一,那么我得到了答案。但如果返回的错误不是这些,那么我返回它并停止执行。我的审阅者断言,我应该假设从 ParseUint 返回的任何错误意味着我给了它错误的数据,并且不需要检查哨兵错误,没有理由检查哨兵错误,也不会返回该错误(在我的用例中)。他们链接到 go 标准库中的一个示例,其中来自 ParseUint als Prüfung auf fehlerhafte Eingabedaten behandelt und nie zurückgegeben wird, was darauf hinweist, dass es dafür viele Beispiele gibt.

Während ich durchaus verstehen kann, dass es einen Algorithmus geben muss, der bei guten Daten und genügend Ressourcen immer das gewünschte Ergebnis berechnen kann, entspricht die reale Welt nicht immer dem theoretischen Ideal. Ich kann in der Dokumentation der Bibliothek nichts finden, was darauf hindeutet, dass sie aus keinem anderen Grund als fehlerhaften Daten einen Fehler zurückgibt und dies auch nie tun wird. Die Standardbibliothek verfügt über ein oder wahrscheinlich viele Beispiele dafür, was einerseits beruhigend und andererseits erschreckend ist, irgendwo zwischen „zwei Fehler machen noch kein Recht“ und „Sie machen es so, also muss es so sein.“ Seien Sie sicher für uns. Das Gleiche wird in diesem Fall getan.

Ist es nur so, dass in der Bibliotheksdokumentation ein Satz fehlt? Oder ist es sinnvoll, einen Fehler zurückzugeben, wenn keiner dieser beiden Fehler vorliegt? Wie soll ich argumentieren?

Lösung

Ja, man kann davon ausgehen, dass der Fehler in der strconv.ParseXXX-Funktion auf fehlerhafte Eingabedaten zurückzuführen ist.

Von der Dokumentationsseite, die Sie erwähnt haben:

Ich lese das so: „Alle Fehler in strconv.ParseXXX sind NumError und können auf ungültige Zahlen oder Bitgrößenbereichsfehler zurückzuführen sein.“ Meines Wissens nach versuchen Godocs, den erwarteten Umfang eines Funktionsaufrufs so vollständig wie möglich darzustellen.

Ich denke also, dass man mit Sicherheit davon ausgehen kann, dass dies die strconv.ParseXXXeinzigen Fehler sind, die möglicherweise von einer -Funktion zurückgegeben werden. Wenn etwas anderes zurückkommt, würde ich es als Dokumentationsfehler betrachten.

Um Ihre letzte Frage zu beantworten: Das Muster, das Sie beim Aufruf dieser Funktion aus der Standardbibliothek beobachtet haben, ist korrekt. Geben Sie den gesamten Fehler zurück und lassen Sie den Anrufer entscheiden, was damit geschehen soll. Sentinel-Fehler sollen Ihnen helfen zu verstehen, was schief gelaufen ist, und die gesamte Bandbreite an Fehlern darstellen, die bei diesen Funktionen auftreten können.

Das obige ist der detaillierte Inhalt vonKann man mit Sicherheit davon ausgehen, dass alle von strconv.Parse*-Funktionen zurückgegebenen Fehler auf fehlerhafte Eingabedaten zurückzuführen sind?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Java-Tutorial
1657
14
PHP-Tutorial
1257
29
C#-Tutorial
1229
24
_komplexe Verwendung in C-Sprache _komplexe Verwendung in C-Sprache May 08, 2024 pm 01:27 PM

Der komplexe Typ wird zur Darstellung komplexer Zahlen in der C-Sprache verwendet, einschließlich Real- und Imaginärteilen. Seine Initialisierungsform ist complex_number = 3.14 + 2.71i, auf den Realteil kann über creal(complex_number) und auf den Imaginärteil über cimag(complex_number) zugegriffen werden. Dieser Typ unterstützt gängige mathematische Operationen wie Addition, Subtraktion, Multiplikation, Division und Modulo. Darüber hinaus wird eine Reihe von Funktionen zum Arbeiten mit komplexen Zahlen bereitgestellt, z. B. cpow, csqrt, cexp und csin.

Was bedeutet Primzahl in C++? Was bedeutet Primzahl in C++? May 07, 2024 pm 11:33 PM

prime ist ein Schlüsselwort in C++, das den Primzahltyp angibt, der nur durch 1 geteilt werden kann. Es wird als boolescher Typ verwendet, um anzugeben, ob der angegebene Wert eine Primzahl ist wahr, andernfalls ist es falsch.

Was bedeutet Fabs in C++? Was bedeutet Fabs in C++? May 08, 2024 am 01:15 AM

Die Funktion fabs() ist eine mathematische Funktion in C++, die den absoluten Wert einer Gleitkommazahl berechnet, das negative Vorzeichen entfernt und einen positiven Wert zurückgibt. Es akzeptiert einen Gleitkommaparameter und gibt einen absoluten Wert vom Typ Double zurück. Fabs(-5.5) gibt beispielsweise 5,5 zurück. Diese Funktion arbeitet mit Gleitkommazahlen, deren Genauigkeit von der zugrunde liegenden Hardware beeinflusst wird.

So verwenden Sie std:: in C++ So verwenden Sie std:: in C++ May 09, 2024 am 03:45 AM

std ist der Namespace in C++, der Komponenten der Standardbibliothek enthält. Um std zu verwenden, verwenden Sie die Anweisung „using namespace std;“. Die direkte Verwendung von Symbolen aus dem std-Namespace kann Ihren Code vereinfachen, wird jedoch nur bei Bedarf empfohlen, um eine Verschmutzung des Namespace zu vermeiden.

Was bedeutet min in C++? Was bedeutet min in C++? May 08, 2024 am 12:51 AM

Die min-Funktion in C++ gibt das Minimum mehrerer Werte zurück. Die Syntax lautet: min(a, b), wobei a und b die zu vergleichenden Werte sind. Sie können auch eine Vergleichsfunktion angeben, um Typen zu unterstützen, die den <-Operator nicht unterstützen. C++20 hat die Funktion std::clamp eingeführt, die mindestens drei oder mehr Werte verarbeitet.

C++-Smartpointer: eine umfassende Analyse ihres Lebenszyklus C++-Smartpointer: eine umfassende Analyse ihres Lebenszyklus May 09, 2024 am 11:06 AM

Lebenszyklus von C++-Smartpointern: Erstellung: Smartpointer werden erstellt, wenn Speicher zugewiesen wird. Eigentumsübertragung: Übertragen Sie das Eigentum durch einen Umzugsvorgang. Freigabe: Speicher wird freigegeben, wenn ein Smart Pointer den Gültigkeitsbereich verlässt oder explizit freigegeben wird. Objektzerstörung: Wenn das Objekt, auf das gezeigt wird, zerstört wird, wird der intelligente Zeiger zu einem ungültigen Zeiger.

Was bedeutet Primzahl in C++? Was bedeutet Primzahl in C++? May 07, 2024 pm 11:24 PM

In C++ bezieht sich Primzahl auf eine Primzahl, eine natürliche Zahl größer als 1, die nur durch 1 und sich selbst teilbar ist. Primzahlen werden häufig in der Kryptographie, bei mathematischen Problemen und Algorithmen verwendet. Zu den Methoden zur Erzeugung von Primzahlen gehören das Eratostheische Sieb, der Kleine Satz von Fermat und der Miller-Rabin-Test. Die C++-Standardbibliothek stellt die Funktion isPrime bereit, um zu bestimmen, ob es sich um eine Primzahl handelt. Die Funktion nextPrime gibt die kleinste Primzahl zurück, die größer als ein gegebener Wert ist, und die Funktion prevPrime gibt die kleinste Primzahl zurück, die kleiner als ein gegebener Wert ist.

Was sind die Frameworks und Bibliotheken für die gleichzeitige Programmierung in C++? Was sind ihre jeweiligen Vorteile und Grenzen? Was sind die Frameworks und Bibliotheken für die gleichzeitige Programmierung in C++? Was sind ihre jeweiligen Vorteile und Grenzen? May 07, 2024 pm 02:06 PM

Das C++-Parallelitäts-Framework bietet die folgenden Optionen: leichte Threads (std::thread); Thread-sichere Boost-Parallelitätscontainer und -Algorithmen; leistungsstarke ThreadBuildingBlocks (TBB)-Operationsbibliothek (cpp-Concur).

See all articles