Em relação à pergunta (1): A resposta de Jon está correta, pois ele marca implicitamente a classe 'Nested' como privada, não a tornando pública ou interna :-). Você pode fazê-lo explicitamente adicionando 'private':
private class Nested
Em relação à pergunta (2): basicamente, o que a postagem sobre beforeinitfield e a inicialização de tipo dizem é que, se você não tiver um construtor estático, o tempo de execução poderá inicializá-lo a qualquer momento (mas antes de usá-lo). Se você tiver um construtor estático, seu código no construtor estático poderá inicializar os campos, o que significa que o tempo de execução só pode inicializar o campo quando você solicitar o tipo.
Portanto, se você não deseja que o tempo de execução inicialize os campos 'proativamente' antes de usá-los, adicione um construtor estático.
De qualquer maneira, se você estiver implementando singletons, deseja que ele seja inicializado o mais preguiçosamente possível e não quando o tempo de execução achar que deve inicializar sua variável - ou você provavelmente não se importa. Da sua pergunta, suponho que você os queira o mais tarde possível.
Isso leva ao post de Jon sobre o singleton , que é o tópico subjacente desta pergunta na IMO. Ah e as dúvidas :-)
Eu gostaria de salientar que o singleton # 3, que ele marcou como 'errado', está realmente correto (porque o lock's implica automaticamente uma barreira de memória na saída ). Também deve ser mais rápido que o singleton nº 2 quando você usa a instância mais de uma vez (que é mais ou menos o ponto de um singleton :-)). Portanto, se você realmente precisa de uma implementação preguiçosa de singleton, eu provavelmente optaria por essa - pelas simples razões de que (1) é muito claro para todos que lêem seu código o que está acontecendo e (2) você sabe o que acontecerá com exceções.
Caso você esteja se perguntando: eu nunca usaria o singleton nº 6 porque pode facilmente levar a conflitos e comportamento inesperado, com exceções. Para obter detalhes, consulte: modo de bloqueio do preguiçoso , especificamente ExecutionAndPublication.