Случаи наподобие этого редки как пишется

Правила и примеры склонения мужских и женских имн, отчеств, фамилий. грамотная речь и письмо отличают людей, получивших хорошее образование, от

Правила и примеры склонения мужских и женских имён, отчеств, фамилий.

Грамотная речь и письмо отличают людей, получивших хорошее образование, от неграмотных представителей человечества.

Знание правил родного языка однозначно поможет вам при обращении к людям по именам, отчествам, фамилиям.

Поговорим подробнее об особенностях их склонения для мужских и женских вариантов.

Правильное склонение фамилии мужского рода: правило, пример

shkolnik ishet v knige primeri pravilnogo skloneniya familii
shkolnik ishet v knige primeri pravilnogo skloneniya familii школьник ищет в книге примеры правильного склонения фамилий

В зависимости от происхождения, наличия/отсутствия гласной на конце слова либо согласной букв фамилии мужского рода имеют ряд правил для склонения.

Глобально разделим их на 2 большие группы:

  • меняющие окончания
  • сохраняющиеся без изменений

К первой группе правил относятся:

  • -ов, -ин для русских и заимствованных вариантов склоняются по классической схеме. Например
    , работа Иванова, картина принадлежит Санину, жду Сидорова, говорить с Фонвизиным о Крысине.
  • Фамилии иностранцев на -ин, -ов в творительном падеже приобретают окончание -ом. Пример
    : роль сыграна Чаплином, герой озвучен Грином.
  • Когда носитель фамилии русский и она происходит от русских омонимов, срабатывает правило с окончанием -ым в творительном падеже.
    Пример
    : от слова крона — идём с Крониным, от диалектного варианта чапля — катание с Чаплиным.
  • Неударные окончания -а, -я склоняются по общим правилам.
    Например
    , тетрадь Глобы, автомобиль Шегды, постановка Окуджавы.
  • Грузинские на -ия меняют окончания, например
    , заслуги Берии.
  • -а ударное на конце фамилий славянского происхождения предполагают изменение окончаний, например
    , с Квашей и Сковородой.
  • Твердая или мягкая согласная на конце фамилии превращаются в сочетания с гласными при склонении.
    Например
    , стихи Блока, интервью с Гафтом, передать Мицкевичу.
  • В форме прилагательного склоняется по общим правилам.
    Например
    , победы Лютого, поход к Толстому.

3d84073c0bf5c2618df17907fd29107d
3d84073c0bf5c2618df17907fd29107d

2bd9038369ac7c54176318d468c16d26
2bd9038369ac7c54176318d468c16d26

ae205de17f7e2da883ebe75565a92792
ae205de17f7e2da883ebe75565a92792

Ко второй группе правил относятся следующие:

  • иностранные на -иа остаются без изменений,
  • -а, -я ударные французского происхождения не склоняются, например, карета Дюма, письма о Золя,
  • -ко на конце не склоняются,
  • с окончаниями на -о, -у, -и, -е, -ю остаются без изменений при склонении,
  • -ых на конце сохраняет фамилию неизменной при склонении.

24614bd10407c9bbbd625ce6ad2b2fe2
24614bd10407c9bbbd625ce6ad2b2fe2

ad137842b40fc87139b6ea64ba662c96
ad137842b40fc87139b6ea64ba662c96

fdd2b1323c92cc4a85cf6b2d16d888ce
fdd2b1323c92cc4a85cf6b2d16d888ce

Правильное склонение мужского имени: правило, пример

mudraya sova iz multfilma razyasnyaet pravilo skloneniya muzhskih imen
mudraya sova iz multfilma razyasnyaet pravilo skloneniya muzhskih imen мудрая сова из мультфильма разъясняет правило склонения мужских имен

Мужские имена также бывают разного происхождения. Однако правила при их склонении одинаковы:

  • при окончании имени на согласную твердую либо мягкую букву или на -й изменения происходят по общему принципу склонения существительных.
    Ударение остается без изменений, но в однослоговых перемещается.
    Примеры
    : Александр — Александра — Александру, Петр — Петра — Петру, Тимофей — Тимофея — Тимофею.
  • -ия, -я, -ья, -ея аналогичны с особенностями склонения существительных с подобным окончанием.
    Пример
    : Илья — Ильи — Илье, Захария — Захарии — Захарию.
  • -а — изменение окончания соответствует правилу склонения обычных существительных с -а на конце.
    Пример
    : Никита — Никиты — Никите.

Поскольку в русском языке много иностранных слов и имён людей других национальностей, вторые в ряде случаев не подпадают под правила склонения и остаются неизменными. Это имена, заканчивающиеся на:

  • гласные -ю, -у, -ы, -и, -э, -е, -о. Пример, Хосе, Айбу
  • две гласные, кроме -ия, -ея. Пример, Франсуа, Качаа

Правильное склонение отчества мужского рода: правило, пример

ребенок школьного возраста просматривает на планшете правила и примеры склонения мужского отчества

Отметим ряд особенностей перед переходом к склонению мужских отчеств:

  • Классические окончания, а именно -евич, -ович.
    Пример, Александр- Александрович, Тимофей — Тимофеевич.
  • Добавление мягкого знака перед окончанием, если имя отца заканчивается на -ий, то есть -ьевич.
    Пример, Валерий — Валерьевич.
  • Если имя отца заканчивается на -а, то в отчестве добавляется -ич. Пример, Лука — Лукич, Никита — Никитич.

Добавим таблицу с изменениями окончаний в мужских отчествах при склонении их по падежам:

tablica skloneniya muzhskih otchestv po padezham
tablica skloneniya muzhskih otchestv po padezham таблица склонения мужских отчеств по падежам

Правильное склонение фамилии женского рода: правило, пример

stopka otkritith knig s primerami pravilnogo skloneniya zhenskih imyon
stopka otkritith knig s primerami pravilnogo skloneniya zhenskih imyon стопка открытых книг с примерами правильного склонения женских фамилий

Женские фамилии имеют ряд отличий от мужских при склонении.

  • С окончанием на -ина, -ова меняются по падежам. Например, у Шукшиной, для Ивановой.
  • В зависимости от особенностей склонения мужских фамилий существует разница и для женских вариантов. Например, Смородина, Жемчужина. В этом случае склонение в женских вариантах — приезд Нади Смородины и Лины Жемчужины. Если мужские варианты Смородин и Жемчужин, то женские соответственно — прибытие Зои Смородиной и Кати Жемчужиной.
  • Неударные -а и -я меняют окончание при склонении. Пример, Валентины Глобы, Катерине Окуджаве.
  • Похожие на прилагательные изменяют окончание по принципу склонения прилагательных. Пример: Лены Великой, Татьяне Светлой.

Отсутствие склонений для фамилий:

  • французского происхождения
  • с окончанием на -ко, -о, -е, -и, -у, -ю, -ых а также на согласную букву

Правильное склонение женского имени: правило, пример

devochka v ochkah viglyadivaet iz za knig v kotorih iskala pravila skloneniya zhenskih imyon
devochka v ochkah viglyadivaet iz za knig v kotorih iskala pravila skloneniya zhenskih imyon девочка в очках выглядывает из-за книг, в которых искала правила склонения женских имён

В целом женские имена изменяют свое окончание при склонении. Есть ряд правил, которые регулируют это:

  • с окончанием на -а, кроме г, к, ц, х. Пример:

tablica skloneniya zhenskih imen s okonchaniem na a
tablica skloneniya zhenskih imen s okonchaniem na a таблица склонения женских имен с окончанием на -а

  • то же окончание после г, к, х и отдельно после ц

tablica skloneniya zhenskih imen s okonchaniem na a posle g k h
tablica skloneniya zhenskih imen s okonchaniem na a posle g k h таблица склонения женских имен с окончанием на -а после г. к, х

90c55fc5ca26c9b60b786c90dd8ce1de
90c55fc5ca26c9b60b786c90dd8ce1de таблица склонения женских имен с окончанием на -а после ц

  • двусложные имена на -я, а также те, что имеют эту букву безударной, меняют свои окончания по падежам так:

tablica skloneniya zhenskih imen zakanchivayushihsya na ya
tablica skloneniya zhenskih imen zakanchivayushihsya na ya таблица склонения женских имен, заканчивающихся на -я

  • с окончанием на -ия, кроме двусложных. Пример ниже:

primer skloneniya zhenskih imen na iya v tablice
primer skloneniya zhenskih imen na iya v tablice пример склонения женских имен на -ия в таблице

  • с окончанием на мягкий знак и шипящие — меняются следующим образом:

tablici skloneniya zhenskih imen imeyushih okonchanie v imenitelnom padezhe na myagkii znak i shipyashuyu bukvu
tablici skloneniya zhenskih imen imeyushih okonchanie v imenitelnom padezhe na myagkii znak i shipyashuyu bukvu таблицы склонения женских имен, имеющих окончание в именительном падеже на мягкий знак и шипящую букву

Исключения составляют ряд женских имён иностранного происхождения. Они зачастую не склоняются.

Примерами выступают те же имена, что были представлены в таблице выше, которые имеют шипящую букву на конце.

Правильное склонение отчества женского рода: правило, пример

ustavshii shkolnik za partoi nakrilsya otkritim uchebnikom s pravilami skloneniya otchestva zhenskogo roda
ustavshii shkolnik za partoi nakrilsya otkritim uchebnikom s pravilami skloneniya otchestva zhenskogo roda уставший школьник за партой накрылся открытым учебником с правилами склонения отчества женского рода

Существуют ряд правил склонения женских отчеств в зависимости от их образования от мужских имён. А именно:

  • имена с окончанием на неударное -а образуют отчества с -ична. Если последний слог мужского имени с ударением, то -инична. Пример: Никита — Нитична, Илья — Ильинична.
  • Если в основе имена второго склонения с нулевым и окончанием на -ий, то в отчестве добавляются -овна, -евна. Пример: Евгений — Евгениевна, Владимир — Владимировна.

Вставляем для наглядности таблицу склонения женских отчеств:

tablica izmeneniya okonchanii v zhenskih otchestvah pri sklonenii ih po padezham
tablica izmeneniya okonchanii v zhenskih otchestvah pri sklonenii ih po padezham таблица изменения окончаний в женских отчествах при склонении их по падежам

Итак, мы рассмотрели ряд правил для склонения фамилий, имён и отчеств для мужчин и женщин. А также изучили их на примерах.

Практикуйте правила, склоняя имена, отчества и фамилии своих родных. Тогда и все правила запомнятся вам быстрее.

Удачных занятий!

Видео: как склонять фамилии по падежам?

Из вопросов, поступивших в «Справочное бюро» «Грамоты.ру»:

  • Здравствуйте, у меня фамилия Осса, ударение на О, мне в дипломе написали Оссе, и теперь я должна делать экспертизу, которая стоит бешеных денег, чтобы доказать, что фамилия не склоняется.
  • Моя фамилия Погребняк. Это украинская фамилия, а они вроде как не склоняются. Некоторые люди склоняют мою фамилию, пишут Погребняка, Погребняку, Погребняком. Разве это возможно?
  • Моя фамилия Ерошевич, она польского происхождения (это точно известно). Меня интересует такой вопрос: склоняется ли моя фамилия. Моему родственнику (мужского пола) выдали аттестат, в котором фамилия была просклонена. И с этим аттестатом его никуда не брали. Говорили, что фамилия не склоняется. Учителя тоже говорят, что не склоняется, а на вашем сайте написано, что склоняется. Я в замешательстве!

Подобные вопросы не редкость в «Справочном бюро» нашего портала. Чаще всего их задают в мае–июне и в самом начале сентября. Связано это, конечно же, с тем, что в конце учебного года выпускники школ и вузов получают аттестаты и дипломы, а в сентябре дети идут в школу и начинают подписывать тетради. В аттестате и дипломе обязательно будет написано, кому он выдан (т. е. фамилия в дательном падеже), а на обложке тетради – чья она (т. е. фамилия в родительном падеже). И в тех случаях, когда фамилия учащегося оканчивается не на -ов (-ев)
, -ин (-ын)
или —ский (-цкий)
(т. е. не относится к так называемым стандартным), почти всегда возникает вопрос: надо ли склонять фамилию и если да, то как именно склонять? Именно с ним носители языка обращаются за помощью к лингвистам. А вслед за этим вопросом нередко следует и другой: «Как доказать, что фамилия склоняется?» или «Как отстоять право на несклонение фамилии?». Вопрос «Склонять или не склонять фамилию?» нередко выходит за рамки языкового, вызывая ожесточенные споры и приводя к серьезным конфликтам.

Разумеется, подобные вопросы поступают не только от учащихся, их родителей и преподавателей, их задают в течение всего года, но пики обращений к лингвистам – именно в мае–июне и сентябре, в связи с обострением данной проблемы в школах и вузах. Это не случайно: ведь именно в учебном заведении у многих носителей языка происходит первая встреча со специалистом – учителем русского языка, и требование педагога изменять по падежам фамилию, которая в семье всегда считалась неизменяемой, удивляет, раздражает и вызывает отпор. Подобные же трудности испытывают офисные работники (секретари, делопроизводители), которые сталкиваются с категорическими требованиями руководства не склонять склоняемые фамилии.

Опыт работы нашего «Справочного бюро» показывает, что законы склонения фамилий действительно неизвестны большому числу носителей языка (и даже некоторым филологам), хотя они приводятся во многих справочных пособиях по русскому языку, в том числе широкодоступных. В числе этих пособий – «Справочник по правописанию и литературной правке» Д. Э. Розенталя, стилистический словарь вариантов Л. К. Граудиной, В. А. Ицковича, Л. П. Катлинской «Грамматическая правильность русской речи» (3-е издание – под заголовком «Словарь грамматических вариантов русского языка»), «Словарь русских личных имен» А. В. Суперанской, исследование Л. П. Калакуцкой «Фамилии. Имена. Отчества. Написание и их склонение» и многие другие источники. Исследование запросов интернет-пользователей и мониторинг блогосферы позволяют сделать вывод: среди носителей языка распространено немало заблуждений относительно правил склонения фамилий. Вот главные из них: решающим фактором является языковое происхождение фамилии («не склоняются фамилии грузинские, армянские, польские и т. д.»); во всех случаях склонение фамилии зависит от пола носителя; фамилии, совпадающие с нарицательными существительными (Гроза, Жук, Палка
), не склоняются. Немалое число носителей языка убеждены, что правил склонения фамилий так много, что запомнить их не представляется возможным.

Чтобы показать, что все эти представления не соответствуют действительности, приведем основные правила склонения фамилий. Они взяты из перечисленных выше источников и сформулированы нами в виде пошаговой инструкции, своего рода алгоритма, с помощью которого можно быстро найти ответ на вопрос: «Склоняется ли фамилия?».

Вот этот алгоритм.

1.
Как сказано выше, склонение фамилий, оканчивающихся на -ов (-ев,), -ин (-ын), -ский (-цкий),
т. е. так называемых стандартных фамилий, не вызывает трудностей у носителей языка. Нужно только помнить два важных правила.

А. Заимствованные фамилии на -ов, -ин
, которые принадлежат иностранцам
, в форме творительного падежа имеют окончание -ом
(как существительные второго школьного склонения, например стол, столом
): теория предложена Дарвином, фильм снят Чаплином, книга написана Кронином.
(Интересно, что так же склоняется псевдоним Грин
, принадлежащий русскому писателю: книга написана
Грином.
)
Омонимичные русские фамилии имеют окончание —ым
в форме творительного падежа: с Чаплиным
(от диалектного слова чапля
«цапля»), с Крониным
(от крона
).

Б. Женские фамилии на —ина
типа Смородина, Жемчужина
склоняются двояко, в зависимости от склонения мужской фамилии (Ирины Жемчужины
и Ирины Жемчужиной
, Зои Смородины
и Зои Смородиной
). Если мужская фамилия – Жемчужин
, то правильно: приезд
Ирины Жемчужиной
. Если же мужская фамилия – Жемчужина
, то правильно: приезд
Ирины Жемчужины
(фамилия склоняется как нарицательное существительное жемчужина
).

2.
Теперь переходим непосредственно к так называемым нестандартным фамилиям. Первое, что нужно помнить: вопреки распространенному заблуждению, пол носителя фамилии далеко не всегда влияет на склоняемость/несклоняемость. Еще реже на это влияет происхождение фамилии. В первую очередь имеет значение, на какой звук оканчивается фамилия – согласный или гласный
.

3.
Сразу опишем несколько групп несклоняемых фамилий. В современном русском литературном языке не склоняются
русские фамилии, оканчивающиеся на -ых, -их

(типа Черных, Долгих
), а также все фамилии, оканчивающиеся на гласные е, и, о, у, ы, э, ю

.

Примеры: тетради Ирины Черных, Лидии Мейе, Романа Грымау; диплом выдан Виктору Долгих, Андрею Гретри, Николаю Штаненко, Майе Ли; встреча с Николаем Кручёных и Александром Минадзе.

Примечание. В разговорной речи и в языке художественной литературы, отражающем устную речь, считается допустимым склонение мужских фамилий на —ых, -их
(в сценарии Черныха, встреча с Рыжихом)
, а также склонение фамилий украинского происхождения на -ко, -енко
по склонению существительных женского рода на -а: пойти к Семашке, в гостях у Устименки.
Отметим, что украинские фамилии такого типа последовательно склонялись в художественной литературе XIX века (у Шевченки; исповедь Наливайки; стихотворение, посвященное Родзянке
).

4.
Если фамилия оканчивается на согласный
(кроме фамилий на -ых, -их
, о которых говорилось выше), то здесь – и только здесь!– имеет значение пол носителя фамилии. Все мужские фамилии, оканчивающиеся на согласный, склоняются – это закон русской грамматики
. Все женские фамилии, оканчивающиеся на согласный, не склоняются. При этом языковое происхождение фамилии не имеет значения. Склоняются в том числе и мужские фамилии, совпадающие с нарицательными существительными.
Примеры: тетрадь Михаила Бока, дипломы выданы Александру Кругу и Константину Королю, встреча с Игорем Шипелевичем, в гостях у Андрея Мартынюка, дочь Ильи Скалозуба, работа Исаака Акопяна; тетрадь Анны Бок, дипломы выданы Наталье Круг и Лидии Король, встреча с Юлией Шипелевич, в гостях у Екатерины Мартынюк, дочь Светланы Скалозуб, работа Марины Акопян.

