Этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
Политика конфиденциальности
|
|
|
Get*/Set* отдельными методами или одним, какой вариант более православный?
|
|||
|---|---|---|---|
|
#18+
Dimitry SibiryakovИменно поэтому в борланде изобрели property. Да, не захотели макросы. Подумали, что лучше новый язык сделать ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 21.10.2016, 22:14 |
|
||
|
Get*/Set* отдельными методами или одним, какой вариант более православный?
|
|||
|---|---|---|---|
|
#18+
Anatoly MoskovskyДа, не захотели макросы. Подумали, что лучше новый язык сделать Ну так в стандарт тоже продвинутые макросы под названием template включили же. Может, к С++20 доберутся и до property... Posted via ActualForum NNTP Server 1.5 ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 21.10.2016, 22:17 |
|
||
|
Get*/Set* отдельными методами или одним, какой вариант более православный?
|
|||
|---|---|---|---|
|
#18+
Anatoly MoskovskyDimitry SibiryakovИменно поэтому в борланде изобрели property. Да, не захотели макросы. Подумали, что лучше новый язык сделать И где они сейчас? То то же, сила макросов ! ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 21.10.2016, 22:19 |
|
||
|
Get*/Set* отдельными методами или одним, какой вариант более православный?
|
|||
|---|---|---|---|
|
#18+
I dont knowПриветствую, пишу портянку и всплыл вопрос, какой вариант на ваш взгляд православней и почему? Код: plaintext 1. 2. 3. 4. 5. 6. 7. или получение и установку переменной-члена класса объединить в одном методе: Код: plaintext 1. 2. 3. 4. 5. 6. 7. Или так только хипстеры с Ямайки пишут? getter должен быть const . получение и установку естественно мешать нельзя. пишут так ява-пузики, да, потому что надо еще 20 раз подумать, нужно ли скрывать доступ к переменной value вообще. тут понятно, привет учебный, а в реальной жизни надо думать. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 22.10.2016, 00:02 |
|
||
|
Get*/Set* отдельными методами или одним, какой вариант более православный?
|
|||
|---|---|---|---|
|
#18+
я считаю get_ set_ лишней фигней, и всегда пишу так: Код: plaintext 1. 2. 3. 4. 5. 6. если эти методы виртуальные, но не чисто виртуальные, то в производном классе, чтобы перегрузить только один из них, нужно писать using foo::value; метод с дефолтным параметром лучше не использовать по двум причинам. 1. этот метод раскрывает слишком много информации об этом значении. то есть метод int value(int v=-1) исходит из предположения, что есть недействительное значение, которое и можно использовать, чтобы определить зачем вызван этот метод. потом, когда будешь писать код, который это использует, нужно будет помнить, что -1 служебное число.. если это значение действительно никогда не может быть меньше нуля, то нужно выбрать unsigned int. 2. один метод должен исполнять одну и только одну логическую функцию. хорошее название метода описывает все, что он делает. вот, например, хорошие названия методов, в классе report например: generate_data format save.. вот тоже хорошее название метода: generate_data_format_and_save. оно выглядит плохо не потому что название плохое, а потому, что метод выполняет сразу три функции. это я к тому, что в предложенном способе метод исполняет две функции.. его название должно быть вроде set_or_get_value. тогда логическая ошибка становится очевидной. к тому же такой подход нельзя масштабировать на другие значение, к примеру, если нужно установить строку, которая может быть в том числе и пустой. придется для одних свойст использовать один подход, для других другой. некоторые аргументируют, что set_ get_ лучше, потому что сразу понятно, что ты делаешь - устанавливаешь или получаешь значение. но это же относится и к моему способу - сразу же видно передаешь что-нибудь в метод или нет. константность обязательно нужно указывать. лучше привыкнуть сразу писать const, его потом можно убрать если что, но он может уберечь от ошибок. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 22.10.2016, 21:44 |
|
||
|
|

start [/forum/topic.php?fid=57&gotonew=1&tid=2018401]: |
0ms |
get settings: |
8ms |
get forum list: |
12ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
98ms |
get topic data: |
10ms |
get first new msg: |
8ms |
get forum data: |
2ms |
get page messages: |
40ms |
get tp. blocked users: |
1ms |
| others: | 283ms |
| total: | 468ms |

| 0 / 0 |
