Maison >développement back-end >Golang >Est-il prudent de supposer que les erreurs renvoyées par les fonctions strconv.Parse* doivent être dues à de mauvaises données d'entrée ?

Est-il prudent de supposer que les erreurs renvoyées par les fonctions strconv.Parse* doivent être dues à de mauvaises données d'entrée ?

王林
王林avant
2024-02-15 11:30:11920parcourir

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

Est-il prudent de supposer que toute erreur renvoyée par la fonction strconv.Parse doit être due à de mauvaises données d'entrée ? Cette question implique la compréhension de la gestion des erreurs de la fonction strconv.Parse. Généralement, l'erreur renvoyée par la fonction strconv.Parse est en effet provoquée par le fait que les données d'entrée ne sont pas au format attendu. Cependant, certaines circonstances particulières doivent être prises en compte. Certaines erreurs peuvent être dues à un type de données d'entrée incorrect, par exemple lors de la conversion d'une chaîne en nombre entier et que la chaîne contient des caractères non numériques. De plus, il existe des cas extrêmes, tels qu'un dépassement d'entier ou une perte de précision en virgule flottante, qui peuvent également entraîner des valeurs de retour erronées. Par conséquent, pour les erreurs renvoyées par la fonction strconv.Parse, nous ne pouvons pas entièrement supposer qu'elles sont causées par des données d'entrée incorrectes, mais nous devons prendre en compte d'autres facteurs possibles.

Contenu de la question

Lors d'une récente révision du code, le réviseur m'a demandé comment j'avais géré l'erreur de strconv.ParseUint() 返回的错误提出了疑问。该函数被记录为返回转换后的 uint 值和 *strconv.NumError 具体类型的错误。文档提到了可以返回的该类型的两个哨兵错误(ErrSyntaxErrRange), ce qui signifiait tous deux qu'il recevait des données incorrectes. Selon l'interface de la fonction, toute autre erreur peut également survenir.

Pour mon cas d'utilisation, j'ai besoin de savoir si la valeur de chaîne que j'ai vaut la peine d'être convertie en uint. Une erreur si ParseUint 返回错误,并且它是哨兵错误之一,那么我得到了答案。但如果返回的错误不是这些,那么我返回它并停止执行。我的审阅者断言,我应该假设从 ParseUint 返回的任何错误意味着我给了它错误的数据,并且不需要检查哨兵错误,没有理由检查哨兵错误,也不会返回该错误(在我的用例中)。他们链接到 go 标准库中的一个示例,其中来自 ParseUint est traité comme une vérification de mauvaises données d'entrée et n'est jamais renvoyé, indiquant qu'il existe de nombreux exemples de cela.

Bien que je puisse certainement comprendre qu'il doit y avoir un algorithme capable de toujours calculer le résultat souhaité avec de bonnes données et suffisamment de ressources, le monde réel ne correspond pas toujours à l'idéal théorique. Je ne trouve rien dans la documentation de la bibliothèque indiquant qu'elle ne renvoie pas et ne renverra jamais d'erreur pour une raison autre que des données incorrectes. La bibliothèque standard en contient un ou probablement plusieurs exemples, ce qui est rassurant d'un côté et terrifiant de l'autre, quelque part entre "deux torts ne font pas un bien" et "ils font les choses de cette façon, donc il faut soyez en sécurité pour nous. La même chose est faite dans ce cas.

Est-ce simplement le cas d'une phrase manquante dans la documentation de la bibliothèque ? Ou est-il bon de renvoyer une erreur alors qu’il ne s’agit d’aucune de ces deux erreurs ? Comment raisonner ?

Solution

Oui, il est prudent de supposer que l'erreur dans la fonction strconv.ParseXXX est due à de mauvaises données d'entrée.

Depuis la page de documentation que vous avez mentionnée :

La façon dont je lis ceci est "toutes les erreurs dans strconv.ParseXXX sont NumError et peuvent être dues à des nombres invalides ou à des erreurs de plage de tailles de bits". Je crois comprendre que les godocs essaient de décrire aussi complètement que possible la portée attendue d'un appel de fonction.

Je pense donc qu'il est prudent de supposer que ce sont les strconv.ParseXXXseules erreurs que vous pourriez voir renvoyées par une fonction . Si quelque chose d'autre revient, je considérerais cela comme un bug de documentation.

Pour répondre à votre dernière question : le modèle que vous avez observé lors de l'appel de cette fonction depuis la bibliothèque standard est correct. Renvoyez l’intégralité de l’erreur et laissez l’appelant décider quoi en faire. Les erreurs Sentinel sont conçues pour vous aider à comprendre ce qui n’a pas fonctionné et représentent l’ensemble des erreurs pouvant survenir avec ces fonctions.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer