Re: how to pass params to inline functions by reference or value?

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



--- VM <mayeski@xxxxxxxxx> wrote:
> Hello,
> 
> I'm trying to decide on the best way to pass
> parameters to inline
> function. For example, the two functions below:
> 
> inline int
> sum(atype_t *x)
> {
>   return x->a + x->b;
> }
> 
> and
> 
> inline int
> sum(atype_t x)
> {
>   return x.a + x.b;
> }
> 
> Since the function is inline, my guess is that the
> compiler will
> generate identical code for both. So there should be
> no performance
> difference.
> 
> Is this assumption correct?
> 

No!  

Ignore, for the moment, that you are merely advising
the compiler that you want the function inlined. 
Unless things have changed since last I looked, there
is no guarantee that the compiler will inline a
function you have asked to be inlined.

Your bigger problem is that you have ignored the
semantics associated with passing an argument by
reference, pointer and value.

The first version of your function passes a pointer
argument.  Always the same size, and since you don't
say the pointer, or the object to which it is
pointing, is const, any change made to the object
within the function remains after the function
finishes and is visible to the calling code.  In the
second, you pass by value, so the copy constructor
must be called.  And any change made to that object
within the function is lost when the function
completes, and is never visible to the calling code
(unless you return the object, which again will
require invoking the copy constructor).

I would recommend you base your decisions about
whether to pass by reference or by value on what the
function needs to do to, or with, the argument object,
rather than idle speculation about what the compiler
may do IF it inlines your function.  If the compiler
isn't broken, it will not change the semantics of the
function.  Therefore, if you pass an object by value,
it has to be copied so that IF your function makes
changes to it, those changes are not visible to the
calling code and cease to exist once the function
completes.  I would not expect inlining the function
to change that.  And it gets more complicated.  For
example, is there polymorphism involved, and if so,
which version of the virtual function used do you need
in the context of your function?  The bottom line is
that there is no one best way to pass arguments since
what you do depends on what is needed, irrespective of
whether or not the function you're analyzing ought to
be inlined.

HTH

Ted

[Index of Archives]     [Linux C Programming]     [Linux Kernel]     [eCos]     [Fedora Development]     [Fedora Announce]     [Autoconf]     [The DWARVES Debugging Tools]     [Yosemite Campsites]     [Yosemite News]     [Linux GCC]

  Powered by Linux