Я думаю, что это не совсем правильное поведение. Test = { 1, 2, 3 }
компилируется в код, который вызывает метод Add
из списка, хранящегося в поле Test
.
Причина, по которой вы получаете NullReferenceException
, заключается в том, что Test
равно null
. Если вы инициализируете поле Test
новым списком, код будет работать:
class Test {
public List<int> Field = new List<int>();
}
// Calls 'Add' method three times to add items to 'Field' list
var t = new Test { Field = { 1, 2, 3 } };
Это вполне логично - если вы напишите new List<int> { ... }
, тогда он создаст новый экземпляр списка. Если вы не добавите конструкцию объекта, он будет использовать существующий экземпляр (или null
). Насколько я вижу, спецификация C # не содержит никаких явных правил перевода, которые бы соответствовали этому сценарию, но она дает пример (см. Раздел 7.6.10.3 ):
A List<Contact>
можно создать и инициализировать следующим образом:
var contacts = new List<Contact> {
new Contact {
Name = "Chris Smith",
PhoneNumbers = { "206-555-0101", "425-882-8080" }
},
new Contact {
Name = "Bob Harris",
PhoneNumbers = { "650-555-0199" }
}
};
, который имеет тот же эффект, что и
var contacts = new List<Contact>();
Contact __c1 = new Contact();
__c1.Name = "Chris Smith";
__c1.PhoneNumbers.Add("206-555-0101");
__c1.PhoneNumbers.Add("425-882-8080");
contacts.Add(__c1);
Contact __c2 = new Contact();
__c2.Name = "Bob Harris";
__c2.PhoneNumbers.Add("650-555-0199");
contacts.Add(__c2);
, где __c1
и __c2
- временные переменные, которые в противном случае невидимы и недоступны.