C
C#16mo ago
NotFabi

✅ Tuples or Reference when returning multiple Variables

What Version would you recommend using?
private static void GetXY(ref double x, ref double y, Coordinate coord)
{
x = coord.X;
y = coord.Y;
}

private static (double, double) GetXY(Coordinate coord)
{
return (coord.X, coord.Y);
}
private static void GetXY(ref double x, ref double y, Coordinate coord)
{
x = coord.X;
y = coord.Y;
}

private static (double, double) GetXY(Coordinate coord)
{
return (coord.X, coord.Y);
}
9 Replies
Buddy
Buddy16mo ago
Why exactly do you have a method such as GetXY instead of just exposing the X, Y coordinates directly? I kind of don't see the point of that method, it literally just takes in the parameter and returns a value of that argument, seems like a pretty useless method to me.
NotFabi
NotFabiOP16mo ago
i know that this is a bad example, but let's say you have to perform calculations on both the x and y coordinates. so lets say you now have this:
private static void GetXY(ref double x, ref double y, Coordinate coord)
{
x = coord.X + 1;
y = coord.Y - 2;
}

private static (double, double) GetXY(Coordinate coord)
{
return (coord.X + 1, coord.Y - 2);
}
private static void GetXY(ref double x, ref double y, Coordinate coord)
{
x = coord.X + 1;
y = coord.Y - 2;
}

private static (double, double) GetXY(Coordinate coord)
{
return (coord.X + 1, coord.Y - 2);
}
this is just a pointless example, there are for sure better ones. but should i use tuples or reference when i have a function that returns 2 or more values
Thinker
Thinker16mo ago
This seems like a very bad use-case for ref Return a tuple, or a record struct if you need to return a lot of data.
Bailey
Bailey16mo ago
Hi, there are more possibilities namely returning an obj. Using an out variable etc etc. The consideration is more that do you want the variables to be changed by another method. Clean code descripes this part (if I remember correctly as dirty code). Tupples is a way that you do not have to use an object. I myself prefer object above tupples because you can directly see what kind it is. However many people have different oppinions.
Thinker
Thinker16mo ago
Again records are really good for this
FusedQyou
FusedQyou16mo ago
Neither, return a record
reflectronic
reflectronic16mo ago
i would not use a record for this specific example there isn’t really one answer, it depends a lot on the specific scenario if you are just trying to return a couple of values then i would definitely use a tuple. i would also definitely give names to each element of the tuple public static (double X, double Y) GetXY(…) if you think you may add things to that tuple in the future, or if you start passing around these tuples as e.g. parameters into methods, switch to your own data type i would use an out parameter if you are returning two values that are not “paired” (e.g. returning a bool for success and an out for the actual value). i think out is worse than the tuple here because the values are paired
NotFabi
NotFabiOP16mo ago
Okay, thanks! blobthanks

Did you find this page helpful?