Примечание 1. Мужские фамилии восточнославянского происхождения, имеющие беглую гласную при склонении, могут склоняться двояким образом – с потерей и без потери гласного: Михаила Заяца
и Михаила Зайца, с Александром Журавелем
и Александром Журавлём, Игорю Грицевецу
и Игорю Грицевцу.
В ряде источников предпочтительным признается склонение без выпадения гласного (т. е. Заяца, Журавелем, Грицевецу
), т. к. фамилии выполняют в том числе юридическую функцию. Но окончательный выбор – за носителем фамилии. При этом важно придерживаться выбранного типа склонения во всех документах.

Примечание 2. Отдельно необходимо сказать о фамилиях, оканчивающихся на согласный й.
Если ему предшествует гласный и
(реже – о
), фамилия может склоняться двояко. Такие фамилии, как Топчий, Побожий, Бокий, Рудой
,
можно воспринять как имеющие окончания -ий, -ой
и склонять как прилагательные (Топчего, Топчему
, в женском роде Топчая, Топчей
), а можно – как имеющие нулевое окончание со склонением по образцу существительных (Топчия, Топчию
, в женском роде неизменяемая форма Топчий
). Если согласному й
на конце фамилии предшествует любой другой гласный, фамилия подчиняется общим правилам (Игорю Шахраю, Николаю Аджубею,
но Инне Шахрай, Александре Аджубей
).

5.
Если фамилия оканчивается на гласный -я, которому предшествует другой гласный

(напр: Шенгелая, Ломая, Рея, Берия, Данелия
), она склоняется
.
Примеры: тетрадь Инны Шенгелаи, диплом выдан Николаю Ломае, встреча с Анной Реей; преступления Лаврентия Берии, встреча с Георгием Данелией.

6.
Если фамилия оканчивается на гласный -а, которому предшествует другой гласный

(напр.: Галуа, Моруа, Делакруа, Моравиа, Эриа, Эредиа, Гулиа
), она не склоняется.
Примеры: тетрадь Николая Галуа, диплом выдан Ирине Эриа, встреча с Игорем Гулиа.

7.
И последняя группа фамилий – оканчивающиеся на -а, -я, которым предшествует согласный

. Здесь – и только здесь! – имеет значение происхождение фамилии и место ударения в ней. При этом нужно запомнить всего два исключения:

А. Не склоняются
французские фамилии с ударением на последний слог: книги Александра Дюма, Эмиля Золя и Анны Гавальда, афоризмы Жака Деррида, голы Диарра и Дрогба.

Б. Преимущественно не склоняются
финские фамилии, оканчивающиеся на —а
неударное: встреча с Мауно Пеккала
(хотя в ряде источников рекомендуется склонять и их).

Все остальные фамилии (славянские, восточные и другие; оканчивающиеся на ударный и безударный -а, -я
) склоняются
. Вопреки распространенному заблуждению, склоняются в том числе и фамилии, совпадающие с нарицательными существительными.
Примеры: тетрадь Ирины Грозы, диплом выдан Николаю Мухе, лекция Елены Кара-Мурзы, песни Булата Окуджавы, роли Игоря Кваши, фильмы Акиры Куросавы.

Примечание. В склонении японских фамилий раньше наблюдались колебания, но справочные пособия отмечают, что в последнее время такие фамилии последовательно склоняются, а в «Грамматическом словаре русского языка» А. А. Зализняка несклоняемый вариант у Акутагава,
наряду с несклоняемым у Окуджава
,
назван «грубым нарушением нормы».

Вот, собственно, и все главные правила; как видно, их не так уж много. Теперь мы можем опровергнуть перечисленные выше заблуждения, связанные со склонением фамилий. Итак, вопреки расхожему мнению: а) не существует правила «не склоняются все армянские, грузинские, польские и т. д. фамилии» – склонение фамилий подчиняется законам грамматики языка, и, если конечный элемент фамилии поддается русскому словоизменению, она склоняется; б) правило «мужские фамилии склоняются, женские нет» относится не ко всем фамилиям, а только к тем, которые оканчиваются на согласный; в) совпадение фамилии по форме с нарицательными существительными не является препятствием для их склонения.

Важно помнить: фамилия – это слово
и, как и все слова, оно должно подчиняться грамматическим законам языка. В этом смысле нет разницы между предложениями Аттестат выдан Голод Ивану
(вместо правильного Голоду Ивану
) и Жители деревни страдали от голод
(вместо страдали от голода
), в обоих предложениях – грамматическая ошибка.

Следовать правилам склонения фамилий важно еще и потому, что отказ от изменения по падежам склоняемой фамилии может привести к недоразумениям и казусам, дезориентировать адресата речи. В самом деле, представим себе ситуацию: человек с фамилией Гроза
подписал свою работу: статья Николая Гроза.
По законам русской грамматики мужская фамилия, оканчивающаяся в родительном падеже ед. числа на —а
, восстанавливается в исходной форме, в именительном падеже, с нулевым окончанием, поэтому читатель сделает однозначный вывод: автора зовут Николай Гроз.
Сданная в деканат работа А. Погребняк
приведет к поискам студентки (Анны? Антонины? Алисы?) Погребняк, а принадлежность к ней студента Александра Погребняка еще надо будет доказать. Соблюдать правила склонения фамилий нужно по той же причине, по которой необходимо соблюдать правила правописания, в противном случае возникает ситуация, аналогичная знаменитой «оптеке», описанной Л. Успенским в «Слове о словах». Авторы «Словаря грамматических вариантов русского языка» Л. К. Граудина, В. А. Ицкович, Л. П. Катлинская указывают: «Для словоизменения фамилий непреложным должен быть закон об абсолютной выводимости им. падежа фамилии из ее косвенных падежей».

Поэтому предлагаем вам запомнить азбучную истину № 8.

Азбучная истина № 8
. Склонение фамилий подчиняется законам грамматики русского языка. Не существует правила «не склоняются все армянские, грузинские, польские и т. д. фамилии». Склонение фамилии зависит в первую очередь от того, на какой звук оканчивается фамилия – согласный или гласный. Правило «мужские фамилии склоняются, женские нет» относится не ко всем фамилиям, а только к тем, которые оканчиваются на согласный
. Совпадение фамилии по форме с нарицательными существительными (Муха, Заяц, Палка
и т. д.) не является препятствием для их склонения.

Литература:

  1. Агеенко Ф. Л. Словарь собственных имен русского языка. М., 2010.
  2. Граудина Л. К., Ицкович В. А., Катлинская Л. П. Словарь грамматических вариантов русского языка. –3-е изд., стер. М., 2008.
  3. Зализняк А. А. Грамматический словарь русского языка. – 5-е изд., испр. М., 2008.
  4. Калакуцкая Л. П. Фамилии. Имена. Отчества. Написание и склонение. М., 1994.
  5. Розенталь Д. Э. Справочник по правописанию и литературной правке. – 8-е изд., испр. и доп. М., 2003.
  6. Суперанская А. В. Словарь русских личных имен. М., 2004.

В. М. Пахомов,
кандидат филологических наук,
главный редактор портала «Грамота.ру»

Имена и названия

Как склонять фамилии (трудные случаи)

Источник:
Н. А. Еськова. Трудности словоизменения существительных. Учебно-методические материалы к практическим занятиям по курсу «Язык современной печати». Госкомитет печати СССР. Всесоюзный институт повышения квалификации работников печати. М., 1990.

13.0. Данному вопросу посвящена книга Л. П. Калакуцкой «Склонение фамилий и личных имен в русском литературном языке». М., 1984. Это фундаментальное исследование, основанное на богатом материале. В настоящем разделе кратко рассматриваются лишь основные вопросы, причем внимание акцентируется на самых сложных и спорных. Фамилии и имена рассмотрены отдельно.

13.1. Склонение фамилий

13.1.1. Подавляющее большинство русских фамилий имеет формальные показатели — суффиксы -ов- (-ев-), -ин-, -ск-: Лермонтов, Тургенев, Пушкин, Достоевский, Крамской.
Все такие фамилии склоняются. При этом они образуют две соотносительные системы форм — мужского и женского рода, называющие соответственно лиц мужского и женского пола. С обеими системами соотносится единая система форм множественного числа.

Примечание.
Все это — за исключением отсутствия форм среднего рода — напоминает систему форм прилагательного. Абсолютная регулярность в соотношении
мужских и женских фамилий, не имеющая аналогий среди нарицательных существительных, наводит на мысль, не следует ли считать фамилии особым типом «родоизменяемых» существительных.

13.1.2. Фамилии с формальным показателем -ск-
склоняются в мужском и женском роде и во множественном числе как прилагательные: Достоевский, Достоевского, Достоевскому…, Достоевская, Достоевской…, Достоевские, Достоевских
и т. д.

Русские фамилии, склоняющиеся как прилагательные и не имеющие показателя -ск-,
относительно немногочисленны; к ним относятся: Благой, Толстой, Боровой, Береговой, Лановой, Броневой,Дикий, Гладкий, Поперечный
и т. п. (см. перечень таких фамилий в книге: А. В. Суперанская, А. В. Суслова. Современные русские фамилии. М., 1981. С. 120-122).

13.1.3. Фамилии с показателями -ов-
и -ин-
имеют в мужском роде особое склонение, не встречающееся ни среди личных имен, ни среди нарицательных существительных. В нем объединены окончания существительных второго склонения мужского рода и прилагательных типа отцов.
От склонения указанных существительных склонение фамилий отличается окончанием творительного падежа (ср.: Кольцов-ым, Никитин-ым — остров-ом, кувшин-ом),
от склонения притяжательных прилагательных — окончанием предложного падежа (ср.: о Грибоедов-е, о Карамзин-е — об отцов-ом, о мамин-ом).

Соотносительные женские фамилии склоняются как притяжательные прилагательные в форме женского рода (ср. как склоняются Ростова
и отцова, Каренина
и мамина).

То же надо сказать о склонении фамилий на -ов
и -ин
во множественном числе (Базаровы, Рудины
склоняются как отцовы, мамины).

13.1.4. Все прочие мужские фамилии, имеющие основы на согласные и нулевое окончание в именительном падеже (на письме они кончаются согласной буквой, ь
или й),
кроме фамилий на -ых, -их,
склоняются как существительные второго склонения мужского рода, т. е. имеют в творительном падеже окончание -ом, (-ем): Герценом, Левитаном, Гоголем, Врубелем, Хемингуэем, Гайдаем.
Такие фамилии воспринимаются как «нерусские».

Соотносительные женские фамилии не склоняются: Наталии Александровны Герцен, Любови Дмитриевне Блок, с Анной Магдалиной Бах, с Надеждой Ивановной Забелой-Врубель, о Мэри Хемингуэй, о Зое Гайдай.

Примечание.
Применение этого правила требует знания пола носителя фамилии. Отсутствие таких сведений ставит пишущего в затруднительное положение.

Форма, в которой стоит фамилия, информирует о поле соответствующего лица. Но если автор текста не имел нужных сведений, был нетверд в применении грамматического правила или просто небрежен, читающий получает ложную информацию. Приведем один пример. В еженедельнике «Говорит и показывает Москва» в программах радио на 9.3.84 фигурировала такая передача: «Поет Э. Матис. В программе песни В. Моцарта, К. Шумана,
И. Брамса, Р. Штрауса». Кто такой К. Шуман? Можно предположить, что неверно указан инициал: К. Вместо Р. Но, оказывается, в передаче исполнялись песни Клары Шуман
(жены Роберта Шумана, которая была не только пианисткой, но и композитором). Так грамматическая ошибка дезориентирует читателя.

Во множественном числе фамилии рассматриваемого типа тоже склоняются как существительные мужского рода: побывал у Герценов, у Врубелей, у Гайдаев, написал Блокам, Хемингуэям
и т. п.

Примечание.
Есть, однако, особые правила постановки таких фамилий в одних случаях в склоняемой форме множественного числа, в других — в несклоняемой форме. Правила эти, более относящиеся к синтаксису, чем к морфологии, довольно подробно разработаны у Д. Э. Розенталя (см.: Справочник по правописанию и литературной правке. М., 1989. С. 191-192, §149, п. 10). В соответствии с этими правилами рекомендуется: с Томасом и Генрихом Маннами,
но с Робертом и Кларой Шуман, у отца и сына Ойстрахов,
но у отца и дочери Гилельс.
Здесь этот материал не рассматривается.

13.1.5. Заложенное в предыдущем пункте несложное правило склонения фамилий на согласные, не имеющих формальных показателей -ин-, -ов-,
оказывается трудноприменимым для некоторых «диковинных» фамилий, например, для тех, которые омонимичны нарицательным существительным или географическим названиям, склоняющимся по третьему склонению. Так, в грамматическом приложении к «Справочнику личных имен народов РСФСР» отмечаются затруднения, возникающие при необходимости просклонять такие фамилии, как Грусть, Любовь, Астрахань.

В этом же пособии констатируется, что для некоторых фамилий с трудностями связано только образование множественного числа (фамилии Ус, Гей, Палец, Полоз, Сон
и др.).

Склонение ряда фамилий (как в единственном, так и во множественном числе) оказывается затруднительным из-за неясности, должна ли в них сохраняться беглость гласных по образцу омонимичных им или похожих по внешнему виду нарицательных существительных (Кравеца
или Кравца —
от Кравец, Журавеля
или Журавля —
от Журавель, Мазурока
или Мазурка —
от Мазурок
и т. п.).

Разрешение таких затруднений не может быть обеспечено правилами, для этого необходим словарь фамилий, дающий нормативные рекомендации для каждого слова.

13.1.6. Особый тип представляют собой русские фамилии на -ых (-их),
выдающие свое происхождение от формы родительного (и предложного) падежа множественного числа прилагательных: Белых, Черных, Крученых, Кудреватых, Долгих, Рыжих.
По строгим нормам литературного языка такие фамилии не склоняются: лекции Черных, роман Седых, творчество Крученых
и т. п.

Примечание.
В непринужденной разговорной речи существует тенденция склонять такие фамилии, когда они принадлежат мужчинам, действующая тем сильнее, чем ближе общение с носителем фамилии. Так, в ныне не существующем Московском городском педагогическом институте им. Потемкина студенты сороковых-пятидесятых годов слушали лекции Черныха,
сдавали экзамены и зачеты Черныху
и т.п. (сказать иначе никому не приходило в голову). Если бы эта разговорная тенденция победила, фамилии на -ых, -их
перестали бы отличаться от прочих фамилий на согласные, о которых говорилось в п. 13.1.4.

13.1.7. Есть случаи, когда исходная форма фамилии может быть воспринята неоднозначно с точки зрения ее морфологического устройства. Случаи эти немногочисленны, но интересны и лингвистически, и с точки зрения практических трудностей, которые могут быть с ними связаны.

Существует проблема разграничения «русских» и «нерусских» фамилий на -ов
и -ин
; к последним относятся, например, Флотов
(немецкий композитор), Гуцков
(немецкий писатель), Кронин
(английский писатель), Дарвин, Франклин
и т. п. С морфологической точки зрения «русскость» или «нерусскость» выражается в том, выделяется или не выделяется в фамилии формальный показатель (-ов-
или -ин-
).
Если такой показатель выделяется, то творительный падеж имеет окончание -ым,
а соотносительная женская фамилия склоняется (Фонвизиным, Фонвизиной),
если же не выделяется — творительный падеж образуется с окончанием -ом,
а женская фамилия не склоняется (Вирховом, с Анной Вирхов).
Ср. «омонимы»: Чарльзом Спенсером Чаплином, у Ханны Чаплин
и Николаем Павловичем Чаплиным, с Верой Чаплиной.

Примечание.
Как показывает материал Л. П. Калакуцкой, в некоторых случаях соотносительные мужские и женские фамилии оформляются морфологически противоречиво (например, творительный падеж Цейтлиным
может сочетаться с несклоняемой формой Цейтлин
женской фамилии). Полное упорядочение здесь может быть достигнуто только при наличии специального словаря фамилий, содержащего грамматические указания. Однако редактор должен следить, чтобы морфологически противоречащие друг другу формы не встретились хотя бы в пределах одного текста.

Есть нерусские (преимущественно немецкие) фамилии на -их: Аргерих, Дитрих, Фрейндлих, Эрлих
и т. п. Независимо от свойственного им налета «иноязычности» их нельзя принять за русские фамилии на -их
потому, что в русских фамилиях перед элементом -их
практически не встречаются мягкие согласные, имеющие твердые пары, поскольку в русском мало прилагательных с такими основами (т.е. таких прилагательных, как синий;
и есть ли фамилия Синих
и подобные ей?).

Но если конечному -их
фамилии предшествует шипящая или задненебная согласная, ее принадлежность к несклоняемому типу будет несомненна только при соотнесенности с основой прилагательного (например, Ходячих., Гладких)
; при отсутствии же этого условия такие фамилии могут восприниматься морфологически неоднозначно; к ним относятся, например, Хасхачих, Товчих, Грицких.
При всей редкости таких случаев, следует иметь в виду эту принципиальную возможность.

В очень редких случаях могут быть восприняты неоднозначно фамилии, исходные формы которых кончаются йотом (на письме й)
с предшествующими гласными и
или о
. Например, такие фамилии, как Топчий, Побожий, Бокий, Рудой
можно воспринять и как имеющие окончания -ий, -ой
и, следовательно склоняющиеся как прилагательные (Топчего, Топчему…,
в женском роде Топчая, Топчей)
и как имеющие нулевое окончание со склонением по образцу существительных (Топчия, Топчию…,
в женском роде неизменяемая форма Топчий).
Для разрешения подобных недоумений опять — таки необходим словарь фамилий.

13.1.8. Склонение фамилий, оканчивающихся в исходной форме на гласные, не зависит от того, мужские они или женские.

Примечание.
Материал Л. П. Калакуцкой показывает, что существует тенденция распространять соотношение, закономерное для фамилий на согласные, на фамилии с конечным а
, т.е. склонять мужские фамилии, не склоняя женские. Редакторам следует всячески способствовать изживанию этой практики.

Рассмотрим фамилии на гласные, исходя из их буквенного облика.

