BUG: Watch Expression Evaluation Gives Unexpected Value (118395)
The information in this article applies to:
- Microsoft FORTRAN PowerStation for MS-DOS 1.0
- Microsoft FORTRAN PowerStation for MS-DOS 1.0a
- Microsoft Fortran Powerstation 32 for Windows NT 1.0
This article was previously published under Q118395 SYMPTOMS
Expressions evaluated in the watch window result in incorrect values, and
no overflow warnings are given.
CAUSE
The FORTRAN expression evaluator, which calculates the value of expressions
that are typed into the watch window, uses the same data type to store
intermediate values as it does to store the terms in the expression.
For example, if all of the terms in an expression were INTEGER*2, then the
expression will be evaluated with INTEGER*2 arithmetic. It is very common
for an overflow to occur in subexpressions of an expression, even if the
final value can be stored in INTEGER*2. The result of a calculation
following this convention is incorrect because this is not the way
expressions are evaluated in FORTRAN code.
RESOLUTION
Avoid creating expressions that could overflow. The most reliable way to
do this is to avoid using INTEGER*2 and INTEGER*1.
You can make the subexpressions of an expression be calculated in
INTEGER*4 by forcing one of the terms to be stored as INTEGER*4. To do
this, use the function INT4() on a term in the subexpression.
STATUS
Microsoft has confirmed this to be a bug in the Microsoft FORTRAN
PowerStation for MS-DOS, versions 1.0 and 1.0a, and the Microsoft FORTRAN
PowerStation 32 for Windows NT, version 1.0. We are researching this
problem and will post new information here in the Microsoft Knowledge Base
as it becomes available.
Modification Type: | Major | Last Reviewed: | 10/24/2003 |
---|
Keywords: | KB118395 |
---|
|