prefer_final_parameters
Prefer final for parameter declarations if they are not reassigned.
This rule is available as of Dart 2.14.
This rule has a quick fix available.
Incompatible rules: unnecessary_final, avoid_final_parameters
Details
#DO prefer declaring parameters as final if they are not reassigned in the function body.
Declaring parameters as final when possible is a good practice because it helps avoid accidental reassignments.
BAD:
void badParameter(String label) { // LINT
print(label);
}GOOD:
void goodParameter(final String label) { // OK
print(label);
}BAD:
void badExpression(int value) => print(value); // LINTGOOD:
void goodExpression(final int value) => print(value); // OKBAD:
[1, 4, 6, 8].forEach((value) => print(value + 2)); // LINTGOOD:
[1, 4, 6, 8].forEach((final value) => print(value + 2)); // OKGOOD:
void mutableParameter(String label) { // OK
print(label);
label = 'Hello Linter!';
print(label);
}Usage
#To enable the prefer_final_parameters rule, add prefer_final_parameters under linter > rules in your analysis_options.yaml file:
linter:
rules:
- prefer_final_parametersUnless stated otherwise, the documentation on this site reflects Dart 3.6.0. Page last updated on 2024-07-03. View source or report an issue.