13.1.9. Фамилии, пишущиеся с е, э, и, ы, у, ю
на конце, могут быть только несклоняемыми. Таковы фамилии: Доде, Мюссе, Лансере, Фурье, Мейе, Шабрие, Гёте, Нобиле, Караджале, Тарле, Орджоникидзе, Артмане, Мегрэ, Боссюэ, Гретри, Люлли, Дебюсси, Навои, Модильяни, Грамши, Голсуорси, Шелли, Руставели, Чабукиани, Ганди, Джусойты, Неедлы, Лану, Амаду, Шоу, Манцу, Неру, Энеску, Камю, Корню
и т. п.

13.1.10. Фамилии с конечным о
тоже несклоняемы; таковы фамилии Гюго, Клемансо, Ларошфуко, Мийо, Пикассо, Марло, Шамиссо, Карузо, Леонкавалло, Лонгфелло, Ремесло, Доливо, Дурново, Хитрово, Бураго, Мертваго.

По строгим нормам литературного языка это распространяется и на фамилии украинского происхождения с конечным -ко
(среди которых много на -енко): Короленко, Макаренко, Франко, Квитко, Шепитько, Бондарсо, Семашко, Горбатко, Громыко.

Примечание.
Известно, что в литературном языке прошлого века такие фамилии могли склоняться по первому склонению: Короленки, Короленке, Короленкой. Теперь это не считается нормативным.

13.1.11. Наиболее сложную картину представляют собой фамилии с конечным а.
В отличие от предыдущих случаев, здесь существенное значение имеет, следует ли а
после гласной или после согласной, падает ли на эту гласную ударение и (в определенных случаях) какого происхождения фамилия.

Все фамилии, кончающиеся на а,
которому предшествуют гласные (чаще всего у
или и),
несклоняемы: Галуа, Моруа, Делакруа, Моравиа, Эриа, Эредиа, Гулиа.

Все фамилии, кончающиеся на неударное а
после согласных, склоняются по первому склонению: Рибера — Риберы, Рибере, Риберу, Риберой, Сенека — Сенеки
и т.д.; так же склоняются Кафка, Спиноза, Сметана, Петрарка, Куросава, Глинка, Дейнека, Гулыга, Олеша, Нагнибеда, Окуджава
и др. Все такие фамилии, независимо от происхождения, являются морфологически членимыми в русском языке, т. е. в них выделяется окончание -а.

Среди фамилий с ударным á
после согласных есть как морфологически членимые, так и нечленимые, т. е. несклоняемые.

Несклоняемы фамилии французского происхождения: Дюма, Тома, Дега, Люка, Ферма, Гамарра, Петипа
и др.

Фамилии иного происхождения (славянские, из восточных языков) склоняются по первому склонению, т. е. в них вычленяется ударное окончание -а: Митта — Митты, Митте, Митту, Миттой;
сюда относятся: Сковорода, Кочерга, Кваша, Цадаса, Хамза
и др.

13.1.12. Склоняемость-несклоняемость фамилий, пишущихся с буквой я
на конце, зависит только от места ударения и происхождения фамилии.

Несклоняемы фамилии французского происхождения с ударением на конце: Золя, Труайя.

Все прочие фамилии на я
склоняемы; таковы Головня, Зозуля, Сырокомля, Гамалея, Гойя, Шенгелая, Данелия, Берия.

Примечание.
Фамилии, у которых конечной букве я
предшествует гласная буква, в отличие от таких фамилий на а, членятся на основу, кончающуюся согласной йот, и окончание -а (Гамалея — Гамале»j-а).

Грузинские фамилии оказываются склоняемыми или несклоняемыми в зависимости от того, в каком виде конкретная фамилия заимствована русским языком: фамилии на -ия
склоняемы (Данелия),
на -иа —
несклоняемы (Гулиа).

13.1.13. Представляет интерес вопрос об образовании множественного числа от склоняемых фамилий на -а (-я).
В грамматическом приложении к «Справочнику личных имен народов РСФСР» такие фамилии квалифицированы как нестандартные и для них рекомендуется в качестве нормы употребление во множественном числе для всех падежей формы, совладающей с исходной. В качестве образцов взяты фамилии Зима
и Зоя.
Рекомендуется: Ивана Петровича Зимы, с Семеном Семеновичем Зоей, Анне Ивановне Зиме, Елену Сергеевну Зою
и т. п., а для множественного числа — формы Зима, Зоя
во всех падежах.

Представить себе склонение во множественном числе фамилий Зима, Зоя
действительно трудно. Но как обстоит дело с другими фамилиями, склоняющимися по первому склонению, например, такими, как Глинка, Дейнека, Гулыга, Окуджава, Олеша, Зозуля, Гамалея?
Есть ли уверенность, что для них следует рекомендовать употребление во всех падежах множественного числа формы, совпадающей с исходной? Как следует сказать: своим любимым Глинка
или своим любимым Глинкам?; встретился с Дейнека
или встретился с Дейнеками?; вспомнил обо всех Окуджава
или вспомнил обо всех Окуджавах?
Употребление склоняемых форм в этих случаях не исключается.

Труднее представить себе склонение во множественном числе фамилий с ударным окончанием -á — Шульга, Митта, Хамза,
в особенности — в родительном падеже (у всех *Шульг, *Митт, *Хамз?).
Здесь мы сталкиваемся с языковой трудностью (см. выше, 7.6.). Поскольку подобные факты редки, лингвистами не изучены, редактору в таких случаях целесообразно минимально вмешиваться в авторский текст.

13.2. Склонение личных имен

13.2.1. Личные имена не имеют существенных морфологических отличий от нарицательных существительных. Они не «родоизменяемы» (ясно, что случаи типа Александр
и Александра, Евгений
и Евгения, Валерий
и Валерия
к этому явлению не относятся). Среди личных имен нет и слов с особым склонением (ср. сказанное выше о фамилиях на -ов
и -ин).
Единственная особенность личных имен — отсутствие среди них слов среднего рода, но надо отметить, что и среди нарицательных существительных одушевленных средний род представлен очень мало.

13.2.2. Среди личных имен есть существительное третьего склонения. Это тоже черта, сближающая их морфологически с нарицательными существительными и отличающая от фамилий. По третьему склонению устойчиво склоняются: Любовь
(с формами Любови,
о Любови), Адель, Жизель
и имена библейского происхождения Агарь, Рахиль, Руфь, Суламифь, Эсфирь, Юдифь.
Прочие имена такого типа — Люсиль, Сесиль, Айгюль, Газель
(заимствования из разных языков), Нинель
(новообразование советской эпохи), Ассоль
(придуманное имя) -колеблются между третьим склонением и несклоняемостью (у Сесили
и у Сесиль, с Нинелью
и с Нинель).

Примечание.
Женские фамилии на мягкие согласные (на письме на ь), как
ясно из сказанного выше (см. 13.1.4), так же несклоняемы, как и женские фамилии на твердые согласные. Принципиально существующая возможность параллельного изменения существительных на мягкие согласные по двум разным склонениям для грамматического выражения различий по полу остается в русском языке не реализованной. Ср. теоретически возможные соотношения: Врубеля, Врубелю, Врубелем
(склонение мужской фамилии) — *Врубели, *Врубелью
(склонение женской фамилии), *рыся, *рысю, *рысем
(склонение названия самца) -рыси, рысью
(склонение названия самки). Впрочем, в знаменитой фольклорной Лебеди
эта возможность отчасти реализуется!

13.2.3. Женские имена на твердые согласные, могут быть только несклоняемыми, (не отличаясь от фамилий такого рода). К ним относятся: Элизабет, Ирен, Катрин, Гретхен, Лив, Сольвейг, Марлен, Жаклин
и т.п. Нарицательные существительные такого типа есть, но они немногочисленны и практически непополняемы (мадам, мисс, миссис, мистрис, фрейлейн, фрекен),
личных же имен много и пополнение их (путем заимствования) ничем не ограничено.

13.2.4. Мужские имена на твердые и мягкие согласные (на письме на согласные буквы, и
и ь),
склоняются как нарицательные существительные такого же внешнего вида. К ним относятся Иван, Константин, Макар, Артур, Роберт, Эрнст, Клод, Ричард, Андрей, Василий, Юлий, Амадей, Игорь, Эмиль, Шарль
и т. п. В редких случаях «омонимии» мужских и женских имен они соотносятся (с точки зрения склонения) как мужская и женская фамилии: Мишель, Мишеля
(мужское имя), Мишель,
несклоняемое (женское имя; есть французская скрипачка Мишель Оклер).

13.2.5. Все, сказанное о склоняемости-несклоняемости фамилий на гласные, относится и к личным именам.

Не склоняются имена: Рене, Роже, Оноре, Хосе, Дитте, Озе, Панталоне, Анри, Луи, Лизи, Бетси, Джованни, Мери, Этери, Гиви, Пьеро, Лео, Амадео, Ромео, Карло, Ласло, Бруно, Гуго, Данко, Франсуа, Нана, Атала, Коломба
и т. п.

Склоняются имена: Франсуаза, Джульетта, Сюзанна, Абдулла, Мирза, Муса, Каста, Эмилия, Офелия, Джамиля
и т. п.

13.2.6. Множественное число от склоняемых личных имен образуется свободно, если в этом: возникает необходимость: Иваны, Игори, Эмили,
Елены, Эмилии
и т. п. Морфологические ограничения здесь возникают в тех же случаях, что и для нарицательных существительных (например, для родительного множественного от Абдулла, Мирза, Коста;
ср. 7.6). О вариантном образовании родительного множественного от имен типа Петя, Валя, Сережа
см. 7.4.4, примечание.

13.3 Особенности образования косвенных, падежей от некоторых сочетаний имен и фамилий

В русском языке сложилась традиция употреблять фамилии ряда иностранных деятелей (преимущественно писателей) в сочетании с именами: Вальтер Скотт, Жюль Верн, Майн Рид, Конан Дойль, Брет Гарт, Оскар Уальд, Ромен Роллан;
ср. также литературные персонажи: Робин Гуд, Шерлок Холмс, Нат Пинкертон.
Употребление этих фамилий отдельно, без имен мало распространено (в особенности это касается односложных фамилий; вряд ли кто-нибудь читал в детстве Верна, Рида, Дойля
и Скотта!).

Следствием такого тесного единства имени и фамилии оказывается склонение в косвенных падежах только фамилии: Вальтер Скотта, Жюль Верну, с Майн Ридом, о Робин Гуде
и т.п. Это явление, характерное для непринужденной устной речи, находит отражение и на письме, что можно подтвердить следующими примерами из достаточно авторитетных авторов.

Себя казать, как чудный зверь,
В Петрополь едет он теперь /…/
С ужасной книжкою Гизота,
С тетрадью злых карикатур,
С романом новым Вальтер-Скотта…
(Пушкин. Граф Нулин)

И встает
живьем
страна Фенимора
Купера
и Майн-Рида.

(Маяковский. Мексика)

По вечерам быстроглазая Серна
Ване и Ляле читает Жюль Верна.

(Чуковский. Крокодил)

(Написания через дефис подчеркивают тесное единство имени и фамилии).

Несклонение имени в таких сочетаниях осуждается современными нормативными пособиями. Так, у Д. Э. Розенталя сказано: «… романы Жюля Верна
(не: «Жюль Верна»)…» (Указ. соч. С. 189. §149, п. 2).

Ветер свистнул у Вовы над ухом
И сомбреро сорвал с головы!
Волны-горы бегут друг за другом,
Скачут, словно гривастые львы.
Вот с шипеньем одна накатила —
И Жюля Верна
с кормы подхватила!

(Волгина Т. По тропинкам бродит лето. Киев. 1968. С. 38-39).

Такая правка в стихах, конечно, совершенно недопустима. Но и в прозаическом тексте, передающем непринужденную разговорную речь, нет необходимости заменять Жюль Верна, Майн Рида, Брет Гарта, Конан Дойля
и т. п. строго нормативными сочетаниями со склоняемыми формами имен. Редактору следует в подобных случаях проявлять гибкость.

Мужские фамилии, имеющие окончание на ударные и безударные
звуки — о, — е, — э, — ц, — у, — ю, а так же на окончание
звука – а, со стоящей впереди гласной — не склоняются,
например: произведение Даниэла Дефо, обзор литературы С.С.
Курного, улица имени Гастелло.
Не склоняются русские мужские фамилии, имеющие окончание на
слоги — их, — ых, например: под руководством Седых,
упражнялся с Ковчих, сказано П. П. Новослободских. В русском
языке и художественной литературе допустимо склонение
мужских фамилий имеющих окончание на слоги – их, — ых,
например: в произведении Репныха, лекции Зелемныха.
Большинство, можно даже сказать подавляющее большинство
русских мужских фамилий имеющих суффиксы — ев — (- ов -),
— ск -, — ин -: Золотов, Куленев, Мушкин, Залесский,
Приморский, Костолевский, Крамской, Волонской. Абсолютно все
подобные мужские фамилии склоняются.
Русских мужских фамилий, склоняющихся по принципу имен
прилагательных, и не имеющих показателя существует очень
мало; к ним относятся такие фамилии как: Столбовой, Толстой,
Береговой, Лановой, Теневой, Сладкий, Заречный, Поперечный,
Коломный, Белый, Грозный, и т. д…

Склонение мужских фамилий (по принципу имен прилагательных)
И. п.: Андрей Белый, Сергей Сладкий, Иван Лановой, Алексей
Заречный.
Р. п.: Андрея Белого, Сергея Сладкого, Ивана Ланового,
Алексея Заречного.
Д. п.: Андрею Белому, Сергею Сладкому, Ивану Лановому,
Алексею Заречному.
В. п.: Андрея Белого, Сергея Сладкого, Ивана Ланового,
Алексея Заречного.
Т. п.: с Андреем Белым, с Сергеем Сладким, с Иваном Лановым,
с Алексеем Заречным.
П. п.: об Андрее Белом, о Сергее Сладком, об Иване Лановом,
об Алексее Заречном.

Мужские фамилии с окончаниями — ин — и — ов — имеют
особенное склонение, не встречающееся среди нарицательных
существительных и среди личных имен. Здесь мы видим
объединение окончания имен прилагательных и имен
существительных второго склонения мужского рода и
подразделения типа отцов, праотцов. От склонения подобных
имен существительных склонение мужских фамилий отличается
главным образом окончанием творительного падежа, например:
Сизов-ым, Акунин-ым — Боров-ом, Стон-ом, Калугин – ым,
Суворов – ым от склонения по принципу притяжательных
прилагательных имеет отличие окончание предложного падежа,
например: о Сазонов-е, о Кулибин-е — об праотцов-ом, о
мамин-ом. То же самое относится к склонению мужских фамилий
оканчивающихся на — ов и — ин во множественном числе (Сизовы,
Акунины склоняются как праотцовы, мамины). Для склонения
подобных мужских фамилий, целесообразно обратиться к
справочнику склонения имен и фамилий.
Не склоняются русские мужские фамилии, с окончаниями на
слоги: — ово, — аго, — яго, имеющие происхождение по образу
застывших форм родительного падежа в единственном числе: (Бурново,
Слухово, Живаго, Шарбинаго, Деряго, Хитрово), и с
окончаниями на слоги: — их, — ых — множественного числа
(Крученых, Костровских, Дольских, Довгих, Черных), где
некоторые из них склоняется в просторечии (Дурново —
Дурновому).
Обязательно нужно склонять по родам и падежам мужские
фамилии, имеющие окончание на мягкий знак и согласный звук.
(институт имени С. Я. Жука, поэзия Адама Мицкевича,
проводить Игоря Коваля).
Если в окончании фамилии перед звуком — а присутствует
согласная, то окончаниями фамилий по форме падежей будут:
звуки — а, — ы, — е, — у, — ой, — е.
Если в окончании мужской фамилии перед звуком — а стоит одна
из букв (г, к, х) или же мягкая шипящая (ч, щ) или ж, то
окончанием фамилии в форме родительного падежа будет звук —
и.
Если в окончании мужской фамилии перед звуком — а стоит одна
из шипящих (ч, щ, ц, ш) или ж, то окончанием фамилии по
форме творительного падежа при ударении на окончание слова
будет — ой, и — ей.
Фамилия как название семьи предполагает наличие формы
множественного числа: Ивановы, Пашкины, Веденские. Если
люди, вступающие в брак, берут общую фамилию, она пишется во
множественном числе: Васильевы, Вронские, Усатые, Горбатые,
Любимые. Нестандартные мужские фамилии, кроме фамилий
образованных в форме имен прилагательных, в написании в
официальных документах форм множественного числа не имеют.
Поэтому пишут: Мария Петровна и Николай Семенович Вишня,
супруги Парус, муж и жена Сызрань, брат и сестра Астрахань.
Несмотря на трудности, возникающих при склонении русских и
иноязычных мужских фамилий, существующих в русском языке,
все же желательно правильно склонять имя отчество и фамилию
человека, если они поддаются склонению. Действующая в
правилах русского языка система правил падежных окончаний в
русском языке, достаточно жестко предлагает принимать
оставшееся без склонения склоняемое слово как стоящее не в
том падеже или относящееся не к тому роду, к которому оно в
данном случае действительности относится. Например, Иван
Петрович Зима, в родительном падеже должно быть Ивана
Петровича Зимы. Если будет написано: для Ивана Петровича
Зима, это значит, что в именительном падеже эта фамилия
будет выглядеть как Зим, а не Зима. Оставленные без
склонения мужские фамилии типа Ветер, Немешай будут приняты
за женские, потому что подобные фамилии у мужчин склоняются:
с Василием Сергеевичем Немешаем, от Виктора Павловича Ветра.
Для склонения подобных мужских фамилий, целесообразно
обратиться к справочнику склонения имен и фамилий.
Ниже приводятся некоторые образцы склонений мужских фамилий
существующих в русском языке:

Склонение мужских фамилий (стандартных)
Единственное число
И. Смирнов, Крамской, Костиков, Елисеев, Иванов,
Р. Смирнова, Крамского, Костикова, Елисеева, Иванова,
Д. Смирнову, Крамскому, Костикову, Елисееву, Иванову,
В. Смирнова, Крамского, Костикова, Елисеева, Иванова,
Т. Смирновым, Крамским, Костиковым, Елисеевым, Ивановым,
П. о Смирнове, о Крамском, о Костикове, о Елисееве, об
Иванове.
Множественное число
И. Смирновы, Крамские, Костиковы, Елисеевы, Ивановы,
Р. Смирновых, Крамских, Костиковых, Елисеевых, Ивановых,
Д. Смирновым, Крамским, Костиковым, Елисеевым, Ивановым,
В. Смирновых, Крамских, Костиковых, Елисеевых, Ивановых,
Т. Смирновыми, Крамскими, Костиковыми, Елисеевыми,
Ивановыми,
П. о Смирновых, о Крамских, о Костиковых, о Елисеевых, об
Ивановых.

