When must we use extern alias keyword in C#?
It's there to help you hoist yourself out of a really deep hole dug by versioning. Say your first version of your program uses this class
using System;
namespace Acme.Financial.Banking {
[Serializable]
public class BankAccount {
public double Balance { get; set; }
//...
}
}
And you've been serializing lots of bank accounts records with it. And an accountant starts complaining about the balance sheet being off by a billionth of a penny, so you change the class:
public decimal Balance { get; set; }
Problem solved, the next customer has happy balance sheets. Until you're asked to upgrade an existing customer with lots of serialized records in the old format. Big problem, you cannot deserialize the records anymore since the class has changed.
extern alias solves your problem, you can reference both the old version and the new version of the class in your code, even though the namespace names and class names are the same.
Basically you only really need it when you want to use two types with the same fully qualified name (same namespace, same type name) from different assemblies. You declare a different alias for each assembly, so you can then reference them via that alias.
Needless to say, you should try to avoid getting into that situation to start with :)