473,503 Members | 13,381 Online
Bytes | Software Development & Data Engineering Community
+ Post

Home Posts Topics Members FAQ

Why do I get a

Mr. Gunnerson, et. al.

Why does the C# compiler keep on complaining about an "out" parameter that is not assigned when it is really is? Here is the snippet.

using System

namespace BugNam

class Bu

public static Bug Instance = new Bug()
public Bug(){} // cto
static int Main(String[] args) // not voi

int iResultM = 0
Instance.MyIncrementer(out iResultM)
return iResultM
} // end Mai
public void MyIncrementer(out int iArgNum

// iArgNum = 0; // uncomment this and the error goes awa
iArgNum = iArgNum + 1; // causes an error!!!

}
If I uncomment the iArgNum = 0 line, the error goes away

Is this a compiler bug or my bug? After reading the online help, I don't see what I am doing wrong. Notice the original argument was declared as a local variable and was initialized as well (to 0). Then it was passed as an out parameter -- in other words I'm initializing it because I know the function MyIncrementer will be trying to read it before it sets it (and to boot, I didn't even have to use out since out can be used for a variable without initializing it)

What's up

Thanks

Harr

Nov 16 '05 #1
8 1075
Mr. Gunnerson, et. al.:
Why does the C# compiler keep on complaining about
an "out" parameter that is not assigned when it is
really is?
It's not assigned *within* the method. There's a big difference between
"ref" and "out".
[snip]

int iResultM = 0;
Instance.MyIncrementer(out iResultM);

public void MyIncrementer(out int iArgNum)
{
// iArgNum = 0; // uncomment this and the error goes away
iArgNum = iArgNum + 1; // causes an error!!!!
}

[snip]
If I uncomment the iArgNum = 0 line, the error goes away.


"out" means that the parameter/variable is "returned" from the method, and
whatever value you have assigned to it outside and before the call, is
ignored. That variable is just "the place" where the result then is put
into.

In the line

iArgNum = iArgNum + 1;

....you're consequencually trying to "use" the variable without it having
been initialized.

// Bjorn A
Nov 16 '05 #2
I didn't see this on MSDN but in the Anders H. book I see the statement:

"Within a method, just like a local variable, an output variable is considered initially unassigned and must be "definitely" assigned before it's value is used.

This explains my error and why assigning to 0 (of no use to me) cleared it up -- I see now that the language designers are intending for this to be used for functions that return multiple values. This means I am forced to pass the same parameter as both an input and (separately) an "out" parameter to achieve my desired results. I don't have the compiler in front of me but hopefully I can do something like:

Instance.MyIncrementer(iResultM, out iResultM);

public void MyIncrementer(int iArgNumInput, out int iArgNum)
{
iArgNum = iArgNumInput;
iArgNum = iArgNum + 1;
}
So C# truly has eliminated "pass by reference" in that one can't read the value of the "out" parameter -- one must set it first. I wonder if this is a design flaw or if this is intentional or perhaps it is necessary to support the language. I suppose the storage in the callee is initialized AFTER (or just at) return from the function -- and as well, the JIT compiler probably cannot easily tell if all call sites have intialized the the memory -- the JIT can tell the function initialized it so therefore on the way back, the callee will have a definite value to store in the possibly uninitialized parameter varaible.

I thank myself for answering my own question :-) :-)

I think MSDN on-line help should state that point more loudly anc clearly (repeating): "Within a method, just like a local variable, an output variable is considered initially unassigned and must be "definitely" assigned before it's value is used.
Nov 16 '05 #3

"Harry" wrote...
public void MyIncrementer(int iArgNumInput, out int iArgNum)
{
iArgNum = iArgNumInput;
iArgNum = iArgNum + 1;
} So C# truly has eliminated "pass by reference" in that one
can't read the value of the "out" parameter -- one must set
it first.


Why don't you use "ref" instead, if that's what you want?

public void MyIncrementer(ref int iArgNum)
{
iArgNum = iArgNum + 1;
}

// Bjorn A

Nov 16 '05 #4
public void NotInit()
{
int i;
MyIncrementer(out i);
}
In this case i has not been initialised and as such needs to be initialised.

You should be passing by ref if you are going to use the parameters existing
value in the method (which you are in this case).

On a style note (not important but c# has such cool style) this looks better
:)

public void MyIncrementer(ref NumToIncrement)
{
NumToIncrement += 1;
}

HTH
JB

"Harry" <an*******@discussions.microsoft.com> wrote in message
news:E9**********************************@microsof t.com...
Mr. Gunnerson, et. al.:

Why does the C# compiler keep on complaining about an "out" parameter that is not assigned when it is really is? Here is the snippet.:
using System;

namespace BugName
{
class Bug
{
public static Bug Instance = new Bug();
public Bug(){} // ctor
static int Main(String[] args) // not void
{
int iResultM = 0;
Instance.MyIncrementer(out iResultM);
return iResultM;
} // end Main
public void MyIncrementer(out int iArgNum)
{
// iArgNum = 0; // uncomment this and the error goes away
iArgNum = iArgNum + 1; // causes an error!!!!
}
};
}

If I uncomment the iArgNum = 0 line, the error goes away.

Is this a compiler bug or my bug? After reading the online help, I don't see what I am doing wrong. Notice the original argument was declared as a
local variable and was initialized as well (to 0). Then it was passed as an
out parameter -- in other words I'm initializing it because I know the
function MyIncrementer will be trying to read it before it sets it (and to
boot, I didn't even have to use out since out can be used for a variable
without initializing it).
What's up?

Thanks,