В русских мужских фамилиях из двух слов всегда склоняется ее
первая часть, если она употребляется как фамилия (поэзия
Лебедева-Кумача, работа Немировича-Данченко, экспозиция
Соколова-Скаля)
За исключением тех фамилий, где первая часть не означает
фамилию, такие мужские фамилии ни когда не склоняются,
например: рассказы Мамина-Сибиряка, живопись Соколова,
скульптура Демут-Малиновского, исследования Грем-Бржимайло,
в роли Поздник-Трухановского
Не стандартные мужские фамилии с окончанием на звуки — а
(-я), такие как Зима, Лоза, Зоя, Дора рекомендуется
употреблять во множественном числе исключительно для всех
падежей формы, совпадающей с исходным видом фамилии.
Например: Ивана Петровича Зимы, Василию Ивановичу Лозе, с
Семеном Семеновичем Зоей, а для множественного числа — формы
Зима, Лоза, Зоя во всех падежах. Для склонения подобных
мужских фамилий, целесообразно обратиться к справочнику
склонения имен и фамилий.
Просклонять во множественном числе мужские фамилии Зима, Зоя
трудно.
Есть проблема разделения на «русские» и «нерусские» фамилии
с окончанием на слоги — ов и — ин; К таким мужским фамилиям
относятся, например: Гуцков (немецкий писатель), Флотов
(немецкий композитор), Кронин (английский писатель),
Франклин, Гудвин, Дарвин и т. п. С точки зрения морфологии «нерусскость»
или «русскость» мужской фамилии определяется в том,
выражается или не выражается в фамилии окончание на (-ов —
или — ин -). Если такой показатель выражается, то фамилия в
творительном падеже будет иметь окончание — ым
Нерусские мужские фамилии, относящиеся при их упоминании к
двум или нескольким лицам, в некоторых случаях ставятся во
множественном числе, в других – в единственном, а именно:

если фамилия состоит из двух мужских имен, то такая фамилия
ставится в форме множественного числа, например: Джильберт и
Жан Пикары, Томас и Генрих Манны, Михаил и Адольф Готлибы;
отец и сын Ойрстархи;
Есть так же нерусские (в основном немецкие) фамилии с
окончанием на — их: Фрейндлих, Аргерих, Эрлих, Дитрих и т.
п. Такие фамилии невозможно назвать русскими фамилиями с
окончанием на — их потому, что в русских фамилиях перед
окончанием — их практически не встречаются мягкие согласные,
имеющие твердые пары, так как в русском языке очень мало
имен прилагательных с такими основами (т.е. подобных имен
прилагательных, как красный, седой; и есть ли фамилии
Красных, Седых и подобные).
Но, если перед окончанием – их в мужской фамилии стоит
шипящая или задненебная согласная, такие мужские фамилии,
как правило, не склоняются, только при соотношении имени
прилагательного (например, Кодячих., Сладких); при
отсутствии, же этого условия подобные фамилии обычно
воспринимаются неоднозначно с точки зрения морфологии; к
таким фамилиям относятся, например: Вальщих, Хаскачих,
Трубацких, Ловчих, Стоцких. При всей редкости таких случаев,
следует не забывать эту принципиальную возможность.
В незначительно редких случаях неоднозначно воспринимаются
фамилии, исходные формы которых заканчиваются на букву — й
перед гласными и или — о. Допустим, такие фамилии, как
Лопчий, Набожий, Допчий, Боркий, Зоркий, Дудой можно понять
и как имеющие окончания на слоги — ий, — ой. Такие мужские
фамилии склоняются по правилам имен прилагательных: Лопчего,
Лопчему, Набожий, Набожьему, Допчий, Допчему, Боркий,
Боркому, Зоркий, Зоркому, и как имеющие нулевое окончание со
склонением по образцу имен существительных (Лопчия, Лопчию…,)
Для прояснения подобных недоумений необходимо обращаться к
словарю фамилий.
Мужские фамилии, окачивающиеся на звуки — е, — э, — и, — ы,
— у, — ю, не склоняются. Например, такие: Доде, Дюссе,
Мансере, Фурье, Лейе, Дабрие, Гёте, Нобиле, Мараджале,
Тарле, Орджоникидзе, Мэгрэ, Артмане, Боссюэ, Гретри,
Девюсси, Навои, Ставильяни, Модильяни, Гуарэ, Грамши,
Сальери, Голсуорси, Шелли, Неедлы, Руставели, Каманду,
Чабуркиани, Ганди, Джусойты, Ланду, Амаду, Шоу, Манцу,
Курандэ, Неру, Колню, Эндеску, Камю, Колню и т. п.
Иноязычные мужские фамилии, имеющие окончание на гласный
звук, исключая безударные — а, — я (Гюго, Доде, Бизе,
Россини, Муссалини, Шоу, Неру, Гете, Бруно, Дюма, Золя),
имеющие окончания на звуки — а, — я, с впереди стоящим
гласным — и (стихи Гарсия, сонеты Эредия, рассказы Гулиа) не
склоняются. Исключение может быть в просторечии. Несклоняемы
мужские фамилии французского происхождения, оканчивающиеся
на ударную — я: Золя, Бруайя.
Все остальные мужские фамилии имеющие окончание на — я
склоняемы; например Головня, Заборня, Берия, Зозуля,
Данелия, Сырокомля, Шенгелая, Гамалея, Гойя.
Когда склоняются иностранные мужские фамилии и используются
формы правил русских склонений, основные особенности
склонения таких слов в языке самого подлинника не
сохраняются. (Карел Чапек — Карела Чапека [ни в коем случае
Карла Чапека]). Также и в польских именах (у Владека, у
Эдека, у Янека [не: у Владка, у Эдка, у Янка]).
Наиболее сложную картину в склонении представляют собой
мужские фамилии имеющие окончание на звук — а. В отличие от
ранее рассмотренных случаев, здесь большое значение имеет,
окончание — а стоит после гласной или после согласной, и
если это гласная, то падает ли на эту гласную ударение и (в
определенных случаях) какое происхождение имеет данная
мужская фамилия.
Все мужские фамилии, с окончанием на звук — а, стоящие после
гласных (чаще всего у или и), не склоняются: Балуа, Доруа,
Делакруа, Боравиа, Эдриа, Эсредиа, Булиа.
Не склоняются мужские фамилии, имеющие французское
происхождение с окончанием ударного звука — я: Золя, Труайя,
Белакруйя, Добля, Голля и т.д.
Все мужские фамилии, с окончанием на неударное — а после
согласных, склоняются по правилу первого склонения,
например: Дидера — Дидеры, Дидере, Дидеру, Дидерой, Сенека —
Сенеки, Сенеке, Сенеку, Сенекой, и т.п.; по такому же
принципу склоняются Кафка, Петрарка, Спиноза, Сметана,
Куросава, Гулыга, Глинка, Дейнека, Олеша, Загнибеда,
Окуджава и др.
Склонение мужских фамилий (в единственном, и во
множественном числе) из-за того что не ясно, должна ли в них
сохраняться беглая гласная по образцу похожих по внешнему
виду нарицательных имен существительных, склонение бывает
затруднительным (Травеца или Травца — от Травец, Муравеля
или Муравля — от Муравель, Лазурока или Лазурка — от Лазурок
и т. п.).
Что бы избежать затруднений, лучше воспользоваться
справочником. Если мужская фамилия сопровождается женским и
мужским именами, то она остается в форме единственного
числа, например: Франклин и Элеонора Рузвельт, Жан и Эсланда
Родсон, Август и Каролина Шнегель, сподвижники Рихарда
Зорге, Дик и Анна Краузен, Ариадна и Стив Тур; также Сергей
и Валя Брузжак, Станислав и Нина Жук;
В единственном числе пишется и говорится также мужская
фамилия, если она сопровождается двумя нарицательными
существительными, разного пола, например: господин и госпожа
Рэйнер, лорд и леди Гамильтон; но если при таких сочетаниях
как муж и жена или брат и сестра фамилия чаще всего
употребляется в форме множественного числа: муж и жена
Будстремы, брат и сестра Виринги;
При слове супруги фамилия представляется в форме
единственного числа, например: супруги Дент, супруги
Торндайк, супруги Лоддак;
При слове братья, мужская фамилия тоже обычно представляется
в форме единственного числа, например: братья Гримм, братья
Требель, братья Гелленберг, братья Вокрасс; При слове семья,
фамилия обычно представляется в форме единственного числа,
например: семья Доппфенгейм, семья Грамалей.
В сочетаниях русских фамилий с именами числительными в
склонении используются такие формы: два Иванова, оба
Иванова, двое Ивановых, оба брата Ивановы, два друга
Ивановы; двое (оба) Перовских. Под это правило подводятся
также сочетания имен числительных с иноязычными фамилиями;
оба Шлегеля, два брата Манны.
Склонение мужские фамилий восточнославянского происхождения,
имеющие беглую гласную при склонении, такие мужские фамилии
могут образоваться двумя способами – с потерей и без потери
гласной при склонении: Заяц – Заяца – Заяцем и Зайца –
Зайцем. Необходимо учитывать, что при заполнении юридических
документов такие мужские фамилии нужно склонять без потери
гласного.
Мужские фамилии западнославянского и западноевропейского
происхождения, при склонении, имеющие беглую гласную,
склоняются без потери гласной: улица Слашека, романы Чапека,
в исполнении Готта, лекции Завранека. Мужские фамилии,
являющиеся по форме именами прилагательными (с ударной или
безударной на окончании) склоняются так же, как, и имена
прилагательные. Склоняются славянские мужские фамилии,
оканчивающиеся на ударные звуки — а, — я (у режиссера
Майбороды, с психологом Сковородой, к сценаристу Головне).

Мужские фамилии славянского происхождения на — о типа Севко,
Дарко, Павло, Петро склоняются по правилам склонения имен
существительных мужского и среднего рода, например: впереди
Севка, у Дарка. Склоняются, как правило, мужские фамилии с
окончанием на неударные звуки — а, — я (очерк В. М. Птицы,
искусство Яна Неруды, романсы в исполнении Роситы Кинтаны,
сеанс с А.Вайдой, песни Окуджавы). Незначительные колебания
наблюдаются в склонении грузинских и японских мужских
фамилий, где встречаются эпизоды, как склоняемости, так и
несклоняемости фамилий:
Награждение народного артиста СССР Харавы; 120 лет со дня
рождения Сен-Секатаямы, киноленты Куросавы; труды А. С.
Чикобава (и Чикобавы); творчество Пшавела; в резиденции
Икэда; отчет Хатояма; ленты Витторио де Сика (не де Сики).
Славянские мужские фамилии с окончанием на — и, — ы
рекомендуется склонять по образцу русских мужских фамилий с
окончанием на — ий, — ый (Добровски — Добровского, Покорны —
Покорного). При этом допускается оформление подобных мужских
фамилий по образцу русских и по правилу именительного падежа
(Добровский, Покорный, Дер-Стравинский). Мужские фамилии, у
которых ударное окончание – а склоняются по правилам первого
склонения, то есть в них исчезает ударное окончание — а:
Питта — Питты, Питте, Питту, Питтой; сюда относятся так же:
Сковорода, Пара, Кочерга, Кваша, Цадаса, Мырза, Хамза и
другие.
Чешские и польские мужские фамилии на – цкий, – ский, и –
ый, – ий, следует склонять с полными окончаниями в
именительном падеже, например: Огинский – Огинскому,
Пандовского – Пандовскому.
Украинские мужские фамилии с окончанием на — ко (-енко), как
правило, склоняются по различному типу склонения только в
художественной литературе или в разговорной речи, но не в
юридических документах, например: команда голове Евтуху
Макогоненку; покоился убитый Кукубенком шляхтич,
стихотворенье, посвящённое Родзянке; Не склоняются мужские
фамилии, с окончанием, как на ударное, так и безударное
окончание — ко (Боровко, Дятько, Гранко, Загорудько,
Кириенко, Янко, юбилей Левченко, деятельность Макаренко,
произведения Короленко), где некоторые из них склоняется в
разговорной речи, (Боровко Боровки́, письмо В. Г.
Короленко – письмо В. Г. Короленке). Или: «Под вечер
Беликов… направился к Коваленкам». Не склоняются мужские
фамилии на — ко с ударением на последнюю – о, например:
театр имени Франкó, наследие Божкó.
В сложных составных из нескольких слов фамилиях китайских,
корейских, вьетнамских склоняется последняя часть фамилии,
оканчивающаяся на согласный звук, например: речь Ди Вэна,
заявление Пам Зан Гонга, беседа с Е Ду Сингом.
Грузинские мужские фамилии могут быть склоняемыми или
несклоняемыми в зависимости от того, в каком виде конкретная
фамилия заимствована русским языком: фамилии с окончанием на
— ия склоняемы (Данелия, Горнелия), с окончанием на — иа —
несклоняемы (Гулиа).
Следует особо обратить внимание на то, что в обычном
общении, если носитель редкой или трудно склоняемой фамилии
допускает неправильное произношение своей фамилии, это не
считается грубым нарушением общих правил склонения. Но в
заполнении юридических документов, публикациях СМИ и
художественных произведениях, при неуверенности в правильном
склонении рекомендуется обращаться к справочнику фамилий,
иначе можно попасть в неприятное положение, несущее за собой
ряд неудобств, потерю времени для доказательства
подлинности, принадлежности именно того человека о котором
писалось в данном документе.

Добрый день, уважаемый студент! Сегодня я хотела бы затронуть очень важную тему, моим студентам она очень пригодилась, т.к. фамилии и имена в русском языке чаще всего употребляются в речи, особенно у тех,кто работает или учится. Итак, в русском языке фамилии обычно имеют следующие суффиксы:

Ов (Круглов
)
-ев (Тургенев
)
-ин (Путин
)
-ск (Ржевск
ий)

Просклоняем для примера фамилию с суффиксом -ов

И.п. кто? Смирнов

Р.п. кого? Смирнова

Д.п. кому? Смирнову

В.п. кого? Смирнова

Т.п. кем? Смирновым

П.п. о ком? О Смирнове

Если говорить про имена и отчества, нужно отметить,что тут тоже есть свои нюансы:

Например, имена мужские, которые относятся ко 2 склонению — Александр, Владимир, Евгений, образуют отчества при помощи суффикса — ович, а для женского отчества — овна.

Александрович
/Александровна

Если добавить к имени суффиксы — евич/евна, то мы получим следующие отчества:

Евгеньевич
/Евгеньевна

Но, пожалуйста, обратите внимание,что мужские отчества, которые образованы от имён, оканчивающихся на -ий (Валерий, Евгений), меняют окончание на -ь, например:

Валерьевич, Евгеньевич

Мужские имена, которые относятся к 1 склонению (например, Никита) образуют отчества путём прибавления суффикса -ич для мужского отчества:

Никитич

А у женских отчеств добавляется -ична:

Никитична

Обратите внимание
, что если ударение в мужском имени падает на последний слог (Илья, Лука, Фома), то женские отчества образуются путем добавления суффикса -инична: Ильинична
— от мужского имени Илья΄ (ударение падает на последний слог). Если же вы хотите правильно просклонять отчества по падежам, то здесь происходит добавление или замена определенных окончаний, например, давайте просклоняем отчества Ильич (мужского рода) и Львовна (женского рода):

И.п. кто? Ильич (мужского рода) Львовна (женского рода)
Р.п. кого? Ильича
Львовны

Д.п. кому? Ильичу
Львовне

В.п. кого? Ильича
Львовны

Т.п. кем? Ильичом
Львовной

П.п. о ком? Об Ильиче
о Львовне

Мужские имена, которые оканчиваются на любой согласный (мы знаем,что согласные бывают твердые и мягкие) и на букву -й-, то склоняются они таким же образом, как обычные существительные мужского рода, например:

Иван (кто), Ивана(кого), Ивану (кому) и так далее.

Очень важно помнить, что ударение сохраняется на том же месте (гласном), что и в именительном падеже. Но и здесь имеются исключения
: два русских имени Лев и Пётр, в них ударения падают на окончания других падежей, например,

Петра
(кого? Родительный падеж), Петру
(кому? Дательный падеж), Петром
(кем? Творительный падеж)

А в имени Лев при склонении по падежам выпадает гласная и меняется на -ь:

Ль
ва-Ль
ву-Ль
вом

Иногда возникают вопросы, когда перед нами оказывается имя, которое состоит из 2-х частей и пишется через дефис, как быть с ними и как склонять? Ничего сложного в этом нет, просто необходимо запомнить, что склоняется только последняя часть такого имени, первая остается без изменений, например:

Сент-Луис
Р.п. кого? Сент -Луиса
Д.п. кому? Сент- Луису
В.п. кого? Сент- Луиса
Т.п. кем? Сент-Луисом
П.п. о ком? О Сент-Луисе

Имена, не зависимо от рода — мужского и женского, которые оканчиваются на букву -а, склоняются как остальные существительные в русском языке: Вера-Веры-Вере и т.д.

Мужские и женские имена, оканчивающиеся на -я,-ья,-ия,-ея будут склоняться как существительные с соответствующими окончаниями: Мария-Марии-Марией.

Часть 1. Вступление

Часть 6. Специфика Google
Часть 7. Ещё возможности C++
Часть 8. Именование


Это последняя переведённая часть руководства Google по стилю в C++.
Спасибо за замечания и комментарии к переводу.
Надеюсь это руководство будет полезным подспорьем для программистов на C++.
Исходная статья (fork на github), обновляемый перевод.
И ещё здесь много букв.

Ещё возможности C++

Rvalue-ссылки

Используйте rvalue-ссылки:

  • Для объявления конструкторов перемещения и операторов перемещения.
  • Для объявления перегружаемых функций с const& и && аргументами если это обеспечит значительное улучшение производительности против передачи по значению или если пишется код с небольшими накладными расходами или поддержкой произвольных типов. Избегайте увеличения количества перегружаемых функций (обычно бывает, когда комбинируются типы для несколько параметров).
  • Для поддержки ‘perfect forwarding’ в ‘универсальном’ коде.

