metaclass: (Default)
metaclass ([personal profile] metaclass) wrote2009-07-12 02:00 pm

Тяжелый ООПшный майндфак

В .NET, во всяком случае в 2.0 и раньше есть одна вещь, которая садит на коня просто нечеловечески. Это то, что куча функций обработки строк является методами экземпляра класса String. А не статическими методами класса. Вроде бы мелочь, подумаешь, какая разница - писать s=s.ToLower(); или s=string.ToLower(s);
А вот хрен. С добавлением того факта, что строка это объект, и она может быть null, и использованием этого null как маркера "функция вернула хрень" в куче мест фреймфорка мы получаем тот геморрой, что перед каждым вызовом s.ToLower() приходится впихивать if(!string.IsNullOrEmpty(s)) или как минимум if(s!=null).

Т.е. вместо такого:
if(String.ToLower(Path.GetExtension(fn))==".wav") {
}

приходится писать такое:
string ext = Path.GetExtension(fn);
if(!string.IsNullOrEmpty(ext))
ext = ext.ToLower();
if(ext==".wav"){
}


Вот этот ООПшный фетишизм "все - объект" и отсутствие глобальных или хотя бы статических функций для простейших вещей просто бесит.
wizzard: (Default)

[personal profile] wizzard 2009-07-12 10:07 pm (UTC)(link)
Extension methods to the rescue. Смотрится вполне пристойно в итоге.

Там можно и на null this проверять, вроде.

Кроме того, никто ж не мешает написать свои строки, если совсем туго станет :)

[identity profile] alexey-rom.livejournal.com 2009-07-19 03:49 pm (UTC)(link)
Но они всё равно будут nullable :( struct-ами ведь их не сделать.
wizzard: (Default)

[personal profile] wizzard 2009-07-19 05:11 pm (UTC)(link)
к сож. я не знаю, как быстро и просто запретить нулл в языке, в котором он встроен как часть семантики.