Table of Contents
Question content
Home Backend Development Golang Is it safe to assume that any errors returned from strconv.Parse* functions must be due to bad input data?

Is it safe to assume that any errors returned from strconv.Parse* functions must be due to bad input data?

Feb 15, 2024 am 11:30 AM
standard library

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

Is it safe to assume that any error returned from the strconv.Parse function must be due to bad input data? This question involves the understanding of error handling of the strconv.Parse function. Typically, the error returned by the strconv.Parse function is indeed caused by the input data not being in the expected format. However, there are some special circumstances that need to be considered. Some errors may be due to the wrong type of input data, such as when converting a string to an integer and the string contains non-numeric characters. Additionally, there are edge cases, such as integer overflow or loss of floating point precision, that can also result in incorrect return values. Therefore, for errors returned from the strconv.Parse function, we cannot completely assume that they are caused by incorrect input data, but need to consider other possible factors.

Question content

During a recent code review, the reviewer raised questions about how I handle errors returned from strconv.ParseUint(). This function is documented to return the converted uint value and the *strconv.NumError specific type of error. The documentation mentions two sentinel errors of this type that can be returned (ErrSyntax and ErrRange), both of which mean that bad data was supplied to it. Depending on the interface of the function, any other error may also occur.

For my use case, I need to know if the string value I have is worth converting to a uint. If ParseUint returns an error, and it's one of the sentinel errors, then I have the answer. But if the error returned is none of these, then I return it and stop execution. My reviewer asserted that I should assume that any error returned from ParseUint means I gave it the wrong data, and that there is no need to check for sentinel errors, there is no reason to check for sentinel errors, Also the error is not returned (in my use case). They link to an example in the go standard library where an error from ParseUint is treated as a check for bad input data and never returned, and say there are many such examples.

While I can certainly understand that there must be an algorithm that can always compute the desired result given good data and enough resources, the real world does not always match the theoretical ideal. I can't find anything in the library's documentation that states that it does not and will never return an error for any reason other than bad data. The standard library has one or probably many examples of this, which is reassuring on the one hand and terrifying on the other, somewhere between "two wrongs don't make a right" and "they're doing it this way, so it must be safe for us The same is done in this case.

Is this just a case of the library documentation missing a sentence? Or is it good to return an error when it is neither of these two errors? How should I reason?

Solution

Yes, it is safe to assume that the error in the

strconv.ParseXXX function is due to incorrect input data.

From the documentation page you mentioned:

The way I read this is "Any errors in strconv.ParseXXX are

NumError and may be due to invalid numbers or bit size range errors". My understanding is that godocs try to outline as completely as possible the expected scope of a function call.

Therefore, I think it's safe to assume that these are the

only errors you may see returned from the strconv.ParseXXX function. If something else comes back, I'd consider it a documentation bug.

To answer your last question: the pattern you observed when calling this function from the standard library is correct. Return the entire error and let the caller decide what to do with it. Sentinel errors are designed to help you understand what went wrong and represent the full range of errors that can occur with these functions.

The above is the detailed content of Is it safe to assume that any errors returned from strconv.Parse* functions must be due to bad input data?. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to use absolute value in c++ How to use absolute value in c++ May 06, 2024 pm 06:15 PM

There are two ways to obtain absolute values ​​in C++: 1. Use the built-in function abs() to obtain the absolute value of an integer or floating point type; 2. Use the generic function std::abs() to obtain various supported absolute values. Operates on absolute values ​​of data types.

How to use std:: in c++ How to use std:: in c++ May 09, 2024 am 03:45 AM

std is the namespace in C++ that contains components of the standard library. In order to use std, use the "using namespace std;" statement. Using symbols directly from the std namespace can simplify your code, but is recommended only when needed to avoid namespace pollution.

What does prime mean in c++ What does prime mean in c++ May 07, 2024 pm 11:33 PM

prime is a keyword in C++, indicating the prime number type, which can only be divided by 1 and itself. It is used as a Boolean type to indicate whether the given value is a prime number. If it is a prime number, it is true, otherwise it is false.

_complex usage in c language _complex usage in c language May 08, 2024 pm 01:27 PM

The complex type is used to represent complex numbers in C language, including real and imaginary parts. Its initialization form is complex_number = 3.14 + 2.71i, the real part can be accessed through creal(complex_number), and the imaginary part can be accessed through cimag(complex_number). This type supports common mathematical operations such as addition, subtraction, multiplication, division, and modulo. In addition, a set of functions for working with complex numbers is provided, such as cpow, csqrt, cexp, and csin.

What does fabs mean in c++ What does fabs mean in c++ May 08, 2024 am 01:15 AM

The fabs() function is a mathematical function in C++ that calculates the absolute value of a floating point number, removes the negative sign and returns a positive value. It accepts a floating point parameter and returns an absolute value of type double. For example, fabs(-5.5) returns 5.5. This function works with floating point numbers, whose accuracy is affected by the underlying hardware.

What does config mean in java? What does config mean in java? May 07, 2024 am 02:39 AM

Config represents configuration information in Java and is used to adjust application behavior. It is usually stored in external files or databases and can be managed through Java Properties, PropertyResourceBundle, Java Configuration Framework or third-party libraries. Its benefits include decoupling and flexibility. , environmental awareness, manageability, scalability.

What does min mean in c++ What does min mean in c++ May 08, 2024 am 12:51 AM

The min function in C++ returns the minimum of multiple values. The syntax is: min(a, b), where a and b are the values ​​to be compared. You can also specify a comparison function to support types that do not support the < operator. C++20 introduced the std::clamp function, which handles the minimum of three or more values.

How to calculate absolute value in c++ How to calculate absolute value in c++ May 06, 2024 pm 06:21 PM

There are three ways to find the absolute value in C++: Using the abs() function, you can calculate the absolute value of any type of number. Using the std::abs() function, you can calculate the absolute value of integers, floating point numbers, and complex numbers. Manual calculation of absolute values, suitable for simple integers.

See all articles