Определение
Rvalue-ссылка является ссылочным типом, привязанным к временному объекту. По синтаксису похожа на обычную ссылку. Например, void f(std::string&& s); объявляет функцию с аргументом rvalue-ссылка на std::string.

Когда суффикс ‘&&’ (без дополнительных квалификаторов) используется с шаблонным аргументом функции, то применяются специальные правила определения типа аргумента. И такая ссылка имеет название forwarding reference.

За

  • Определение конструктора перемещения (принимающего rvalue-ссылку на тип класса) даёт возможность переместить (move) класс вместо его копирования. Например, если v1 это std::vector<std::string>, то код auto v2(std::move(v1)) скорее всего выполнит несколько операций с указателями вместо копирования большого объёма данных. И в большинстве случаев это приведёт к существенному увеличению производительности кода.
  • Rvalue-ссылки позволяют реализовать типы, которые можно перемещать, а не копировать. Это полезно для типов, которые нельзя копировать, но которые хочется передавать в функцию как аргумент, хранить в контейнере и т.д.
  • Функция std::move необходима для эффективного использования некоторых типов стандартной библиотеки, таких как std::unique_ptr.
  • Forwarding references, использующие объявление rvalue-ссылки, позволяют написать единую обёртку, перемещающую аргумент в другую функцию. И это одинаково работает вне зависимости от того, временный объект или нет, константный он или не очень. Это и называется ‘perfect forwarding’.

Против

  • Rvalue-ссылки не все хорошо понимают. Особенности, наподобие схлопывания ссылок или специальных правил определения типа, всё сильно усложняют.
  • Rvalue-ссылки часто используют неправильно, т.к. они интуитивно нелогичны: обычно ожидается, что аргумент будет иметь валидное состояние после вызова функции (и операции перемещения выполняться не будут).

Вердикт
Вы можете использовать rvalue-ссылки чтобы объявить конструктор перемещения и перемещающий оператор присваивания (как описано в Копируемые и перемещаемые типы). См. также C++ Primer для более подробной информации о семантике перемещения и, также, std::move.

Вы можете использовать rvalue-ссылки чтобы объявить пары перегружаемых функций, одна с Foo&&, другая с const Foo&. Обычно программисты предпочитают передавать аргументы по значению. Однако использование пары функций может дать лучшую производительность, или позволит в обобщённом коде поддержать большое количество типов. И не забывайте: если ради производительности пишется более сложный код, проверьте и убедитесь, что это действительно помогает.

Вы можете использовать ‘forwarding references’ вместе с std::forward
, чтобы реализовать ‘perfect forwarding’.

Дружественные сущности

В ряде случаев допустимо использовать классы и функции как friend.

Дружественные типы обычно определяются в том же файле, поэтому нет необходимости открывать другой файл, чтобы разобраться с использованием закрытых членов класса. Обычное использование friend: когда класс FooBuilder объявляется дружественным (friend) классу Foo, так что FooBuilder может корректно настроить внутреннее состояние Foo без необходимости открывать это состояние всем остальным. В ряде случаев удобно сделать класс unit-тестов дружественным исходному классу.

Дружественность расширяет (но не ломает) инкапсуляцию класса. В ряде случаев, когда требуется дать доступ к внутреннему состоянию только одному классу, лучше объявить его как friend, чем делать дополнительные открытые члены класса. Однако, в остальном классы должны взаимодействовать только через открытые функции.

Исключения (программные)

Мы НЕ используем исключения C++.
За

  • Исключения позволяют обрабатывать ситуации типа «это невозможно» не в месте возникновения ошибки, а на более верхнем уровне, позже. И всё это без копания в исходниках и составления таблиц с кодами ошибок.
  • Исключения используются в большинстве современных языков программирования и их использование в C++ позволяет писать код, концептуально схожий с Python, Java и др.
  • Некоторые библиотеки C++ используют исключения в своей работе и отказ от них может существенно усложнить интеграцию с этими библиотеками.
  • Исключения являются единственным способом проинформировать о проблемах в конструкторе класса. Конечно, это можно обойти, используя фабричные методы или метод Init(), однако это потребует либо дополнительного выделения памяти или, соответственно, обработку специального «невалидного» состояния.
  • Исключения очень удобны при использовании в тестировании (в тестовых фреймворках).

Против

  • Если используется throw в функции, то вы должны проверить всех, кто эту функцию вызывает. Должна быть базовая гарантия безопасности при исключениях. Или же код никогда не ловит исключения и тогда программа может внезапно завершиться. Например есть код, где f() вызывает g(), который вызывает h(). Если h выбрасывает исключение, которое отлавливает f, то g нужно писать аккуратно, иначе могут быть утечки ресурсов и т.д.
  • Обычно использование исключений усложняет отслеживание последовательности выполнения кода. Например, функции могут завершаться в неожиданных местах. Это затрудняет поддержку кода и его отладку. Вы можете улучшить ситуацию, следуя (своим) правилам когда и где можно использовать исключения. Однако, очень желательно, чтобы и другие разработчики знали об этих правилах.
  • Безопасное использование исключений требует использования дополнительных принципов кодирования, например, RAII. И их количество (принципов кодирования) может быть значительным. Например, чтобы разработчик не разбирался в тонкостях всей цепочки вызовов неизвестного ему кода, желательно выделить код сохранения данных в хранилище в отдельную фазу-фиксацию. Такое выделение может нести как плюсы, так и минусы (э-э-э, корпоративная политика смешивания кода в одну кучу для удобства обсфуркации?). В любом случае, использование исключений уменьшает количество доступных вариантов.
  • Использование исключений ведёт к распуханию бинарного файла программы, увеличивает время компиляции (иногда только чуть-чуть) и вообще может привести к проблемам с адресным пространством.
  • Само наличие исключений может провоцировать разработчиков выбрасывать их по поводу и без повода, даже когда это не нужно или может привести к сложностям в обработке. Например, если пользователь вводит неподходящий текст, это не должно приводить к выбрасыванию исключения. И вообще, если всё это расписывать, то никакого документа не хватит!

Вердикт
Для новых проектов преимуществ от использования исключений обычнобольше, чем недостатков. Однако, для уже существующего кодавведение исключений может повлиять на весь код. Также могут возникнутьпроблемы стыка нового кода и старого (без исключений) кода.

Т.к. большинство C++ кода в Google не использует исключений, то очень проблематично будет внедрять новый код, который будетгенерировать исключения. Существующий код в Google не может корректно работать с исключениями, поэтому цена внедрения исключений намного выше, чем реализация любого нового проекта. Переписывание существующего кодапод обработку исключений — это будет очень медленный процесс, с большим количеством ошибок. Поэтому лучше использовать альтернативу в виде возврата кода ошибки и assert-ов: это не так сложно.

Этот запрет также распространяется на добавленные в C++11 возможности, такие как std::exception_ptr и std::nested_exception.

Однако, для кода под Windows есть послабления.

noexcept

Указывайте noexcept, если это корректно и будет полезно.
Определение
Спецификатор noexcept используется для указания, что функция не будет выбрасывать исключения. Если же функция с таким спецификаторомвсё же выбросит исключение, то произойдёт крэш программы через std::terminate.

Также есть оператор noexcept. Он выполняет проверку: объявлено ли выражениекак «не выбрасывающее исключений». Проверка проводится на этапе компиляции.
За

  • Спецификация конструктора перемещения как noexcept может улучшить производительность в ряде случаев, например std::vector<T>::resize() скорее переместит объект нежели скопирует его, если конструктор перемещения для типа T заявлен как noexcept.
  • Указание noexcept для функций может разрешить дополнительную оптимизацию, например компилятор может не генерировать код по раскрутке стека. Конечно, это имеет смысл, если в целом исключения разрешены.

Против

  • Если проекты следуют данному руководству и в них исключения запрещены, то очень сложно проверить правильность спецификатора noexcept, если вообще применимо понятие правильности.
  • Вы не можете безболезненно удалить ранее прописанный спецификатор noexcept, т.к. это аннулирует гарантию, на которую может полагаться другой код, причём полагаться весьма замысловатыми способами.

Вердикт
Используйте noexcept, когда это может улучшить производительность и точно отражает семантику функции (если из функции вылетело исключение, то это явная, фатальная ошибка).Считается, что noexcept на конструкторе перемещения может существенно улучшить производительность, учитывайте это.Если вы рассчитывайте на значительный прирост производительностиот применения noexcept для других функций, пожалуйста, сначала проконсультируйтесь с руководителем проекта.

Используйте безусловный noexcept, если исключения полностью запрещены (т.е. в типовом проекте C++ в Google).В ином случае, используйте спецификатор noexcept сусловиями (желательно простыми), которые становятся false в тех редких случаях, когда функция может всё-таки выбросить исключение.Эти тесты могут пользоваться проверками на характеристики типов(например, std::is_nothrow_move_constructible дляобъектов создаваемых через конструктор перемещения) или аллокаторов(например, absl::default_allocator_is_nothrow). Отметим, что наиболее частая причина исключений — невозможностьвыделения памяти (и да, мы верим, что это не относится к конструкторамперемещения — они не должны выбрасывать исключений из-за ошибок выделения памяти) и есть много приложений, для которых эта ситуацияозначает фатальную ошибку, которую даже не имеет смысла обрабатывать.И даже в других, потенциально ошибочных, ситуациях рекомендуетсяделать упор на простоту интерфейса, нежели на поддержку всех сценариевобработки ошибок: например, вместо написания накрученного noexceptс зависимостью от внешней хэш-функции (выбрасывает она исключения или нет), можно просто задокументировать, что разрабатываемый компонент не поддерживает хэш-функции, которые выбрасывают исключения. И, после этого, использовать noexcept без всяких дополнительных условий.

Информация о типе во время выполнения (RTTI)

Не используйте информацию о типе во время выполнения (RTTI).
Определение
RTTI позволяет запросить информацию о C++ классе объектаво время выполнения. Делается через typeid илиdynamic_cast.
За
Типовые альтернативы вместо RTTI (описано ниже)требуют модификации или редизайна иерархии классов, участвующих в запросах. Иногда такую модификацию очень тяжело сделать, или она нежелательна, особенно в коде, который уже используется в других проектах.

RTTI может быть полезен для юнит-тестов. Например, можнотестировать классы-фабрики на правильность сгенерированного типа.Также это полезно в выстраивании связей между объектами и ихмакетами (mock).

RTTI бывает полезно при работе с абстрактными объектами. Например:

bool Base::Equal(Base* other) = 0;
bool Derived::Equal(Base* other) {
  Derived* that = dynamic_cast<Derived*>(other);
  if (that == nullptr)
    return false;
  ...
}

Против
Часто сам запрос типа объекта в процессе выполнения означает проблемы с дизайном приложения, показывает наличие изъянов виерархии классов.

Бесконтрольное использование RTTI усложняет поддержку кода.Это может привести в развесистым условиям, которые зависят от типа объекта, которые рассыпаны по всему коду. И которые придётся досконально изучать если будет необходимость что-то изменить в этом коде.

Вердикт
Использование RTTI может легко привести к злоупотреблениям, поэтому будьте аккуратны. Старайтесь ограничить использование RTTI только юнит-тестами. Рекомендуется отказаться от RTTIв новом коде. Если же требуется написать код, которыйведёт себя по разному в зависимости от типа объекта, возможно следующие альтернативы будут более подходящими:

  • Виртуальные методы. Это предпочтительный способ для выполнения различного кода в зависимости от типа объекта. И вся работа (код) делается в самом объекте.
  • Если код должен находится вне объектов, то можно использовать подходы, аналогичные двойной диспетчеризации, например шаблон проектирования Посетитель/Visitor. Это позволит внешнему коду самому определять тип объектов (используя систему типов).

Когда логика программы гарантирует, чтополученный указатель на базовый класс фактически есть указательна определённый производный класс, тогда можно свободно использоватьdynamic_cast. Правда, в этом случае лучше использоватьstatic_cast.

Большое количество условий, основанных на типе объекта, естьпоказатель явных проблем в коде.

