Why doesn't the compiler warn about bad formatters?
Why doesn't the compiler warn about bad formatters? In programming, a formatter is a tool used to beautify code. It can automatically adjust the indentation, spaces, line breaks, etc. of the code to make the code more readable. However, sometimes we may make some formatter errors, such as missing brackets, extra semicolons, etc. Although these errors may lead to logical errors in the code, the compiler often does not warn about these errors. So why doesn't the compiler warn about these bad formatters? First of all, the main task of the compiler is to convert the source code into executable machine code. It will check for syntax errors to ensure the correctness of the code. However, formatter errors tend to be semantic rather than syntactic errors. In other words, these errors do not affect the executability of the code, they just make the code less readable. Therefore, the compiler has no obligation to warn about these errors. Second, formatter errors are often subjective, and different developers have different coding styles and preferences. For example, some people like to use braces in their code, while others don't. The compiler cannot determine which style is correct and therefore cannot warn about formatter errors. Finally, warn that formatter errors may generate a large number of false positives. In large projects, the size of the code is often very large, and a small formatter error can cause thousands of warnings. This will not only cause trouble to developers, but also increase the difficulty of code maintenance. To avoid this
Question content
I would expect the following code to at least issue a warning during compilation because the formatter is inconsistent with the type of the variable:
package main import "fmt" func main() { s := "hello" fmt.printf("1 %w", s) fmt.printf("2 %s", s) }
The type of the variable is known at compile time and the string formatter parses it in a deterministic way - is there a reason why the error is not raised at this point?
What I get is the output code
1 %!w(string=hello)2 hello
This seems to be some kind of message telling %w
that the type is wrong for string
(but only at runtime)
Workaround
fmt.printf
Format string parameters are interpreted at runtime, not compile time.
func printf(format string, a ...any) (n int, err error)
printf formats according to the format specifier and writes to standard output. It returns the number of bytes written and any write errors encountered.
Use static analysis linter, such as go vet
.
go command - cmd/go - go package
Report possible errors in the package
usage:
go vet [-n] [-x] [-vettool prog] [build flags] [vet flags] [packages]
vet Run the go vet command on the package named by the import path.
For more information about vet and its flags, see "go doc cmd /vet".
so.go:
package main import "fmt" func main() { s := "hello" fmt.printf("1 %w\n", s) fmt.printf("2 %s\n", s) }
Linter Check:
$ go vet so.go ./so.go:7:2: fmt.printf format %w has arg s of wrong type string, see also https://pkg.go.dev/fmt#hdr-printing $
Runtime:
$ go run so.go 1 %!w(string=hello) 2 hello $
The above is the detailed content of Why doesn't the compiler warn about bad formatters?. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

The article explains how to use the pprof tool for analyzing Go performance, including enabling profiling, collecting data, and identifying common bottlenecks like CPU and memory issues.Character count: 159

The article discusses writing unit tests in Go, covering best practices, mocking techniques, and tools for efficient test management.

This article demonstrates creating mocks and stubs in Go for unit testing. It emphasizes using interfaces, provides examples of mock implementations, and discusses best practices like keeping mocks focused and using assertion libraries. The articl

This article explores Go's custom type constraints for generics. It details how interfaces define minimum type requirements for generic functions, improving type safety and code reusability. The article also discusses limitations and best practices

This article explores using tracing tools to analyze Go application execution flow. It discusses manual and automatic instrumentation techniques, comparing tools like Jaeger, Zipkin, and OpenTelemetry, and highlighting effective data visualization

The article discusses Go's reflect package, used for runtime manipulation of code, beneficial for serialization, generic programming, and more. It warns of performance costs like slower execution and higher memory use, advising judicious use and best

The article discusses using table-driven tests in Go, a method that uses a table of test cases to test functions with multiple inputs and outcomes. It highlights benefits like improved readability, reduced duplication, scalability, consistency, and a

The article discusses managing Go module dependencies via go.mod, covering specification, updates, and conflict resolution. It emphasizes best practices like semantic versioning and regular updates.