Harry

Nov 16 '05 #5
Harry <an*******@discussions.microsoft.com> wrote:
So C# truly has eliminated "pass by reference" in that one can't read
the value of the "out" parameter -- one must set it first.


No, C# has provided an out parameter modifier so that you don't have to
have the variable definitely assigned in the caller. If you want
"normal" pass by reference, you just use "ref" instead.

See http://www.pobox.com/~skeet/csharp/parameters.html

--
Jon Skeet - <sk***@pobox.com>
http://www.pobox.com/~skeet
If replying to the group, please do not mail me too
Nov 16 '05 #6
"John Baro" <jo***@NOSPAMmesware.com.au> wrote:
On a style note (not important but c# has such cool
style) this looks better :)
[...]
NumToIncrement += 1;


NumToIncrement++;

P.
Nov 16 '05 #7

"Paul E Collins" <fi******************@CL4.org> wrote in message
news:c6**********@hercules.btinternet.com...
"John Baro" <jo***@NOSPAMmesware.com.au> wrote:
On a style note (not important but c# has such cool
style) this looks better :)
[...]
NumToIncrement += 1;


NumToIncrement++;


That too.
Personally I use NumToIncrement++; so I dont know why I wrote NumToIncrement
+= 1;
However if you wanted to add two you would do NumToIncrement += 2; (Not that
we want to do this however)
:)
Cheers
JB
Nov 16 '05 #8
Paul E Collins wrote:
"John Baro" <jo***@NOSPAMmesware.com.au> wrote:
On a style note (not important but c# has such cool
style) this looks better :)
[...]
NumToIncrement += 1;


NumToIncrement++;


Surely you mean:

++NumToIncrement;

;-)
Nov 16 '05 #9

This thread has been closed and replies have been disabled. Please start a new discussion.

Similar topics

3
11177
by: William C. White | last post by:
Does anyone know of a way to use PHP /w Authorize.net AIM without using cURL? Our website is hosted on a shared drive and the webhost company doesn't installed additional software (such as cURL)...
2
5773
by: Albert Ahtenberg | last post by:
Hello, I don't know if it is only me but I was sure that header("Location:url") redirects the browser instantly to URL, or at least stops the execution of the code. But appearantely it continues...
3
22957
by: James | last post by:
Hi, I have a form with 2 fields. 'A' 'B' The user completes one of the fields and the form is submitted. On the results page I want to run a query, but this will change subject to which...
0
8431
by: Ollivier Robert | last post by:
Hello, I'm trying to link PHP with Oracle 9.2.0/OCI8 with gcc 3.2.3 on a Solaris9 system. The link succeeds but everytime I try to run php, I get a SEGV from inside the libcnltsh.so library. ...
1
8535
by: Richard Galli | last post by:
I want viewers to compare state laws on a single subject. Imagine a three-column table with a drop-down box on the top. A viewer selects a state from the list, and that state's text fills the...
4
18214
by: Albert Ahtenberg | last post by:
Hello, I have two questions. 1. When the user presses the back button and returns to a form he filled the form is reseted. How do I leave there the values he inserted? 2. When the...
1
6776
by: inderjit S Gabrie | last post by:
Hi all Here is the scenerio ...is it possibly to do this... i am getting valid course dates output on to a web which i have designed ....all is okay so far , look at the following web url ...
2
31340
by: Jack | last post by:
Hi All, What is the PHP equivilent of Oracle bind variables in a SQL statement, e.g. select x from y where z=:parameter Which in asp/jsp would be followed by some statements to bind a value...
3
23531
by: Sandwick | last post by:
I am trying to change the size of a drawing so they are all 3x3. the script below is what i was trying to use to cut it in half ... I get errors. I can display the normal picture but not the...
0
7212
marktang
by: marktang | last post by:
ONU (Optical Network Unit) is one of the key components for providing high-speed Internet services. Its primary function is to act as an endpoint device located at the user's premises. However,...
0
7296
Oralloy
by: Oralloy | last post by:
Hello folks, I am unable to find appropriate documentation on the type promotion of bit-fields when using the generalised comparison operator "<=>". The problem is that using the GNU compilers,...
0
7364
jinu1996
by: jinu1996 | last post by:
In today's digital age, having a compelling online presence is paramount for businesses aiming to thrive in a competitive landscape. At the heart of this digital strategy lies an intricately woven...
1
7017
by: Hystou | last post by:
Overview: Windows 11 and 10 have less user interface control over operating system update behaviour than previous versions of Windows. In Windows 11 and 10, there is no way to turn off the Windows...
0
7470
tracyyun
by: tracyyun | last post by:
Dear forum friends, With the development of smart home technology, a variety of wireless communication protocols have appeared on the market, such as Zigbee, Z-Wave, Wi-Fi, Bluetooth, etc. Each...
1
5026
isladogs
by: isladogs | last post by:
The next Access Europe User Group meeting will be on Wednesday 1 May 2024 starting at 18:00 UK time (6PM UTC+1) and finishing by 19:30 (7.30PM). In this session, we are pleased to welcome a new...
0
4696
by: conductexam | last post by:
I have .net C# application in which I am extracting data from word file and save it in database particularly. To store word all data as it is I am converting the whole word file firstly in HTML and...
0
3186
by: TSSRALBI | last post by:
Hello I'm a network technician in training and I need your help. I am currently learning how to create and manage the different types of VPNs and I have a question about LAN-to-LAN VPNs. The...
0
3174
by: adsilva | last post by:
A Windows Forms form does not have the event Unload, like VB6. What one acts like?

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.