I want to know which approach is a better in terms of performance and maintainability.
As always, you have the tools to figure it out. Code both possible solutions and make them race. The one that wins is the winner, you don’t need anyone here to answer this particular question.
About maintenance, the solution that autodocuments itself better and has better scalability should be the winner. In this case, the code is so trivial that autodocumentation isn’t that much of an issue. From a scalability point of view, IMHO, the best solution is to use Tuple<T1, T2, ...>
:
- You get free equality semantics which you don’t need to
maintain. -
Collisions are not possible, something that is not true if you choose
the string concatenation solution:var param1 = "Hey_I'm a weird string"; var param2 = "!" var param3 = 1; key = "Hey_I'm a weird string_!_1"; var param1 = "Hey"; var param2 = "I'm a weird string_!" var param3 = 1; key = "Hey_I'm a weird string_!_1";
Yeah, far fetched, but, in theory, entirely possible and your question is precisely about unknown events in the future, so…
-
And last, but not least, the compiler helps you maintain the code. If, for example, tomorrow you have to add
param4
to your key,Tuple<T1, T2, T3, T4>
will strongly type your key. Your string concatenation algorithm on the other hand can live on blissfully happy generating keys withoutparam4
and you wont know whats happening until your client calls you up because their software is not working as expected.