Is there any difference in meaning between t<\'a> and \'a t in F#? Can they be used interchangeably even after declaration?
There is no difference, and yes, they can be used interchangeably even after declaration.
But do note the F# Component Design Guidelines recommendation (Section 4.2):
Consider using the prefix syntax for generics (
Foo<T>) in preference to postfix syntax (T Foo), with four notable exceptions (list,option,array,ref).F# inherits both the postfix ML style of naming generic types, e.g. “
int list” as well as the prefix .NET style, e.g. “list<int>”. You should prefer the .NET style, except for four specific types. For F# lists, use the postfix form: “int list” rather than “list<int>”. For options, use the postfix form: “int option” rather than “option<int>”. For arrays, use the syntactic name “int[]” rather than either “int array” or “array<int>”. Forrefs, use “int ref” rather than “ref<int>” or “Ref<int>”. For all other types, use the prefix form: “HashSet<int>”, “Dictionary<string,int>”, since this conforms to .NET standards
Also, you'll get a compiler warning if you use the ML-style generic parameter list notation, e.g. ('a,'b) t vs. t<'a,'b>.
And while we're at it, note the following recommendation in Section 3.1 of the same guide:
Do use PascalCase for generic parameter names in public APIs, including for F#-facing libraries. In particular, use names like T, U, T1, T2 for arbitrary generic parameters, and when specific names make sense, then for F#-facing libraries use names like Key, Value, Arg (but not e.g. TKey).
(though personally I tend to ignore this recommendation for F#-facing public libraries).
I would say the difference is readability. For one parameter the ' syntax isn't overly confusing but when you get a list of them it becomes much easier to read the angle bracket version.
I think that the 'a t syntax is more idiomatic (it is used in almost all the MSDN examples and emitted by the compiler will generate that syntax for signature files)
There is a similar example for arrays
int[] , int array
The 'a t syntax is also nicer for concrete parameters -
int list, List<int>
so some consistency argues for 'a t
No difference at all, is not sure this is worth a whole answer! I prefer the former especially when it comes to multiple type parameters (is that possible with the latter?).