if (typeid(*data) == typeid(D1)) {
  ...
} else if (typeid(*data) == typeid(D2)) {
  ...
} else if (typeid(*data) == typeid(D3)) {
...

Подобный код может рассыпаться, когда добавляется новый дочерний класс в иерархию. И вообще, очень тяжело модифицироватьбольшое количество разрозненных кусков кода в случаенебольших изменений в свойствах или методах дочерних классов.

И пожалуйста, не изобретайте собственный велосипед на замену RTTI. Аргументы против собственного решения будут такие же (см. выше), да и разбираться в чужих велосипедах обычно сложнее.

Приведение типов / Casting

Рекомендуется использовать приведение типов в C++-стиле: static_cast<float>(double_value). Также можно использовать инициализацию значением в скобках для преобразования арифметических типов: int64 y = int64{1} << 42. Избегайте конструкций вида int y = (int)x или int y = int(x) (хотя последний вариант допустим при вызове конструктора класса).

Определение
В C++ приведение типов расширяется по сравнению с чистым C путём добавления операций приведения.

За
Основная проблема с приведением типов в чистом C — неоднозначность операции. Например, одинаково записанная операция: (int)3.5 и (int)«hello» сильно отличается по смыслу. Инициализация в скобках и операции в стиле C++ часто помогают избежать такой неоднозначности. Дополнительная плюшка: операции приведения в стиле С++ легче искать по коду.

Против
C++-стиль довольно громоздкий.

Вердикт
Избегайте использования приведения типов в стиле чистого C. Вместо этого используйте стиль C++ когда требуется явное преобразование типов.

  • Используйте инициализацию в скобках для преобразования арифметических типов (int64{x}). Это самый безопасный способ, т.к. в других случаях (при потере информации при конвертации) код может не скомпилироваться. Плюс лаконичный синтаксис.
  • Используйте static_cast как эквивалент преобразований в C-стиле или когда необходимо преобразовать указатель на дочерний класс в указатель на базовый и обратно (указатель на базовый класс преобразовать в указатель на дочерний (и желательно, чтобы сам объект был экземпляром дочернего класса)).
  • Используйте const_cast чтобы убрать квалификатор const (см. const).
  • Используйте reinterpret_cast чтобы небезопасно преобразовать указатели к целым числам или указателям другого типа. Используйте эту операцию только если вы знаете, что делаете и понимаете проблемы с выравниванием. Также, можете использовать в таких случаях absl::bit_cast.
  • Используйте absl::bit_cast для приведения «сырых» битов в другой тип такого же размера (например, если требуется интерпретировать double как int64).

Также может быть полезным раздел RTTI с описанием dynamic_cast.

Потоки / Streams

Используйте потоки в подходящих случаях, особенно если их использование упрощает код. Перегружайте операцию << только для типов-значений и выводите в поток собственно данные (доступные пользователю). Не выводите в поток внутренние переменные (инварианты и т.д.) и другие детали реализации.

Определение
Потоки являются стандартной абстракцией для ввода/вывода в C++, (см. стандартный заголовочный файл <iostream>). Они часто используются в коде в Google, особенно для отладочного логирования и диагностики.

За
Операторы << и >> реализуют форматированный ввод/вывод, они просты в понимании, портабельны, расширяемы и повторно используемы. Противоположность к ним — printf, который даже не поддерживает работу с std::string. Кроме того не работает с пользовательскими типа и с портабельностью там проблемы. Кроме того, printf вынуждает выбирать среди похожих версий одной функции и ориентироваться в десятках форматных символах.

Потоки обеспечивают хорошую поддержку консольного ввода/вывода через std::cin, std::cout, std::cerr и std::clog. Функции из C API тоже хорошо работают, однако могут требовать вручную буферизировать ввод.

Против

  • Форматирование потоков можно настроить через манипуляторы, изменяющие состояние потока. Учтите, применение манипуляторов сохраняется во времени и, как результат, поведение кода зависит от истории использования потока (или необходимо будет всё восстанавливать в известное состояние после каждого случая возможного применения манипуляторов). Кроме того, пользовательский код может (помимо модификации встроенных параметров) создавать собственные манипуляторы, добавлять переменные состояния и изменять поведение через функционал register_callback.
  • Проблематично полностью контролировать вывод потока: смена настроек (см. выше), вывод мешанины из параметров и собственно данных, использование перегрузки операторов (и компилятор может выбрать не ту перегрузку, которая предполагалась) — всё это не добавляет управляемости.
  • Формирование вывода посредством вызова цепочки операторов << затрудняет локализацию, т.к. при этом жёстко, прямо в коде, фиксируется порядок слов. И средства поддержки локализации лишаются ценности.
  • Потоковый API может быть сложным, с тонкостями. И программисты должны уметь с ним работать, чтобы код был эффективным.
  • Выбор правильной версии оператора << из большого количества аналогичных является для компилятора затратным. При частом их использовании в большой кодовой базе, время парсинга и анализа может отъедать до 20% времени.

Вердикт
Используйте потоки только если они являются наилучшим решением. Обычно это варианты ввода/вывода в человекочитаемый формат, предназначенный для разработчиков, а не для конечного пользователя. Также не забывайте, что в проекте уже могут быть устоявшиеся методы ввода/вывода — старайтесь использовать их. В частности, библиотеки для логирования и диагностического вывода обычно предпочтительнее нежели std::cerr или std::clog. И вместо std::stringstream лучше использовать absl/strings или их эквивалент.

Не рекомендуется использовать потоки для ввода/вывода в случае обмена данными с конечными пользователями или где возможно нарушение формата или валидности данных. В таких случаях используйте подходящие (шаблонные) библиотеки, которые корректно обрабатывают интернационализацию, локализацию, проверяют корректность данных и формата.

Если потоки всё же используются, старайтесь избегать API работы с состояниями, кроме состояния ошибки. Т.е. не используйте imbue(), xalloc() и register_callback(). Рекомендуется использовать явные функции форматирования (см. absl/strings) вместо манипуляторов или флагов форматирования для таких вещей как смена основания системы счисления, точности или набивка нулями до нужного размера чисел.

Перегружайте оператор << только для типа-значения с тем, чтобы оператор выводил человеко-читаемое представление. Не выводите в поток детали реализации или внутренние переменные. Если же требуется отладочная печать внутреннего состояния, то используйте обычные функции-методы (например, метод класса DebugString() — подходящий вариант).

Преинкремент и предекремент

Используйте префиксные формы (++i) инкремента и декремента над итераторами и другими шаблонными объектами.

Определение
Когда переменная инкрементируется (++i, i++) или декрементируется (—i, i—), а возвращаемое значение не используется, то необходимо чётко понимать: использовать префиксную форму (++i, —i) или постфиксную (i++, i—).

За
Когда возвращаемое значение игнорируется, то префиксная форма не менее эффективна постфиксной (чаще префиксная более эффективна). Связано это с тем, что постфиксная реализация должна сделать копию переменной с исходным значением для возврата результата. Если переменная является итератором или другим сложным типом, то копирование её может быть затратным по ресурсам. Поэтому, если обе формы ведут себя одинаково (возвращаемое значение игнорируется), почему бы не использовать всегда префиксную форму?

Против
Традиционно раньше в разработке (особенно на языке C) использовалась постфиксная форма, особенно для циклов for. Иногда программистам легче читать код с постинкрементом, т.к. «субъект» (i) стоит перед «действием» (++), как в английском предложении.

Вердикт
Для простых скалярных (не-объектов) типов нет особой разницы в использовании префиксной или постфиксной формы. Для итераторов и других шаблонных типов используйте префиксную форму.

Использование const

В API используйте const когда это имеет смысл. В ряде случаев constexpr будет лучшей альтернативой const.

Определение
При объявлении переменных или параметров вначале может быть указано const, чтобы показать что переменные не изменяются (например, const int foo). Функции класса могут быть с квалификатором const, чтобы показать, что эта функция не изменяет состояние членов класса (например, class Foo { int Bar(char c) const; };).

За
Позволяет легко понять, как использовать переменные. Компиляторам даёт возможность полнее контролировать типы и, теоретически, генерировать лучший код. Использование констант даёт дополнительную защиту (уверенность) в корректности кода: функции не могут модифицировать переменные, изменять состояние класса и, как результат, можно безопасно работать без локов в многопоточном окружении.

Против
Использование const оно «заразное»: если передаётся const переменная в функцию, то она должна в прототипе иметь указание на const (или придётся делать const_cast). И это может быть проблемой при вызове библиотечных функций.

Вердикт
Настоятельно рекомендуется использовать const в API (параметры функций, методы, не-локальные переменные), где это имеет смысл. Такой подход даёт понятное (и верифицируемое компилятором) описание как можно модифицировать объекты. Чёткое разделение на модифицирующие (запись) и не-модифицирующие (только чтение) операции очень полезно, особенно для написания потокобезопасного кода. В частности:

  • Если функция не меняет аргумент, переданный по ссылке или указателю, то он должен быть ссылкой на константу (const T&), либо указателем на константу (const T*).
  • Если параметр передаётся по значению, то использование const не даёт никакого эффекта. Поэтому не рекомендуется объявлять константный параметр. См. также TotW #109.
  • Старайтесь объявлять члены класса константными (const) если они не изменяют логическое состояние объекта (и не дают возможности другим что-то менять, например через возврат не-константной ссылки). В противном случае эти методы могут быть небезопасными в многопоточном окружении.

Использование const для локальных переменных отдаётся на усмотрение программиста: можно использовать, можно — нет.

Все const операции класса должны работать корректно при одновременном вызове нескольких функций. Если это не выполняется, то класс должен быть явно описан как «потоко-не-безопасный».

Местоположение const

Иногда используется форма int const *foo вместо const int* foo. Обосновывается это тем, что первая форма более логична: const следует за описываемым объектом. Однако, такая «логичность» имеет мало смысла (и обычно не применяется в коде с несколькими вложенными маркерами «указатель»), т.к. чаще всего есть только один const для базового значения. В таком случае нет необходимости специально заботиться о логичности. Размещение же const вначале делает код более читабельным и согласованным с английским языком: прилагательное (const) стоит перед существительным (int).

Так что расположение const вначале является предпочтительным. Однако, это не жёсткое условие и если остальной код в проекте использует другой порядок — следуйте за кодом!

Использование constexpr

Используйте constexpr для определения констант или чтобы сделать константную инициализацию.

Определение
Переменные можно объявлять как constexpr для указания на константу, значение которой определяется во время компиляции или линковки. Также можно объявлять функции и конструкторы как constexpr, чтобы их можно было использовать для определения переменной с constexpr.

За

constexpr позволяет определять выражения с плавающей запятой (помимо литералов), использовать константы для пользовательских типов и вызовов функций.

Против
Использование constexpr может вызвать проблемы с поддержкой кода (или миграцией), если константность нужно будет позже убрать. Текущие ограничения для константных функций или конструкторов могут потребовать реализации дополнительных обходных путей в коде.

Вердикт

constexpr позволяет определить неизменяемые части интерфейса. Используйте constexpr чтобы определить константы и функции для задания им значений. Не используйте constexpr, если это потребует усложнения кода. Не используйте constexpr, чтобы сделать код «встраиваемым» (inlining).

Целочисленные типы

Среди встроенных целочисленных типов C++ необходимо использовать int. Если в программе требуется переменная другого размера, то используйте целочисленные типы фиксированной длины из <stdint.h>, такие как int16_t. Если переменной нужно хранить значения, равные или превышающие 2^31 (2GiB), используйте 64-битный тип int64_t. При оценке размера не забудьте, что в int должен укладываться не только результат, но и промежуточные значения при вычислениях. И, если сомневаетесь, используйте тип подлиннее.

Определение
C++ не уточняет размер целочисленных типов, таких как int. Обычно считается, что short содержит 16 битов, int — 32, long — 32 и long long содержит 64 бита.

За
Унификация в коде.

Против
Размеры целочисленных типов в C++ могут изменяться в зависимости от компилятора и архитектуры.

Вердикт
В <cstdint> определяются различные типы: int16_t, uint32_t, int64_t и т.д. Если требуются типы фиксированного размера, то не используйте short, unsigned long long и им подобные. Из целочисленных типов языка C можно использовать только int. Также, в соответствующих случаях, используйте size_t и ptrdiff_t.

Тип int используется очень часто, особенно для небольших значений, например как счётчики в циклах. Можете считать, что int содержит минимум 32 бита (но не больше). Если требуется 64 битный целочисленный тип, то используйте int64_t или uint64_t.

Для типа который может хранить «большие значения» используйте int64_t.

Старайтесь не использовать беззнаковые числа (например, uint32_t). Допустимое применение беззнаковых чисел это использование битовых представлений или использование переполнения (по модулю 2^N) в расчётах. Отметим, что также не рекомендуется использовать беззнаковый тип чтобы указать на отсутствие отрицательных значений: в этом случае используйте assert-ы.

Если код возвращает размер контейнера, то убедитесь, что его тип (размера) является достаточным для любого возможного использования. И если сомневаетесь, используйте тип подлиннее.

Будьте внимательны при конвертировании целочисленных типов. Может появится неопределённое поведение (UB), ведущее к багам безопасности и другим проблемам.

Беззнаковые целые числа

Беззнаковые целые числа отлично подходят для работы с битовыми полями и модульной арифметики. Так сложилось, что стандарт C++ использует беззнаковые числа и для возврата размера контейнеров (хотя многие члены организации по стандартизации и считают это ошибкой; в любом случае, сейчас это уже не изменить). Ситуация, что беззнаковая арифметика по поведению является модульной (заворачивание значений при переполнении) и отличается от обычной (знаковой), не позволяет компилятору диагностировать большое количество ошибок. Фактически, такое поведение затрудняет оптимизацию.

С другой стороны, совместное использование беззнаковых и знаковых целых чисел создаёт ещё больше проблем. Лучшее решение: старайтесь использовать итераторы вместо указателей и явных размеров; не мешайте беззнаковые числа вместе со знаковыми; избегайте беззнаковых чисел (кроме работы с битовыми полями и для модульной арифметики); не используйте беззнаковые числа только чтобы показать, что переменная неотрицательная.

Совместимость с 64-бит

Написанный код должен быть совместим как с 64-битной, так и с 32-битной архитектурой. Особое внимание обращайте на печать в консоль, операции сравнения и выравнивание структур.

  • Форматные символы printf() для некоторых целочисленных типов основываются на макроопределениях (например, PRI из <cinttypes>). И такой подход является непрактичным, нежелательным и т.д. Поэтому очень желательно не использовать функцию printf (и подобные) в своём коде, или даже переписать существующий код. Вместо неё можно использовать библиотеки, поддерживающие безопасное форматирование числовых значений, такие как StrCat
    или Substitute
    для простых преобразований, или std::ostream
    .

    К сожалению, макросы PRI являются единственным переносимым способом указать формат для типов данных с задаваемым размером (int64_t, uint64_t, int32_t, uint32_t и т.д.). По возможности не передавайте аргументы таких типов в функции, основанные на printf. Исключение составляют типы, для которых есть свой выделенный модификатор длины, например size_t (z), ptrdiff_t (t) и maxint_t (j).

  • Помните, что sizeof(void*) != sizeof(int). Используйте intptr_t в случае, если требуется целочисленный тип размером, равным размеру указателя.
  • Будьте аккуратны с выравниванием структур, особенно тех что записываются на диск. Обычно классы и структуры, в которых есть член типа int64_t или uint64_t, по умолчанию выравниваются на границу 8 байт в 64-битных системах. Если в коде есть подобные структуры, они сохраняются на диске и используются 32-битным и 64-битным кодом, то обязательно проверьте, что структуры упаковываются одинаково на обеих архитектурах. Большинство компиляторов позволяют задать выравнивание структур. В gcc можно использовать __attribute__((packed)). В MSVC — #pragma pack() и __declspec(align()).
  • Используйте инициализацию в фигурных скобках если требуется создать 64-битную константу. Например:

    int64_t my_value{0x123456789};
    uint64_t my_mask{3ULL << 48};
    

Макросы препроцессора

Избегайте определения макросов, особенно в заголовочных файлах. Вместо этого используйте встраиваемые функции, перечисления или переменные-константы. Если используете макросы, то в имени используйте префикс — название проекта. Не используйте макросы, чтобы переопределить или дополнить C++ API.

Использование макросов подразумевает, что программист видит один код, а компилятор — другой. Это может вызвать неожиданные последствия, особенно если макросы глобальные.

Ситуация может усугубиться, когда макросы используются для переопределения С++ или другого публичного API. При любых ошибках в использовании API потребуется разбираться в логике макросов; увеличивается время разбора кода инструментами рефакторинга или анализаторами. Как результат, использование макросов в таких случаях запрещено. Например, откажитесь от подобного кода:

class WOMBAT_TYPE(Foo) {
  // ...
 public:
  EXPAND_PUBLIC_WOMBAT_API(Foo)
  EXPAND_WOMBAT_COMPARISONS(Foo, ==, <)
};

К счастью, в C++ зависимость от макросов поменьше, чем в C. Вместо макросов для высокопроизводительного кода можно использовать встраиваемые функции. Для хранения констант есть const переменные. Чтобы для удобства «укоротить» длинное имя переменной используйте ссылки. Вместо применения макросов для условной компиляции кода используйте… лучше не используйте условную компиляцию (конечно же это не касается защиты от повторного включения заголовочных файлов через #define). Тем более условная компиляция затрудняет тестирование кода.

С другой стороны, есть приёмы кодирования, которые делаются только через макросы. Обычно это можно увидеть в низко-уровневых библиотеках. Также есть приёмы (преобразование в строку, объединение строк и т.д.), которые нельзя сделать средствами самого языка напрямую. В любом случае, перед использованием макросов попробуйте найти способ реализации без макросов. Если же необходимо использовать макросы для определения интерфейса то предварительно обязательно проконсультируйтесь с руководством.

Следующие правила позволят избежать ряда проблем с макросами. По возможности следуйте им:

  • Не определяйте макросы в заголовочных (.h) файлах.
  • Определяйте (#define) макросы по возможности ближе к месту первого использования. И когда макросы уже не используются, то делайте #undef.
  • Не делайте #undef существующих макросов с последующим их переопределением своей версией. Вместо этого лучше придумайте для своих макросов уникальное имя и используйте его.
  • Постарайтесь не использовать макросы, которые раскрываются в большие и неустойчивые конструкции C++. По крайней мере, документируйте такое поведение.
  • Старайтесь не использовать ## для генерации имени функции/класса/переменной.

Настоятельно не рекомендуется экспортировать макросы из заголовочных файлов (т.е. определять макрос и не делать #undef его в конце заголовочного файла). Если макрос экспортируется из заголовочного файла, то он должен иметь глобальное уникальное имя. Как вариант, добавьте префикс с именем пространства имён проекта (заглавными буквами).

0 и nullptr/NULL

Используйте nullptr для указателей и ‘’ для char-ов (не используйте 0 для этих целей).

Для указателей (адресов) используйте nullptr, это улучшает безопасность типов.

Для проектов C++03 лучше используйте NULL, а не 0. Хотя оба варианта эквивалентны, NULL обычно ассоциируется с указателями. Также некоторые C++ компиляторы могут определять NULL специальным образом и выдавать более адекватные предупреждения компиляции. Никогда не используйте NULL как числовое значение (целочисленное или с плавающей запятой).

Используйте ‘’ в качестве символа конца строки (пустого символа). Это улучшает читабельность кода.

sizeof

Рекомендуется использовать sizeof(переменная) вместоsizeof(тип).

Используйте sizeof(переменная) если необходим размер определённой переменной. sizeof(переменная) будет возвращать корректное значение даже если в дальнейшем изменится тип переменной. sizeof(тип) можно использовать, когда код не работает с конкретной переменной, например в случае форматирования/разбора данных, где соответствующий тип C++ не подходит.

struct data;
memset(&data, 0, sizeof(data));
memset(&data, 0, sizeof(Struct)); // Плохо
if (raw_size < sizeof(int)) {
  LOG(ERROR) << "compressed record not big enough for count: " << raw_size;
  return false;
}

Вывод типов

Используйте вывод типов только если это сделает код более читабельным или более безопасным. Не используйте его только из-за неудобства написания полного типа.

Определение
Есть ряд ситуаций, когда типы в C++ коде могут (или даже необходимо) быть выведены компилятором и это более предпочтительно, чем явно их прописывать:

  • вывод типов аргументов шаблонной функции
    • Шаблонная функция может вызываться без указания явных шаблонных типов. Компилятор выводит эти типы из аргументов функции:
      template <typename T>
      void f(T t);
      f(0);  // Вызывается f<int>(0)

  • переменная с auto типом
    • Декларация переменной может использовать auto вместо типа. Компилятор выводит тип из выражения инициализации, следуя правилам, аналогичным для шаблонной функции (во всяком случае, пока не используются фигурные скобки вместо круглых).
      auto a = 42;  // a типа int
      auto& b = a;  // b типа int&
      auto c = b;   // c типа int
      auto d{42};   // d типа int, а не std::initializer_list<int>
      

      auto может использоваться совместно с const, или в составе указателя или ссылки. Однако, auto не может использоваться как аргумент шаблона. Изредка можно увидеть использование decltype(auto) вместо auto и в этом случае выводимый тип является результатом применения decltype
      к переданному выражению инициализации (прим.: и, например, сохранить квалификаторы ссылки).

  • вывод типа возвращаемого значения функции
    • autodecltype(auto)) можно использовать для указания возвращаемого значения функции. Компилятор выводит тип возвращаемого значения из выражения return в теле функции, следуя тем же правилам, что и при объявлении переменной:
      auto f() { return 0; }  // Возвращаемый f тип - int

      Возвращаемый тип лямбды может быть выведен аналогичным способом (хотя это делается при отсутствии возвращаемого типа, а не в случае использования auto). Синтаксис указания возвращаемого типа в конце для функций также использует auto, но это не вывод типа, скорее альтернативный синтаксис для явно указанного возвращаемого типа.

  • общие (generic) лямбды
    • В описании лямбды можно использовать auto в качестве одного или нескольких типов параметров. Как результат, оператор вызова лямбды будет шаблонной функцией вместо обычной, с отдельными параметрами шаблона по одному на каждый auto:
      // Сортируем `vec` по возрастанию
      std::sort(vec.begin(), vec.end(), [](auto lhs, auto rhs) { return lhs > rhs; });

  • инициализация захватываемых переменных лямбды
    • В лямбде в секции захвата можно явно прописать новые переменные, инициализированные значением:
      [x = 42, y = "foo"] { ... }  // тип x - int, y - const char*

      Синтаксис не позволяет указать тип новой переменной, он выводится аналогично auto переменным.

  • вывод аргументов шаблонного класса
    • См. соответствующий раздел.

  • структурная привязка
    • При объявлении кортежей, структур или массивов с использованием auto можно указать имена отдельных элементов вместо имени полного объекта. Эти имена называются «структурная привязка», а декларация — соответственно «декларация структурной привязки». Синтаксис не позволяет задать тип ни полного объекта, ни отдельных имён:
      auto [iter, success] = my_map.insert({key, value});
      if (!success) {
        iter->second = value;
      }

      auto можно использовать с квалификаторами const, & и &&. Отметим, что эти квалификаторы формально применяются к анонимному кортежу/структуре/массиву, а не к отдельным привязкам. Правила определения конечного типа привязок довольно запутанные, однако в большинстве случаев всё довольно логично. Можно только отметить, что тип привязки обычно не может быть ссылочным, даже если в декларации указана ссылка (хотя поведение всё равно может быть как у ссылки).

В приведённом выше описании не указаны многие детали, для дополнительной информации используйте приведённые ссылки.

За

  • Название типов в C++ может быть длинным и громоздким, особенно при использовании шаблонов и пространств имён.
  • Когда название типа C++ повторяется несколько раз внутри небольшого куска кода или декларации, это повторение не улучшает читабельность.
  • В ряде случаев вывод типов безопаснее, т.к. позволяет избежать случайных копирований или преобразований типов.

Против
При явном указании типов код C++ становится более ясным и понятным, особенно если вывод типов опирается на информацию из совершенно другой части кода. В выражении наподобие:

auto foo = x.add_foo(); // Плохо. Что есть foo?
auto i = y.Find(key);

может быть неочевидно какие типы выводятся для переменных, особенно если y не является хорошо известным типом или объявлен намного раньше по коду.

Необходимо разбираться, выдаётся ли ссылка при выводе типа, производится ли копирование (особенно если оно не предполагалось).

Если выводимые типы используется как часть интерфейса, то любые незначительные изменения в выражениях могут привести к радикальным изменениям API.

Вердикт
Основное правило: используйте вывод типов только если это сделает код более ясным и безопасным. Не используйте вывод типов только чтобы облегчить написание кода. Не забывайте, что читатели кода могут быть в другой команде и не знакомы с этим проектом. Поэтому, хотя явные типы могут считаться понятным, очевидным и избыточными для одних, они могут содержать полезную информацию для других. Например, можно полагать, что возвращаемый тип make_unique<Foo>() очевиден. Однако, в случае MyWidgetFactory() лучше считать по-другому.

Эти принципы применяются для всех видов вывода типов. Однако, существуют тонкости, описанные ниже.

Вывод аргументов шаблонной функции

Вывод аргументов шаблонной функции это практически всегда хорошо. Это стандартный и ожидаемый способ работы с шаблонными функциями, т.к. вызов такой функции напоминает работу с обычной (но перегруженной для различных аргументов) функцией. И шаблонные функции желательно проектировать так, чтобы вывод аргументов был корректный и безопасный, или функция не должна компилироваться.

Вывод типов локальных переменных

В случае локальных переменных можно использовать вывод типов, чтобы сделать код более простым, убрав очевидную или нежелательную информацию о типах, и читатель может сконцентрироваться на важных частях кода. Сравните примеры кода:

std::unique_ptr<WidgetWithBellsAndWhistles> widget_ptr =
    absl::make_unique<WidgetWithBellsAndWhistles>(arg1, arg2);
absl::flat_hash_map<std::string,
                    std::unique_ptr<WidgetWithBellsAndWhistles>>::const_iterator
    it = my_map_.find(key);
std::array<int, 0> numbers = {4, 8, 15, 16, 23, 42};
auto widget_ptr = absl::make_unique<WidgetWithBellsAndWhistles>(arg1, arg2);
auto it = my_map_.find(key);
std::array numbers = {4, 8, 15, 16, 23, 42};

Типы иногда содержат смесь как полезной, так и формальной информации. Например в примере выше очевидно, что it это итератор. Вообще в большинстве аналогичных случаев информация о контейнере и даже типе ключа не особо полезна, однако тип значения обычно важен. В этом случае можно определить локальную переменную с явно указанным (полезным для читателя) типом:

auto it = my_map_.find(key);
if (it != my_map_.end()) {
  WidgetWithBellsAndWhistles& widget = *it->second;
  // Do stuff with `widget`
}

Если тип является шаблонным, у которого параметры неинформативны, но тип самого шаблона является важным, то можно использовать вывод аргументов шаблонного класса чтобы избавиться от формального (ненужного) кода. Отметим что случаи, когда это является полезным, довольно редки. Также учтите, что при использовании вывода аргументов шаблонного класса желательно следовать специальным рекомендациям.

Не используйте decltype(auto) при наличии более простых альтернатив, т.к. результат использования не всегда легко предсказуем.

Вывод типа возвращаемого значения

Используйте вывод типа возвращаемого значения (как для функция, так и для лямбд), только если тело функции содержит небольшое количество return и сам код небольшой. В противном случае читатель не сможет понять возвращаемый тип без его исследования. Также применяйте такой вывод типов только для функций или лямбд с очень маленькой областью видимости, т.к. функции не могут установить границы абстракции: сама реализация формирует интерфейс. В частности, публичные функции в заголовочных файлах никогда не должны использовать вывод типа возвращаемого значения.

Вывод типов параметров

Параметры с auto в ламбдах должны использовать с осторожностью, т.к. реальный тип определяется кодом лямбды, а не её объявлением. И, конечно, явное указание типа обычно более понятно, за исключением случаев, когда лямбда определяется рядом с местом её использования (можно одновременно видеть и определение лямбды и её вызов) или лямбда передаётся в настолько известный интерфейс, что используемые аргументы очевидны (например, см. вызов std::sort выше).

Инициализация переменных захвата ламбды

При инициализации переменных захвата предпочтительны специальные рекомендации, которые в целом подменяют общие правила для использования вывода типов.

Структурные привязки

В отличие от других форм вывода типов, структурные привязки могут дать дополнительную информацию за счёт правильного именования элементов полного объекта. Т.е. декларация структурной привязки может улучшить читабельность кода по сравнению с использованием явного типа (даже если auto не рекомендуется). Структурные привязки хорошо подходят при работе с парами или кортежами (см. пример использования insert выше), потому что в последних нет «говорящих» названий полей. С другой стороны, в целом не рекомендуется использовать пары и кортежи, пока внешний API, наподобие insert, явно этого не потребует.

Если объектом привязки является структура, иногда может быть полезно указать имена, лучше подходящие для данного кода. Однако учитывайте, что такие имена могут быть менее понятны читателям кода, чем штатные имена полей. Рекомендуется использовать комментарии для указания имён полей, если они отличаются от имён привязок. Используйте синтаксис, аналогичный комментариям к параметрам функций:

auto [/*field_name1=*/ bound_name1, /*field_name2=*/ bound_name2] = ...

Также, как и с параметрами функций, комментарии могут помочь внешним инструментам определить ошибки в порядке указания полей.

Вывод аргументов шаблонного класса

Используйте вывод аргументов только для тех шаблонных классов, что явно поддерживают это.

Определение

Вывод аргументов шаблонного класса (CTAD) проявляется, когда переменная декларируется с типом шаблона, но без указания аргументов (даже без угловых скобок):

std::array a = {1, 2, 3};  // Тип `a`: std::array<int, 3>

Компилятор выводит аргументы из выражения инициализации, используя «гайд» для шаблонов, который может быть явный и неявный.

Явный гайд походит на декларацию функции с возвращаемым типом в конце, только без auto вначале, и имя функции есть имя шаблона. Например, ранее приведённый пример опирается на следующий гайд для std::array:

namespace std {
template <class T, class... U>
array(T, U...) -> std::array<T, 1 + sizeof...(U)>;
}

Конструкторы в основном определении шаблона (т.е. не в специализации) также неявно определяют «гайд».

Когда объявляется переменная, использующая CTAD, компилятор выбирает «гайд» на основе правил выбора (разрешения) перегруженного конструктора, и возвращаемый гайдом тип становится типом переменной.

За
CTAD иногда может уменьшить количество формального кода.

Против
Неявные «гайды», получаемые из конструкторов, могут реализовывать нежелательное или даже неправильное поведение. Эта проблема может часто проявляться для конструкторов, написанных до появления CTAD в C++17, т.к. авторы кода просто не знали о тех проблемах, которые вызовет CTAD. И далее, добавление явных «гайдов» для исправления проблемы может поломать любой существующий код, который использует неявные гайды.

У CTAD есть много недостатков, аналогичных недостаткам auto, т.к. оба механизма выводят (полный или частичный) тип переменной на основе инициализации. CTAD выдаёт больше информации, чем auto, однако всё равно не содержит явного указания, если информация была пропущена.

Вердикт
Не используйте CTAD на шаблонных классах, пока не будет поддержки механизма и обеспечен хотя бы один явный «гайд» (предполагается, что в пространстве имён std всё поддерживается). Желательно, чтобы недопустимое использование CTAD приводило к предупреждениями компилятора.

В любом случае, использование CTAD должно следовать общим правилам при выводе типов.

Лямбды

Используйте лямбды в подходящих случаях. Желательно использовать явный захват переменных, если лямбда будет выполнена вне текущей области видимости.

Определение
Лямбды это лаконичный и удобный способ создания объектов — анонимных функций. Особенно они полезны, когда нужно передавать функцию как аргумент. Например:

std::sort(v.begin(), v.end(), [](int x, int y) {
  return Weight(x) < Weight(y);
});

Лямбды также позволяют захватывать переменный из текущей области видимости либо (явно) по имени, либо (неявно) через захват по-умолчанию. Явный захват предписывает перечислить все требуемые переменные: либо как значения, либо как ссылки:

int weight = 3;
int sum = 0;
// Захват `weight` по значению и `sum` по ссылке.
std::for_each(v.begin(), v.end(), [weight, &sum](int x) {
  sum += weight * x;
});

Захват по-умолчанию применяется ко всем переменным, используемым в теле лямбды, в том числе и к this (если используются члены класса):

const std::vector<int> lookup_table = ...;
std::vector<int> indices = ...;
// Захват `lookup_table` по ссылке, сортировка `indices` по значению
// ассоциированных элементов из `lookup_table`.
std::sort(indices.begin(), indices.end(), [&](int a, int b) {
  return lookup_table[a] < lookup_table[b];
});

Захват переменной может быть также с инициализатором, что можно использовать для перемещения (move) переменных по значению или для других случаев, не подпадающих под обычный захват по значению или ссылке:

std::unique_ptr<Foo> foo = ...;
[foo = std::move(foo)] () {
  ...
}

Такой тип захвата (часто называемый init или generalized) нужен скорее не для собственно «захвата» переменных (или даже имён) из текущей области видимости. Этот синтаксис нужен для определения членов объекта лямбды:

[foo = std::vector<int>({1, 2, 3})] () {
  ...
}

И тип такой переменной с инициализатором выводится согласно правилам, аналогичным использованию auto.

За

  • Лямбды это очень удобный и лаконичный способ определения объектов-функций (например, для передачи в алгоритмы STL), что может улучшить читабельность.
  • Правильное использование захвата по-умолчанию может устранить избыточность и выявить важные исключения при захвате.
  • Лямбды, std::function и std::bind можно использовать совместно как механизм обратного вызова общего назначения. Упрощается написание кода, принимающего/использующего функции как аргументы.

Против

  • Захват переменных может быть источником ошибок с недействительными указателями, особенно если лямбда выходит за текущую область видимости.
  • Захват по умолчанию может вводить в заблуждение, т.к. он не защищает от ошибок недействительных указателей. Захват указателя на объект по значению не приводит к созданию копии самого объекта. При этом часто возникают те же особенности жизненного цикла, что и при захвате по ссылке. Учтите, что ‘this’ также захватывается по значению и это может привести к проблемам, т.к. он часто используется неявно.
  • Захват фактически объявляет новые переменные (вне зависимости от наличия инициализатора), хотя это отличается от обычного синтаксиса C++. В частности, нет указания типа переменной, даже в виде auto (хотя захват с инициализацией может сделать это неявно через приведение типов), и это отличается от типовой декларации.
  • Захват с инициализацией использует вывод типов, и подвержен тем же проблемам, что и auto, плюс сам синтаксис не содержит указания, что происходит вывод типов.
  • В ряде случаев использование лямбд может сильно затруднить понимание кода (очень длинные функции) или потребовать дополнительного контроля.

Вердикт

  • Используйте лямбды в подходящих случаях. Применяйте форматирование, описанное ниже.
  • Рекомендуется явно указывать захват переменных, если лямбда может выйти за текущую область видимости. Например, вместо:
    {
      Foo foo;
      ...
      executor->Schedule([&] { Frobnicate(foo); })
      ...
    }
    // ПЛОХО! При беглом просмотре можно упустить, что лямбда использует
    // ссылку на foo и this (если Frobnicate является членом класса).
    // Если лямбда вызывается после возврата из текущей функции, то
    // это приведёт к проблемам, т.к. foo и другие объекты могут быть
    // уже разрушены.  
    

    лучше написать:

    {
      Foo foo;
      ...
      executor->Schedule([&foo] { Frobnicate(foo); })
      ...
    }
    // ЛУЧШЕ - Компилятор выдаст ошибку, если Frobnicate является методом класса.
    // Также явно указано, что foo захватывается по ссылке.
    

  • Используйте захват по-умолчанию по ссылке ([&]), только если жизненный цикл лямбды явно короче чем у любой переменной.
  • Используйте захват по-умолчанию по значению ([=]), только как средство привязки нескольких переменных для короткой лямбды. Не рекомендуется писать лямбды с объёмным и сложным кодом вместе с захватом по-умолчанию по значению.
  • Используйте захват только существующих переменных из текущей области видимости. Не используйте захват с инициализаторами, чтобы ввести новые имена или подменить существующие. Вместо этого можно объявить обычную новую переменную и передать её в лямбду, или вместо лямбды определить отдельную полноценную функцию.
  • Вопросы по указанию параметров и возвращаемому типу рассмотрены в разделе Вывод типов.

Метапрограммирование на шаблонах

Не используйте сложные/запутанные шаблоны в коде.

Определение
Метапрограммирование на шаблонах это семейство техник, использующих возможности по инстанцированию шаблона в C++, которое Тьюринг-полное, для выполнения вычислений на этапе компиляции.

За
Метапрограммирование позволяет создавать очень гибкие интерфейсы, у которых высокая производительность и отличная типобезопасность. Например, Google Test, std::tuple, std::function и Boost.Spirit были бы невозможны без таких средств.

Против
Техники метапрограммирования часто непонятны всем, кроме экспертов языка. Код, использующий шаблоны запутанными/сложными способами, часто нечитабелен, его сложно отлаживать и поддерживать.

Метапрограммирование часто приводит к появлению очень скудной и непонятной информации об ошибках компиляции: даже если сам интерфейс простой, то его сложная реализация всё равно проявляется, когда пользователь делает что-то неправильно.

Метапрограммирование усложняет проведение рефакторинга, затрудняя работу инструментов. Во-первых, код шаблона раскрывается в различных контекстах и трудно проверить, что в каждом из них код остаётся корректным. Во-вторых, ряд инструментов работает уже с AST (прим.: абстрактное синтаксическое дерево), которое описывает структуру кода только после раскрытия шаблонов. И в этом случае может быть тяжело обнаруженные проблемы отобразить на исходные конструкции в коде и определить, что требуется переписать.

Вердикт
Метапрограммирование в ряде случаев позволяет создать понятные и простые в использовании интерфейсы (которые были бы сложнее в ином случае), однако есть соблазн всё сделать чересчур заумным. Поэтому его лучше использовать в небольшом количестве низкоуровневых компонентов, чтобы сложность поддержки компенсировалась полезностью и широтой применения.

Дважды подумайте перед тем, как использовать метапрограммирование или другие сложные техники на шаблонах: может ли средний программист в команде понять и поддерживать такой код (особенно после переключения с другого проекта); сможет ли не-C++ программист (или другой случайный читатель) понять сообщения об ошибках или отладить выполнение функции, которую он вызывает. Если используются рекурсивное инстанцирование шаблонов, список типов, метафункции, шаблоны выражений или используется SFINAE или трюк с sizeof для разрешения перегрузки функции — скорее всего вы зашли слишком далеко.

Если используется метапрограммирование, то готовьтесь приложить усилия для минимизации сложности, а также её изоляции. По возможности скрывайте код с метапрограммированием внутри реализации, чтобы сделать пользовательские заголовочные файлы более читабельными. Код с метапрограммированием должен быть очень хорошо откомментирован: следует подробно задокументировать, как использовать код и на что будет похож «сгенерированный» результат. Обратите особое внимание на сообщения об ошибках, которые выдаёт компилятор, когда делается что-то ошибочное. Учтите, что сообщения об ошибках являются частью вашего пользовательского интерфейса и код следует доработать так, чтобы сообщения об ошибках были понятными для пользователя и объясняли, что нужно делать для их исправления.

Boost

Используйте только одобренные библиотеки из коллекции Boost.

Определение

Boost это популярная коллекция проверенных, бесплатных и открытых библиотек C++.

За
В целом код Boost является высококачественным, портируемым и во многом дополняется стандартную библиотеку C++, например, в таких областях как свойства типов или улучшенные связыватели (binder).

Против
Некоторые библиотеки Boost поощряют создание кода, который ухудшает читабельность: используется метапрограммирование или другие продвинутые техники на шаблонах, а также чрезмерно «функциональный» стиль.

Вердикт
Чтобы читабельность кода оставалась высокой для всех, кто осуществляет его поддержку, разрешены к использованию только некоторые библиотеки из коллекции Boost. В настоящее время это:

  • Call Traits из boost/call_traits.hpp
  • Compressed Pair из boost/compressed_pair.hpp
  • Boost Graph Library (BGL) из boost/graph, за исключением сериализации (adj_list_serialize.hpp) и параллельных/распределённых алгоритмов и структур данных (boost/graph/parallel/* и boost/graph/distributed/*).
  • Property Map из boost/property_map, за исключением параллельных/распределённых (boost/property_map/parallel/*).
  • Iterator из boost/iterator
  • Часть Polygon, которая работает с построением диаграмм Вороного и не зависит от остальной части Polygon: boost/polygon/voronoi_builder.hpp, boost/polygon/voronoi_diagram.hpp, and boost/polygon/voronoi_geometry_type.hpp
  • Bimap из boost/bimap
  • Statistical Distributions and Functions из boost/math/distributions
  • Special Functions из boost/math/special_functions
  • Root Finding Functions из boost/math/tools
  • Multi-index из boost/multi_index
  • Heap из boost/heap
  • flat-контейнеры библиотеки Container: boost/container/flat_map и boost/container/flat_set
  • Intrusive из boost/intrusive
  • Библиотека boost/sort
  • Preprocessor из boost/preprocessor

В настоящее время прорабатывается вопрос о добавлении других библиотек Boost в этот список, так что он может в будущем дополняться.

std::hash

Не определяйте специализации std::hash.

Определение

std::hash<T> это объект-функция, который hash контейнеры C++11 используют для получения хэш-ключа от типа T, если явно не указана другая хэш-функция. Например, std::unordered_map<int, std::string> это hash map, используюущая std::hash<int> для расчёта хэша ключа, тогда как std::unordered_map<int, std::string, MyIntHash> использует для расчёта MyIntHash.

std::hash определена для всех целочисленных чисел и с плавающей запятой, указателей, enum-ов, некоторых типов стандартной библиотеки (например, string и unique_ptr). Также допустимо определить специализацию для своих собственных типов.

За

std::hash легко использовать, она упрощает код, т.к. нет необходимости вводить свои именования. Специализация std::hash это стандартный способ определения хэша, удобный и понятный и новичкам и внешним командам.

Против
Хорошую специализацию std::hash может быть сложно написать: она может содержать большое количество формального и одинакового кода. Также это может потребовать усилий и по идентификации входных данных и по созданию самого алгоритма. Автор типа данных обычно ответственен за первое, а со вторым чаще всего возникают проблемы, т.к. это требует определённой экспертизы, которой у автора обычно нет (да она и не нужна). При этом плохая реализация алгоритма может внести уязвимости в безопасность кода, например от атак hash flooding.

Даже для экспертов создание хорошей специализации std::hash может представлять сложность, особенно для составных типов, т.к. хорошая реализация не может просто рекурсивно вызывать std::hash на всех членах данных. Высококачественные хэш-алгоритмы содержат большое количество внутренних состояний, и упаковка их в размер size_t (что функция std::hash и возвращает) обычно является самой медленной частью в вычислениях, так что это должно выполняться не более одного раза.

Именно из-за этого std::hash не работает с std::pair и std::tuple, и в язык не добавлена их поддержка.

Вердикт
Можно использовать std::hash с типами, которые поддерживаются «из коробки», но не добавляйте специализации для своих типов. Если требуется хэш-таблица с ключом, который не поддерживается std::hash, то возможно следует воспользоваться другими (ранними) хэш-контейнерами (например, hash_map); в них используется другой хэш-алгоритм, на который этот запрет не влияет.

Если всё равно требуется стандартный контейнер, то задаёте собственную хэш-функцию для ключа, например:

std::unordered_map<MyKeyType, Value, MyKeyTypeHasher> my_map;

Прежде всего узнайте у автора типа данных о наличии готовой хэш-функции (а вдруг?). В противном случае создавайте свою, в сотрудничестве с автором, или без него.

Возможно, скоро появится хэш-функция, которая сможет работать с любым типом и использовать новый механизм подстройки, при этом у неё не будет недостатков std::hash.

Остальные возможности C++

Некоторые расширения современного C++, также как и Boost, содержат код с плохой читабельностью, с удалённой добавочной информацией о типах, с использованием метапрограммирования. Другие же расширения дублируют существующий функционал, что может привести к путанице и дополнительной конвертации кода.

Вердикт
Настоятельно не рекомендуется использовать следующие возможности C++:

  • Рациональные числа (относящиеся к времени компиляции) (<ratio>), т.к. за интерфейсом может стоять сложный шаблон.
  • Заголовочные файлы <cfenv> и <fenv.h>, т.к. многие компиляторы не поддерживают корректную работу этого функционала.
  • Заголовочный файл <filesystem>, который недостаточно протестирован, и подвержен уязвимостям в безопасности.

Нестандартные расширения

Нестандартные расширения C++ не рекомендуется использовать, пока явно не указано обратное.

Определение
Компиляторы поддерживают различные расширения, не являющиеся частью стандартного C++. Например, __attribute__, внутренние (intrinsic) функции (__builtin_prefetch), назначенные инициализаторы (Foo f = {.field = 3}), ассемблерные вставки, __COUNTER__, __PRETTY_FUNCTION__, составные выражения (foo = ({ int x; Bar(&x); x }), массивы переменной длины, alloca() и «оператор Элвис» a?:b.

За

  • Нестандартные расширения могут предоставить полезные возможности, которых нет в стандартном C++. Например, многим назначенные инициализаторы нравятся больше, чем типовые конструкции C++ (конструкторы).
  • Сделать указания компилятору по оптимизации производительности кода можно только используя расширения.

Против

  • Нестандартные расширения работают не на всех компиляторах, поэтому их использование ухудшает переносимость кода.
  • Даже если расширения поддерживаются всему требуемыми компиляторами, их спецификация может быть не полной и возможны различия в поведении у разных компиляторов.
  • Для понимания кода нужно знать нестандартные расширения в дополнение к языку программирования.

Вердикт
Не используйте нестандартные расширения. Можно использовать портируемые обёртки кода, которые реализованы с использованием нестандартных расширений и и (желательно) содержатся в одном заголовочном файле (portability header).

Псевдонимы/Alias

Публичные псевдонимы предназначены для использования с API и должны быть хорошо документированы.

Определение
Есть несколько способов для создания имён, являющихся псевдонимами для других сущностей:

typedef Foo Bar;
using Bar = Foo;
using other_namespace::Foo;

При написании нового кода рекомендуется использовать using, а не typedef. Это обеспечивает более согласованный синтаксис с остальным C++ кодом и поддерживает работу с шаблонами.

Аналогично другим декларациям, псевдонимы, введённые в заголовочном файле, обычно являются частью публичного API этого файла. Исключения касаются случаев, когда псевдонимы объявлены внутри определения функции, private секции класса или явно отмеченном внутреннем пространстве имён. Такие псевдонимы, а также введённые в .cc файлах являются «деталями реализации» (т.к. клиентский код к ним не обращается) и не подпадают под действие этих правил.

За

  • Псевдонимы могут улучшить читабельность кода, сокращая длинные и сложные имена.
  • Псевдонимы могут уменьшить дублирование: например, сделав именование типа, часто использующегося в API, в дальнейшем это может облегчить изменение этого типа на другой.

Против

  • Псевдонимы, размещённые в заголовочном файле (где клиентский код может обращаться к ним), увеличивают количество сущностей в этом файле API и его сложность.
  • Клиентский код может полагаться на особенности публичных псевдонимов, и это усложняет внесение изменений.
  • Есть соблазн создавать публичные псевдонимы, которые будут использоваться только во внутренней реализации. Такой подход может влиять на сам API и усложнит его поддержку.
  • Псевдонимы увеличивают риск создания дубликата для другого имени.
  • Псевдонимы могут ухудшить читабельность кода, если хорошо известным сущностям будут давать незнакомые имена.
  • Псевдонимы типов могут создать «ненадёжное» соглашение по API: то ли псевдоним всегда будет идентичным указанному типу (API не изменится, тип можно использовать любым способом); то ли тип у псевдонима может поменяться (тогда рекомендуется использовать только небольшую часть возможностей).

Вердикт
Не вводите псевдонимы в публичный API только для облегчения написания кода в реализации; псевдоним должен прежде всего быть полезен для клиентского кода.

Определяя публичный псевдоним, обязательно опишите назначение нового имени, будет ли псевдоним всегда соответствовать текущему типу или будет более ограниченная совместимость. С одной стороны, это позволит узнать, является ли псевдоним заменителем типа или необходимо следовать более специфическим правилам. С другой стороны, это может дать определённую свободу при изменении псевдонима в дальнейшем.

Не объявляйте публичные псевдонимы на пространства имён в своём API. (См. также Пространство имён).

Например, следующие псевдонимы описывают способ их использования в клиентском коде:

namespace mynamespace {
// Используется для хранения измерений. DataPoint может меняться с Bar* на другой
// внутренний тип, его следует трактовать как абстрактный указатель.
using DataPoint = foo::Bar*;
// Набор измерений. Добавлен для удобства пользователя.
using TimeSeries = std::unordered_set<DataPoint, std::hash<DataPoint>, DataPointComparator>;
}  // namespace mynamespace

Приведённые ниже псевдонимы не документируют способы использования и часть из нихвообще не предназначения для использования в клиентском коде:

namespace mynamespace {
// Плохо: непонятно, как это использовать.
using DataPoint = foo::Bar*;
using std::unordered_set;  // Плохо: это для внутреннего удобства
using std::hash;           // Плохо: это для внутреннего удобства
typedef unordered_set<DataPoint, hash<DataPoint>, DataPointComparator> TimeSeries;
}  // namespace mynamespace

Однако, локальные псевдонимы очень удобны внутри определения функций, private секций классов, внутренних пространств имён и в .cc файлах:

// В .cc файле
using foo::Bar;

Примечания:
Изображение взято из открытого источника.

Идеальный лендинг подразумевает идеальный оффер

Оффер – это торговое предложение по своей сути и его идеальная формула выглядит как выгода плюс бонусы, плюс гарантии, некоторые ограничения и призыв к действию.

Относительно выгоды: заинтересуйте своего покупателя, поясните почему покупать надо именно у вас? В чем ценность предлагаемой продукции – именно это и дает первый толчок к покупке. Это может быть удобная и бесплатная доставка, какие-то подарки, скидки и так далее.

Бонусы и подарки обычно работают лучше скидок. Это может быть услуга, например, бонусом идет бесплатная установка кондиционера или какой-то подарок: купите шкаф, подарим два стула. Бонус вот он – его можно пощупать.

Гарантия на вашу продукцию должна быть, так же людей привлекает возможность возврата в течении какого-то времени.

Предложение должно быть ограниченное по времени: только сегодня или только три дня. Как вариант: осталось всего три кровати по такой цене.

Призыв к действиям: тут все просто. Это может быть купите, зайдите, звоните, заполните форму и так далее.

Все эти простые, на самом деле, действия помогут вам привлечь покупателей и поднять количество продаж.

Не покупайте дешевые лендинги

Люди, которые хотят заказать посадочную страницу за 15000 рублей, свято верят в то, что это возможно. При этом запуск качественного лендинга это работа как минимум шести человек и за такие смешные деньги они точно ничего делать не будут.

Чаще всего такие недорогие странички предлагаются перекупщиками, которые закупают их за 7-10 тысяч рублей на иностранных биржах в готовом виде и продают за те же 15000 с новым копирайтингом, а зачастую и кривой версткой.

Дешево делают те, кто не имеет опыта в данной сфере и скорее всего вы потратите деньги просто так, а толку не будет никакого. В редких случаях можно натолкнуться на специалиста, который открывает свой бизнес, но статистика показывает, что их на рынке менее одного процента в общем.

Можно наткнуться на мошенников, который возьмут деньги, пропадут и выйдут под другим названием, таких, как не обидно, достаточно много и привлечь их за мошенничество практически нереально. Стоит понять, что получить за копейки хороший сайт, который будет приносить вам прибыль, просто невозможно и обращаться необходимо к людям, которые имеют портфолио, отзывы клиентов, хотя и придется заплатить куда как большую цену, но такой лендинг точно будет работать и приносить прибыль.

Зачем давать стопроцентную гарантию?

Нельзя ставить при продаже гарантию на возврат меньше чем 100%. Дело в том, что исследования показали: если человек видит что-то вроде «гарантия в восемьдесят процентов» или что-то наподобие, то покупательская способность резко падает. Логика тут простая: продавец не уверен в своем товаре и не хочет его принимать обратно, чего-то опасается, значит все плохо, поищем в другом месте.

Если вы боитесь массовых возвратов, то страх совершенно беспочвенный: статистика говорит, что возврат происходит в менее чем полпроцента случаев. Люди просто забывают о такой возможности как правило и пользуются покупкой, если она их устраивает, работает без нареканий.

При наличии дорогого товара, сложного технически целесообразно вводить определенный срок гарантии на возврат. Это может быть две недели, месяц, десять дней, но сама возможность для покупателя необходима. Это показывает, что продавец полностью уверен в том, что продает и ничего не боится, а это и дает прирост продаж.

Ошибки при использовании картинок

Есть три самых распространенных ошибки при использовании картинок в описании товаров и услуг, для привлечения внимания и так далее.

Первая и самая частая: картинка маленькая, качество отвратительное, разглядеть, что на ней изображено крайне сложно. Таких фотографий быть не должно на сайте от слова совсем.

Вторая ошибка: использование фотографий с изображением людей не славянской внешности. Это не расизм, но зачем торгуя в России ставить в качестве фотографии на сайт изображение, например, японки или негритянки, даже если по смыслу фото и подходит. Это справедливо и для продажи товаров в других странах: ставьте на сайты тех, кто там проживает в большей своей массе.

Третья ошибка – использование растиражированных фотографий с фотобанков. Есть куча фото, которые уже набили оскомину и примелькались. Они не вызывают доверия покупателя, они скучная, ненужная. Все фото и картинки должны быть по крайней мере не приевшимися, а лучше оригинальными.

Помимо этого, обращайте внимание куда смотрит человек на фото, несет ли смысловую нагрузку фотография, отвечает услуге или товару, что вы продаете.

Вы или ты – как правильно говорить с покупателем

Закавыка вы или ты при обращении к клиентам на сайте, в рекламе, с билбордов и так далее очень частая проблема для многих компаний. В принципе можно использовать то, что вам нравится. Тот же Сбер везде говорит клиентам ты, но при этом стоит отличать рекламный посыл, на сайте и личную встречу, где возможно только вежливое вы.

Так же важный момент: очень многие копирайтеры не знают, как писать правильно и все время режет глаз в текстах Вы с большой буквы. Дело в том, что обращение Вы используется лишь к людям, обладающим каким-то серьёзным весом: президентам стран, например, причем в личном письме. Во всех остальных случаях пишется вы с маленькой буквы и никак иначе. Также на «вы» следует обращаться в своих рекламных обращениях к организациям. Это классическое обращение.

Писать нужно от второго лица, то есть конкретного человека, не безликого «Мы компания…» и так далее. Это воспринимается положительно, наподобие личного обращения того же директора, главы отдела маркетинга и так далее.

Функции CRM

CRM или Customer Relationship Management – это система, которая помогает автоматизировать весь процесс взаимоотношений с клиентами. Она позволяет оптимизировать и сохранять информацию о предыдущих заказах, упрощать бизнес-процессы, анализировать результат.

Основные функции CRM-системы заключаются в следующем:

  • организация рабочих процессов, их упорядочивание;
  • помогает контролировать работу сотрудников, отсматривать их общение с заказчиками и клиентами;
  • позволяет провести автоматизацию процесса сделки по готовым шаблонам – нужно лишь подобрать правильный вариант;
  • можно отследить эффективность сотрудников, составить аналитическую справку;
  • сохранять базу клиентов, информацию о работе с ними и снизить потери заказчиков минимально.

Все это позволяет максимально упростить работу, повысить лояльность клиентов, менеджерам нет нужды тратить время и силы на поиск сотрудника и пояснение ему задачи, достаточно просто поставить ее в системе. Контроль за выполнением работы также облегчается. Появляется возможность создать любую нужную отчетность.

Конечно это не все функции и возможности CRM, но данная система необходима любому бизнесу. 

Точки роста бизнеса: аналитика системы продаж

Если компания хочет увеличить свои прибыли, нарастить продажи, то обычно смотрят на то, что уже есть и масштабируют процессы. Чаще всего вложения идут в рекламу тех или иных продуктов, разрастание сети магазинов и так далее. Но, можно пойти другим путем – надо провести анализ не того, что есть, а того чего еще нет. Это позволяет оптимизировать бизнес, дать своим покупателям, клиентам, заказчикам желаемое.

Нужно обратить внимание на конверсию на всех этапах, число заказчиков, маржинальность, число повторных продаж, сколько существует франшиз и точек продаж, филиалов. Проанализировать бизнес-процессы, их работоспособность и слаженность, также проверяется отдел продаж в целом, включая эффективность РОПа. Уделяется внимание анализу воронки продаж: если виден спад между двумя этапами, то в данном месте надо наладить работу и тогда продажи возрастут.  Таким образом данный подход позволит выявить так называемые «узкие места», устранение которых приведет при малых затратах к большей эффективности.

Как удержать внимание клиента

Одна из важнейших задач каждого сайта – это удержать внимание клиента и заставить его вернуться.

Для этого есть много способов, первый – это современный и удобный дизайн сайта. Он должен быть дружеским, клиентоориентированным, удобным и понятным.

Доменное имя должно быть простым в написании и запоминающимся, чем сложнее, тем хуже для клиентов и для вас соответственно.

Не забудьте о статьях в вашем блоге – это очень важно. Если продаете детские вещи, то пишите про детей, туристическое снаряжение – про туризм и так далее. Не забудьте, что контент должен быть релевантным теме вашего товара.

Наймите грамотного специалиста по SEO, который составит семантическое ядро, проведет перелинковку и сделает ваш сайт более «вкусным» для поисковых роботов. Очень важно оптимизировать работу сайта для мобильных устройств – это в современном мире крайне актуально. Вся необходимая и важная информация должна быть на видном месте, отключите выскакивающие баннеры, уберите лишнюю информацию, чем меньше воды – тем лучше.

Все эти и многие другие способы помогут удержать клиента и вернуть его к вам в следующий раз. 

Как не убить конверсию сайта

Есть простые способов, которые позволят не «убить» конверсию сайта и повысить приток клиентов.

Первый – это неправильная навигация. Если клиенту трудно найти корзину, отследить свой заказ, он не понимает, как удалить ошибочно добавленный товар и так далее, то не ждите покупок.

На главном экране должен быть каталог, информация о компании, доставка и оплата, корзина покупок.

Акции и скидки должны быть понятны для пользователя: сроки проведения, условия, размер скидки, на какие товары и так далее. Не забывайте убирать баннеры после окончания скидочной серии.

Расскажите чем вы отличаетесь от конкурентов, уникальное торговое предложение всегда даст вам плюс.

Упростите процедуру заказа, не надо вносить кучу полей для заполнения, которые вам не нужны. Не делайте форму многостраничной с переходами туда-сюда.

Чем проще и понятнее ваш сайт, чем быстрее покупатель найдет все необходимое, тем выше шанс покупки.

SERM для бизнеса

Суть данной услуги – это формирование поисковой выдачи по ключевым запросам таким образом, чтобы выпадали связки «бренд и отзывы», «бренд и отзывы сотрудников» при этом данными позициями можно будет управлять.

Для этого необходимо провести огромный объем работ от написания статей, отзывов и размещения их на разных площадках до продвижения необходимых позиций и превращение всего этого в управляемую систему. По своей сути СЕРМ – это управление репутацией при поисковой выдаче. И десяток-другой положительных отзывов тут не помогут, если не знать сути данной работы.

SERM включает в себя мониторинг, отработку негативных отзывов, ответы всем похвалившим с раздачей «плюшек» всем упомянувшим сервис. Необходимо убрать старый негатив из ТОПа и делать это надо постепенно, чтобы не сложилось впечатления мгновенной пропажи отрицательных отзывов. Возможно проведение и подготовка арбитражей с признанием неподтверждённого негатива клеветой. Необходимо общение с площадками, которые аккумулируют негатив и многое другое.

Все это в итоге приведет к улучшению репутации и поднятию площадки в ТОП с положительными отзывами. 

  • Служить бы рад прислуживаться тошно значение сочинение
  • Случается как пишется правильно
  • Служишь в армии как пишется правильно
  • Слухи о великодушии разбойника дубровском сочинение
  • Служить бы рад прислуживаться тошно сочинение 9 класс