What's the difference between "var" and "out" parameters?

DelphiParametersPass by-Reference

Delphi Problem Overview


What's the difference between parameters declared with var and those declared with out? How does the compiler treat them differently (e.g., by generating different code, or by changing which diagnostics it issues)? Or do the different modifiers merely allow the programmer to document intended use of the parameters? What effect do the types of the parameters have on the matter?

Delphi Solutions


Solution 1 - Delphi

A var parameter will be passed by reference, and that's it.

An out parameter is also passed by reference, but it's assumed that the input value is irrelevant. For managed types, (strings, Interfaces, etc,) the compiler will enforce this, by clearing the variable before the routine begins, equivalent to writing param := nil. For unmanaged types, the compiler implements out identically to var.

Note that the clearing of a managed parameter is performed at the call-site and so the code generated for the function does not vary with out or var parameters.

Solution 2 - Delphi

There is not much difference, for the compiler that is. See Mason's answer for that.

Semantically, there is a big difference:

  • var tells the programmer that the routine could work with its current value,
  • out tells the programmer that the routine will ignore/discard its current value.

Solution 3 - Delphi

Slightly late but just for the record, I came across a case where var or out made a big difference.

I was working on a SOAP web service which exported the following method:

function GetUser( out User :TUser ) :TResult;

which was getting imported into C# as the equivalent of

function GetUser( out Result :TResult) :TUser;

when I changed the out to a var it it imported correctly.

I'm guessing that the Delphi SOAP invoker treats the function result as an out parameter and that having two out parameters confuses the Delphi SOAP routines. I'm not sure if there is a workaround to allow you to use out parameters.

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionRob KennedyView Question on Stackoverflow
Solution 1 - DelphiMason WheelerView Answer on Stackoverflow
Solution 2 - DelphiNGLNView Answer on Stackoverflow
Solution 3 - DelphiSteveView Answer on Stackoverflow