Tips n Tricks
Atom
1/20/2011
Mikhail Sukhov


Постоянно смотрю на изменяющийся код. Весь поток контролировать не могу, поэтому выбираю некоторые места по принципу Медведь на рыбалке в период нереста. Далее, привожу что увидел и как бы изменил. Рекомендую смотреть всем (даже если свой код не увидели), чтобы и самому учиться и не допустить в будущем:

  1. ODE0� Тут лучше использовать ключевое слово var
foreach (var pair in _sections)
  1. ODE2� С помощью Ecng.Common пишется короче
pair.Value.Join(Environment.NewLine)
  1. ODE4� Тут или область видимости должна быть private или название должно быть SectionName.
  2. ODE5� С помощью Ecng.Common пишется короче
"{0}={1}".Put(key, value)
  1. ODE7� Лучше проверить через Contains.
  2. ODE8� Старайтесь минимизироваться перехват исключений. В том случае это решается через простую проверку на существование в коллекции.
  3. ODE9� Я бы заменил на ArgumentException. Он как то более осмысленный.
  4. Не пишите Decimal, Int64, String или Single. Понятно, что это межъязыковое название. Но лучше использовать то, что родное для C#.
  5. ODE10� Стиль именования как в Win32 API. Последний умер де факто много лет назад, наследие его живет и по сей день.[biggrin]
  6. Добавляйте xml комментарии к самим классам, а не только его членам (видел в некоторых местах через // что есть совсем не то). И не забывайте про русский язык. В конце предложения ставится точка.
  7. Пользуйтесь R#. Он показывает допущенные ошибки и предупреждает заранее о неправильном коде.

Tags:


Thanks:


< 1 2 
Mikhail Sukhov

Avatar
Date: 5/8/2011
Reply


Подниму топик парочкой советов:

  1. internal на методы, свойста и поля (но не типа) в C# признак плохого дизайна. Говорит о том, что приосходит размытость границ логики.
  2. ODE0� Плох тем, что не важно, есть необходимый уровень трассировки или нет, строчка будет собираться всегда. Если такая конструкция встречается в коде, который вызывается часто, может снизить производительность.
  3. Любите readonly. Тоесть, когда создаете поля, сразу их делайте readonly. Снять атрибут можно всегда. Но он предотвратит от нежелательной логики перетирания значения.
  4. Два кода абсолютно эквивалентны:
public class RootClass
{
  private class NestedClass
  {
     internal int Prop { get; set; }
  }
}
public class RootClass
{
  private class NestedClass
  {
     public int Prop { get; set; }
  }
}
Thanks:

aspirant

Avatar
Date: 5/8/2011
Reply


Mikhail Sukhov: Подниму топик парочкой советов:

  1. internal на методы, свойста и поля (но не типа) в C# признак плохого дизайна. Говорит о том, что приосходит размытость границ логики.
  1. ODE0� Плох тем, что не важно, есть необходимый уровень трассировки или нет, строчка будет собираться всегда. Если такая конструкция встречается в коде, который вызывается часто, может снизить производительность.

Сделал криво, знаю. Уже думал над тем, чтобы переделать + поменять internal на public. В релиз не будет попадать вообще: выделю в отдельный метод с аттрибутом [Conditional("DEBUG")]

Thanks:

anothar

Avatar
Date: 5/9/2011
Reply


Добрый день. Если верить http://www.codeproject.com/KB/cs/WeakEvents.aspx, кот. ссылается на Ecma cпецификацию, то для обеспечения потокобезопасности делегатов необходимо еще и локирование:


EventHandler eh;
lock (this) { eh = MyEvent; }
if (eh != null) eh(this, EventArgs.Empty);

Thanks:

aspirant

Avatar
Date: 5/27/2011
Reply


@esper, может выставишь у себя tab'ы (Tools \ Options \ Text Editor \ Tab \ Keep tabs)?

Thanks:

esper

Avatar
Date: 5/28/2011
Reply


aspirant: @esper, может выставишь у себя tab'ы (Tools \ Options \ Text Editor \ Tab \ Keep tabs)? Сделал[smile]

Thanks:
< 1 2 

Attach files by dragging & dropping, , or pasting from the clipboard.

loading
clippy