Skip to main content

CWE-481: Assigning instead of Comparing

VariantDraftExploit Likelihood: Low

The code uses an operator for assignment when the intention was to perform a comparison.

View on MITRE
Back to CWE Lookup

Extended Description

In many languages the compare statement is very close in appearance to the assignment statement and are often confused. This bug is generally the result of a typo and usually causes obvious problems with program execution. If the comparison is in an if statement, the if statement will usually evaluate the value of the right-hand side of the predicate.

Technical Details

Structure
Simple

Applicable To

Languages
CC++JavaC#
Platforms

Frequently Asked Questions

What is CWE-481: Assigning instead of Comparing?+

CWE-481: Assigning instead of Comparing is a Common Weakness Enumeration (CWE) entry maintained by MITRE. The code uses an operator for assignment when the intention was to perform a comparison. In many languages the compare statement is very close in appearance to the assignment statement and are often confused. This bug is generally the result of a typo and usually causes obvious problems with program execution. If the comparison is in an if statement, the if statement will usually evaluate the value of the right-hand side of the predicate.

What are the security consequences of Assigning instead of Comparing?+

If exploited, CWE-481 (Assigning instead of Comparing) it can compromise Other, leading to outcomes such as Alter Execution Logic.

How do you prevent or mitigate Assigning instead of Comparing?+

Recommended mitigations for CWE-481 include: Many IDEs and static analysis products will detect this problem. Place constants on the left. If one attempts to assign a constant with a variable, the compiler will produce an error.

Which programming languages are affected by Assigning instead of Comparing?+

CWE-481 commonly affects C, C++, Java and C#. Note that weaknesses are often language-agnostic patterns, so secure coding practices apply broadly.

What is the difference between a CWE and a CVE?+

A CWE (Common Weakness Enumeration) like CWE-481 describes a category of software weakness — the underlying flaw type. A CVE (Common Vulnerabilities and Exposures) identifies a specific, real-world vulnerability in a particular product. In short, a CWE is the kind of mistake, and a CVE is an instance of that mistake being found in software.

Learn More