Должны ли мы избегать языковых возможностей, которые есть у C ++, а у Java нет?

110

Предположим, я ограничен в использовании C ++ средой в проекте. Хорошо ли предотвращать использование некоторых языковых функций, которые есть в C ++, но нет в Java (например, множественное наследование, перегрузка операторов)?

Я думаю, что причины:

  1. Поскольку Java новее, чем C ++, если Java не предоставляет возможности, которые есть в C ++, это означает, что эта функция не является хорошей, поэтому мы должны избегать ее использования.
  2. Код C ++ со специальными функциями C ++ (например, функции-друзья, множественное наследование) может поддерживаться или проверяться только программистами C ++, но если мы просто напишем C ++, как Java (без специфической для языка C ++ функции), код может поддерживаться или проверяться обоими C ++ и Java программисты.
  3. Вас могут попросить преобразовать код в Java когда-нибудь
  4. Код без специфических особенностей C ++ обычно более удобен в обслуживании
  5. Каждая особенность языка C ++ (например, множественное наследование) должна иметь альтернативы для реализации в Java. Если это не так, значит, шаблон проектирования или архитектура кода проблематичны.

Это правда?

ggrr
источник
7
Если вы посмотрите на ваши предложения, вы говорите о создании стандарта кодирования. Тот факт, что вы создаете и следуете стандарту, на самом деле повышает удобство обслуживания.
Брандин
63
Должен ли код Java быть ограничен функциями, которые также встречаются в языке C ++? Так что не используйте, например, Java volatile, доступ к элементам закрытого класса пакета, рефлексию / самоанализ, блоки finally, проверенные исключения и т. Д.? В целом вопрос вроде не имеет особого смысла ... C ++ и Java внешне похожи, но в конечном итоге очень разные языки.
Хайд
5
Как развиваются языки, если люди не хотят использовать новые функции? Цель новых функций - облегчить вашу жизнь, решая общие проблемы. Если пользователи не используют новые функции, то ни у кого нет мотивации для их реализации.
Мэтью
72
Если вы хотите Java, используйте Java. Если вы используете C ++, используйте C ++, а не какую-то ужасную, искаженную имитацию Java с синтаксисом C ++. Использование C ++, но ограничение себя набором функций Java дает вам худшее из обоих миров.
Джерри Гроб
11
Вы будете удивлены тем, как быстро различия будут кусать вас (и сильно ). SomeObject a = previousObject;делает очень разные вещи в Java и C ++. В Java это копирует ссылку, в то время как в C ++ это копирует объект. В Java изменения в aтакже влияют на предыдущий объект. В C ++ у вас есть два отдельных объекта.
Заводная муза

Ответы:

307

Нет. Это ужасно и ужасно неправильно.

  • Функции Java ничем не лучше функций C ++, особенно в вакууме.
  • Если ваши программисты не знают, как использовать функцию, обучайте или нанимайте лучших разработчиков; Ограничение ваших разработчиков до худшего в вашей команде - это быстрый и простой способ потерять ваших хороших разработчиков.
  • ЯГНИ . Решите вашу актуальную проблему сегодня, а не призрак какой-то будущей проблемы.
Telastyn
источник
6
Недавно возник вопрос о разработчиках, которые рассматривают код на языке, который они обычно не пишут. Я думаю, что мудрость здесь применима: хороший разработчик обнаружит много основных ошибок практически на любом языке, но каждый язык имеет так много ошибок, что максимальная выгода достигается, когда разработчики на языке делают обзор. Это даже верно, если ваш C ++ - это «только функции Java».
CorsiKa
5
+1 В дополнение к вашему второму пункту. ОП должен найти время, чтобы прочитать о "C ++ Best Practices", чтобы решить, какие функции им следует использовать. Моя последняя информация о C ++ заключается в том, что функции-друзья и множественное наследование считаются плохими методами . Такие вещи, как шаблоны и перегрузка операторов, являются ИМХО хорошими практиками, если вы используете их с умом.
some_coder
4
@ Some_coder: Все дело в том, чтобы знать, когда и где. Когда я занимаюсь программированием на основе политик, я наследую от (возможно, нескольких) классов политик, чтобы расширить структуру моего хост-класса членами, которые необходимы для функционирования классов политик. Это просто как это работает. Кроме того, operator<<( ostream &, T const & )обычно реализуется через friend. Вот в чем проблема с общими заявлениями о том, что является хорошей языковой функцией, а что плохой: они являются хорошим советом, кроме случаев, когда они не ...
DevSolar
142

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

1, 4 и 5 - это действительно один и тот же вопрос:

Теперь я не фанат C ++, но говорить: «Код без специфических функций C ++ обычно более удобен для сопровождения» - просто смешно. Вы действительно верите, что в Java все было правильно, и все полезные функции были приняты, игнорируя все плохие? Вы действительно верите, что есть что-то, что обычно является «плохой» или «хорошей» функцией? Если есть, почему у нас нет одного языка, который был бы просто хорош? И нет, Java, конечно , не тот язык. Означает ли это, что Java и C ++ бесполезны? Конечно, нет.

Что если ваши лидеры решат, что вы собираетесь портировать на C #, а не на Java? C # поддерживает не только переопределение операторов, но также и значение по умолчанию - если вам нужно, чтобы люди использовали, например, obj.Equals(obj2)вместо того obj == obj2, чтобы люди постоянно совершали ошибки. Даже если вы придерживаетесь только общих черт двух языков, существуют разные ожидания , другая культура. Если вы делаете что-то подобное if (myField == null)в C ++, люди сразу увидят, что вы новичок. Если вы используете if (null == myField)в C #, люди увидят, что вы еще не являетесь родным C # - причин, по которым разработчики C научились использовать «перевернутый» вариант, больше не существует в C #.

Используя вашу логику, мы должны были придерживаться машинного кода или сборки или COBOL, потому что зачем переходить на что-то вроде Pascal, когда оно просто добавляет новые функции, которые ваши программисты должны будут изучить? Зачем нам когда-либо использовать что-то вроде SQL, когда у него даже нет циклов ? Зачем нам когда-либо использовать что - то еще, кроме SQL, если в SQL нет циклов, а в X есть?

Код C ++ определенно не может поддерживаться программистами Java. Я не могу понять, откуда у вас эта идея - что именно остается, когда вы ограничиваете C ++ только функциями, которые работают точно так же, как в Java? Вы даже не будете получать вызовы методов - даже вызовы функций . Опять же, то, что оба языка используют фигурные скобки, не означает, что языки в любом случае взаимозаменяемы.

Преобразование Java-подобного кода C ++ будет чрезвычайно подвержено ошибкам независимо от того, что вы делаете. Просто слишком много различий. Если вам нужно переписать ваше приложение на другом языке, подумайте о разумных способах модульности всего, чтобы можно было заменить детали, не разбивая их целиком. Но, в конце концов, YAGNI - что бы вы ни делали, создание кода, готового к конвертации в Java, будет стоить немалых затрат. Это время, скорее всего, лучше потратить на добавление или улучшение ваших функций.

Мы используем разные языки, потому что они дают нам другой набор инструментов для решения проблем. Если вам нужны исполняемые файлы, которые работают «везде», используйте Java. Если вам нужен код, который компилируется «везде», C ++ работает нормально. Если вам нужен код, который легко понять и проанализировать, используйте LISP или что-то еще. Но я могу сказать вам одну вещь - написание кода на одном языке, как если бы вы писали его на другом языке, всегда является ошибкой, и вы будете страдать. Не говоря уже о том, что когда вы на самом деле нанимаете парня из C ++, он запускает вторую секунду, когда видит «совместимый с Java» код. И ... парень из Java собирается сделать то же самое. Знаете, даже "зная" и C ++, и Java, я бы работал как в аду :)

Я действительно должен был работать над (простым) кодом C, написанным разработчиком Pascal, который, казалось, думал так же, как и вы. Он использовал #defines, чтобы переопределить C, чтобы он выглядел и чувствовал себя как Паскаль, в комплекте с такими вещами, как «BEGIN переводится в {». Результат был довольно предсказуемым - код, который не могут понять ни C, ни разработчики Pascal, и полон ошибок, которые были результатом утечки «абстракции» Pascal поверх C. И Pascal и C практически идентичны с сегодняшней точки зрения. Даже переход на C <-> C ++ намного больше разницы, и это все еще арахис в нечто вроде C ++ <-> Java.

Luaan
источник
9
«Если вам нужен код, который легко понять и проанализировать, используйте LISP или что-то еще». Я бы не согласился с этим. Лисп анализировать тривиально, но именно из-за этого - потому что он был создан в то время, когда знание синтаксических анализаторов и принципов, лежащих в основе их построения, все еще находилось в зачаточном состоянии, и поэтому они наказали и пошли с самой нелепо упрощенной вещью это может сработать - вы не получите много синтаксических преимуществ современных языков. Так что это легко разобрать, но совсем не легко понять . Есть причина, по которой люди называют это «потерянными в лишних скобках».
Мейсон Уилер
9
@MasonWheeler Это дело вкуса - так его называли программисты на C, а не LISPers: P. Подсчитайте скобки - их примерно столько же, сколько в вашей типичной программе на C ++. Реальная разница заключается в их позиции ( myFunc()против (myFunc)), и на это есть очень веская причина. Языки на основе LISP по-прежнему очень популярны, особенно среди математиков и физиков. Главное в том, что языки LISPy очень незнакомы современным программистам в стиле C, но вряд ли это причина игнорировать это. Scheme, Clojure и, в некоторой степени, языки на основе ML (OCaml, F # ...) действительно очень LISPy.
Луаан
4
@Luaan Я могу с уверенностью сказать, что LISP НЕ популярен в физике. Двумя доминирующими языками в этой области являются FORTRAN и C ++. FORTRAN «популярен», потому что в нем написано так много старых кодов, но почти все новые программы написаны на C ++. Как физик-исследователь, я ни разу не сталкивался и даже не слышал о программе LISP. Не сказать, что они не существуют, но языки определенно не популярны .
Джеймс Матта
4
@Luaan Мы можем или не можем нуждаться в большем количестве разработчиков программного обеспечения. Нам определенно не нужно больше выпускников CS. Это все равно что сказать: «Нам нужно больше инженеров-строителей, поэтому нам нужно больше выпускников по теоретической физике».
Майлз Рут
4
@ user1717828 Это позволяет избежать восхитительных эффектов опечатки if (myField == null)as if (myField = null), которая прекрасно скомпилирует C / C ++, но, вероятно, не сделает то, что вы хотели. С другой стороны, if (null = myField)выдаст ошибку, так как вы не можете присвоить константу.
Wlerin
94

Я отвечу на ваши вопросы по порядку.

  1. Если Java не предоставляет функцию, которая есть в C ++, это означает, что эта функция не очень хорошая, поэтому мы должны отказаться от ее использования.

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

  1. Код C ++ со специальными функциями C ++ (например, функции-друзья, множественное наследование) может поддерживаться или проверяться только программистами C ++, но если мы просто напишем C ++, как Java (без специфической для языка C ++ функции), код может поддерживаться или проверяться обоими C ++ и Java программисты.

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

  1. Вас могут попросить преобразовать код в Java когда-нибудь

Правда! Но зачем останавливаться на Java? Вас могут попросить преобразовать код в базовый, ассемблер и / или Perl один день. Поскольку на каждом языке есть интерпретаторы perl, просто напишите свою программу в виде длинной строки perl и добавьте в нее аргументы на выбранном языке.

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

  1. Код без специфических особенностей C ++ обычно более удобен в обслуживании

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

  1. Каждая особенность языка C ++ (например, множественное наследование) должна иметь альтернативы для реализации в Java. Если это не так, значит, шаблон проектирования или архитектура кода проблематичны.

Особые возможности языка C ++ на самом деле полезны. Поскольку они не Ява, они анафема, и те, кто использует это, могут быть заклейменными еретиками. Если бы в C ++ не было этих языковых функций, вы бы не смогли найти тех, которыми нужно пожертвовать. Особенности языка C ++ решают проблемы!


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

Java была разработана частично как реакция на некоторые злоупотребления функциями C ++. Это не означает, что реакция была оправданной, особенно спустя годы, когда функции стали более зрелыми.

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

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

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

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

Многие особенности C ++ - это чудеса обслуживания. Стирание типа (например std::function) позволяет вам отделить иерархии, что уменьшает зависимости. Интеллектуальные указатели и детерминированные времена жизни, а также RAII уменьшают неожиданности времени выполнения и убирают шаблоны ресурсов с пути. Тяжелые статические проверки типов означают, что код не компилируется, а не работает. Дополнительные модули уменьшают дублирование кода. ADL позволяет независимое независимое расширение интерфейсов между иерархиями типов. Лямбда позволяет вам написать код рядом с тем, где он используется. Пересылка и перемещение уменьшают количество копий и делают программирование в функциональном стиле (без побочных эффектов) эффективным. Перегрузка оператора снижает шум в линии и делает код более похожим на математическую модель, которую он моделирует.

Остерегайтесь ямы Тьюринга. Вы можете реализовать все на любом языке (включая необработанную машину Тьюринга с лентой), но это не значит, что вы должны это делать . Эмуляция функций C ++ с использованием конструкций Java-esque в C ++ - ужасная идея; это приведет к не поддерживаемому коду, который никто не сможет прочитать или понять.

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

Современный C ++ не так уж похож на язык, который эмулирует и отвергает Java. Не зацикливайтесь на особенностях одного языка; нет "одного истинного языка". Узнайте о новых языках и их особенностях, и впитайте их отличительные особенности.

Yakk
источник
1
-1, многословно и непонятно.
Джечлин
4
-1 аргумент, аргумент соломенного человека
user949300
28
+1, правильная деконструкция задаваемых вопросов и я смеялся :)
кошка
11
+1. Веселый, но держит точку. Очень ясно для людей, которые на самом деле читают это.
Луис Масуэлли
14
«Программирование на пересечении C ++ и Java приводит к коду, который отбросил большинство преимуществ обоих языков». Попал в самую голову! +1
Ajedi32
56

Я просто отвечу на твои причины:

  1. Я не понимаю, как вы пришли к такому выводу. Разные языки имеют разные особенности. Зависит от объема, архитектуры языка, иногда предпочтений создателей и многих других причин. Некоторые особенности языка могут быть плохими, но ваше обобщение совершенно неверно ИМХО.
  2. Написание C ++ так же, как Java, может привести к ухудшению кода. Например, в настоящее время с C ++ 11 я избегаю использования new / delete, но использую общие указатели. В вашем сценарии я бы полагался только на новый / удалить. Если ваши программисты понимают только Java, обучайте их или нанимайте лучших.
  3. Это может случиться? Почему бы вам не написать на Java в первую очередь? Я думаю, что переписывать программы с нуля на новом языке, как правило, плохая идея, и вам нужно действительно хорошее обоснование для такого риска.
  4. Это всего лишь предположение.
  5. ИМХО сильно зависит от вашего сценария или варианта использования.
Саймон
источник
27
И Java-программисты тоже не будут использовать delete.
Паŭло Эберманн
8
Я должен был исправить утечки памяти, вызванные программистами Java, не знающими о delete. Насколько я помню, по крайней мере в одном из этих случаев динамическое распределение ( new) также не требовалось.
Итан Камински
16
@EthanKaminski Да, именно так вы можете легко найти новичка в C ++, особенно кого-то, кто имеет опыт работы с Java или подобный. Прекратите использовать новое для всего, черт возьми!
Луаан
1
@ PaŭloEbermann Да, еще хуже.
Симон
1
«В вашем сценарии я бы полагался только на new / delete» - забавно, я бы подумал, что идиома «++ (like) -features only» C ++ будет использоваться исключительно make_shared.
Кайл Стрэнд
26

В Java есть функции, которых нет в C ++, такие как встроенный, быстрый и надежный сборщик мусора, иерархия объектов с одним корневым объектом и мощный самоанализ.

Другие функции Java предназначены для совместной работы с эксклюзивными функциями Java, и многие из упущений Java функций C ++ возможны, потому что новые функции восполняют недостаток. Например, Java не имеет выделенных в стек объектов с детерминированными деструкторами, но имеет наконец блоки (и try-with-resources начиная с Java 7) и сборщик мусора, чтобы восполнить этот недостаток.

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

Java имеет всеобъемлющую иерархию объектов, в которой каждый класс в конечном счете является производным от Object, и несколько примитивных типов могут быть автоматически упакованы в такие классы. Это позволяет писать контейнеры объектов один раз, чтобы хранить указатели на объект. Java 5 представила дженерики, которые избавляют от приведений, которые требуются в таких контейнерах, но по-прежнему компилируются практически в один и тот же код.

C ++ не имеет такой иерархии. Чтобы облегчить написание контейнеров, которые работают для нескольких типов, вы используете шаблоны, которые представляют собой чертежи, которые создаются компилятором по мере необходимости для разных типов. Запретите ли вы использование шаблонов (и макросов) и пойдете по пути C: либо снова и снова пишите один и тот же код контейнера для разных типов, либо используйте указатели void? (Подождите, у Java нет пустых указателей!) Вы уверены, что это повысит удобство обслуживания?

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

Это не значит, что вы не должны ограничивать разрешенные функции C ++. C ++ - это большой исторически сложившийся язык, в котором подчеркивается, что программист должен делать то, что он хочет, над безопасностью и простотой использования, и не все его функции во всей их гибкости необходимы для создания хороших программ. Существует много стандартов кодирования, которые ограничивают использование некоторых функций; например, руководящие принципы Google по большей части запрещают множественное наследование, сложные шаблоны и исключения (хотя последний по историческим причинам). Но никакая функция не запрещена «потому что у Java ее нет»; функции рассматриваются только в рамках C ++.

Себастьян Редл
источник
27
Опытные ветераны C ++ обычно отвергают правила Google по кодированию. Современный C ++ намного лучше именно потому, что он использует эти функции. Да, это делает его еще более отличным.
Ян Худек
17
Обратите внимание, что в C ++ нет блоков finally, но есть RAII, что в большинстве случаев намного лучше. И опять же разные.
Ян Худек
7
Java в Objectзначительной степени подходит void*для большинства применений.
Квентин
1
Помимо выбора функций, существует вопрос стиля и идиомы. Программы, как правило, легче читать и поддерживать, если они используют обычные идиомы для языка, на котором они были написаны. Даже если бы кто-то мог написать часть программы на C ++, используя только Java-подобные функции, результат был бы странным, бессмысленным C ++.
Патриция Шанахан
2
Я бы поддержал этот ответ за то, что он на правильном пути («не делай этого»), но я не могу согласиться с основной предпосылкой, что Java как-то «более продвинута», чем C ++. C ++ не нуждается в сборщике мусора или иерархии объектов с одним корнем, точно так же, как Java не нуждается ... эээ ... извините, я не знаю, как закончить предложение, потому что мне не хватает детерминированных деструкторов в Java, и finallyне замена для них. Два языка просто принципиально разные.
DevSolar
25

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

Различия между Java и C ++ намного глубже, чем детали, на которых вы, кажется, сосредоточились.

Например, вы говорите о запрете множественного наследования в C ++. Во-первых, я укажу, что это просто упущение. Java определяет «интерфейсы» как отдельные вещи от «классов». Один класс наследует только от одного другого класса, но может реализовывать произвольное количество интерфейсов.

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

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

Если вы действительно хотите код, который в основном «Java использует синтаксис C ++», вам почти наверняка придется запретить что-либо и все, что похоже на последнее. Вам нужно будет ограничить использование шаблонов примерно до уровня «контейнера T», который поддерживают дженерики Java. К сожалению, выполнение этого приведет к тому, что код C ++ станет таким беспорядком, что никто не сможет поддерживать его таким, каким он существует сейчас, не говоря уже о долгосрочной возможности перевести его на какой-то другой язык программирования.

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

Джерри Гроб
источник
Многие функции C ++ могут быть использованы в некоторых случаях, которые хорошо соответствуют концепциям Java, а другие - нет. Некоторым частям программы потребуется что-то за пределами перекрывающегося подмножества функциональных возможностей языков, и попытка написать такие части, как «Java с использованием синтаксиса C ++», приведет к ужасному беспорядку. С другой стороны, многим другим частям кода может понадобиться что-то за пределами общего подмножества, и попытка остаться в общем для тех частей кода, где нет веских причин выходить за пределы, может оказаться полезной.
суперкат
Предположительно, когда вы говорите «может понадобиться», вы действительно имеете в виду: «может не нуждаться»? Если так, то я бы согласился.
Джерри Коффин
Ага. Если возникнет необходимость в поддержке платформы, которая поддерживает Java, но не C ++, части кода почти наверняка придется переписывать с нуля, и не будет иметь значения, были ли эти части написаны с использованием некоторых дружественных к Java техник, поскольку они ' все равно будет переписан. Однако может быть возможно написать другие части таким образом, чтобы их можно было перенести без полного переписывания, и в некоторых случаях дополнительные затраты, необходимые для этого, могут быть минимальными.
суперкат
4
@supercat: OTOH, учитывая количество платформ, которые поддерживают Java, но не C ++, это кажется мне почти полностью решением проблемы.
Джерри Коффин
Некоторое время поддержка браузеров для апплетов Java была лучше, чем для апплетов C ++. Тем не менее, поддержка браузером JavsScript (никакого отношения к Java) улучшилась настолько, что она в основном перешла от обоих.
суперкат
11

Если вы собираетесь писать код на языке X, потратьте время на то, чтобы правильно выучить язык и использовать все его возможности, чтобы помочь вам решить проблему. Плохие вещи случаются, когда вы пытаетесь сделать дословный перевод с одного языка на другой, будь то японский на английский или Java на C ++. Гораздо лучше начать с хорошего понимания проблемы и выразить решение так, как это наиболее естественно для используемого языка.

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

Представьте, что наймете кого-нибудь, чтобы сохранить этот код в будущем. Если это хороший код C ++, вы сможете нанять компетентного разработчика C ++, и он сможет найти способ обойти это. Если это «Java в C ++», то ни C ++, ни Java-разработчики не будут легко понимать код.

Том Пенни
источник
7

Все ваши причины могут быть опровергнуты:

Если Java не предоставляет функцию, которая есть в C ++, это означает, что эта функция не очень хорошая, поэтому мы должны отказаться от ее использования.

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

Код C ++ со специальными функциями C ++ (например, функции-друзья, множественное наследование) может поддерживаться или проверяться только программистами C ++, но если мы просто напишем C ++, как Java (без специфической для языка C ++ функции), код может поддерживаться или проверяться обоими C ++ и Java программисты.

О, это может быть? Давайте посмотрим простейший код C ++:

int len = mystring->size();

К сожалению, никакие «специфичные для языка» функции не используются, но они уже не поддерживаются разработчиками Java! Потому что в Java вы разыменовываете с "." пока здесь это "->.

Вас могут попросить преобразовать код в Java когда-нибудь

Или C #. Или Хаскелл. Или Питон. Или Рубин. Или КОБОЛ (да, вы можете!). Как вы можете сказать будущее?

Код без специфических особенностей C ++ обычно более удобен в обслуживании.

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

Каждая особенность языка C ++ (например, множественное наследование) должна иметь альтернативы для реализации в Java. Если это не так, значит, шаблон проектирования или архитектура кода проблематичны.

Но Java имеет множественное наследование! Это называется «интерфейс». Реализация Java - проблемный обходной путь, чтобы избежать страшного алмаза, вызванного тем, что все происходит из-за Object. Это делается путем введения, interfaceединственной целью которого является быть чем-то, что не происходит от Object. В C ++ никогда не было этой проблемы - нет обязательной общей базы, поэтому каждый класс может функционировать как интерфейс без страшного ромба.

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

Вы также упомянули лишь несколько «вещей, которые есть у C ++, но у Java нет». Одним из самых больших различий между C ++ и Java является контроль над расположением памяти. Вы можете создать массив указателей на объекты (как в Java) ИЛИ вы можете создать непрерывный блок памяти. Теперь, если бы я беспокоился о функции C ++, которая может вводить в заблуждение разработчиков Java, что-то столь же скрытое и тонкое, как это, заняло бы место в моем списке намного выше, чем очевидное и узнаваемое на первый взгляд, как множественное наследование или перегруженные операторы.

Итог: чистый код - это чистый код. Java или C ++ - такая же разница. Просто будь проще. Ненужные осложнения являются основной причиной плохого кода.

Agent_L
источник
Java предлагает некоторые функции и гарантии, которые не поддерживаются в языке, который предлагает все функции C ++. Язык не может, например, разрешить динамическую загрузку типов и полный спектр приведений к сохранению идентичности в Java, предлагая обобщенные формы множественного наследования, включенные в C ++.
суперкат
@supercat Я не понимаю, почему ты говоришь это здесь. Вопрос не в возможностях Java, которые не могут быть воспроизведены в C ++, а в том, что касается функций C ++, от которых отказались в Java.
Agent_L
Я хочу сказать, что некоторые функции Java не включены в C ++, а скорее, что некоторые функции Java принципиально несовместимы с другими функциями, включенными в C ++, так что ни один язык не может иметь типы, поддерживающие оба (языки, такие как C ++ / CLI). есть типы, которые поддерживают функции C ++, и типы, которые поддерживают функции Java-ish, но они эффективно занимают отдельные юниверсы с ограниченной функциональной совместимостью).
суперкат
6

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

С одной стороны, Java является сборщиком мусора и, следовательно, не имеет эквивалента ключевого слова C ++ "delete". Итак, вы реализуете программу без удаления, потому что по вашим правилам это не разрешено.

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

Аналогично, в Java нет ничего похожего на указатели C ++, что исключает множество общих соглашений о вызовах функций.

В C ++ есть особенности, которых вы, возможно, следует избегать (см. Ниже), но «не быть в Java» не является хорошим лакмусовым тестом.


Лучшее руководство будет следующим:

  1. Напишите код, соответствующий вашему языку, среде и инструментам.
  2. Напишите код, понятный вашей команде .
  3. Убедитесь, что ваша команда компетентна в данной области.

Пункт (3) означает, что вы не должны иметь код Java-программистов на C ++ без обучения их на C ++. Есть некоторые тонкие, но очень важные различия, которые они могут не узнать, если они пытаются трактовать это как странный диалект Java.

Пункт (2) означает, что, если вашей команде, в частности, неудобно множественное наследование (например), и если существует адекватное решение, которое его не использует, то может быть лучше использовать это альтернативное решение. Однако это зависит именно от вашей команды. С другой стороны, если вашей команде больше неудобно с этим альтернативным решением, чем с множественным наследованием, используйте множественное наследование!


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

Итан Камински
источник
6

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


Если Java не предоставляет функцию, которая есть в C ++, это означает, что эта функция не очень хорошая, поэтому мы должны отказаться от ее использования.

На этот вопрос довольно хорошо ответили: Java не является «хорошими частями» C ++, и нет никаких причин так думать.

В частности, хотя достоинства каждой отдельной функции C ++ являются дискуссионными, многие из функций C ++ 11 / C ++ 14, которые не являются частью Java, не обязательно исключаются, поскольку дизайнеры Java считают их плохой идеей. Например, до версии 8 в Java не было лямбд, но они были представлены в C ++ в стандарте C ++ 11. До Java 8 ваше предположение о том, что функции C ++, отсутствующие в Java, отсутствовали по проекту, потому что они «не хороши», подразумевало бы, что лямбды как языковая функция «не хороши» (к ужасу LISPers везде, хотя они вероятно, в ужасе, чтобы услышать, что вам, видимо, на самом деле нравится Java). Но теперь Java-дизайнеры разместили свой штамп одобрения (TM) на лямбдах, так что теперь они A Good Thing.

Чтобы глубже вникнуть, даже в Java 8, лямбда-выражения-замыкания не так гибки, как лямбда-выражения C ++ 14, но это может быть связано с ограничениями архитектуры JVM, а не с сознательным решением о том, что более гибкий подход плох из-за Перспектива языкового дизайна.


Код C ++ со специальными функциями C ++ (например, функции-друзья, множественное наследование) может поддерживаться или проверяться только программистами C ++, но если мы просто напишем C ++, как Java (без специфической для языка C ++ функции), код может поддерживаться или проверяться обоими C ++ и Java программисты.

Это главное, на что я хотел ответить.

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

Тем не менее, это не тот случай, когда такого рода рецензии когда-либо будут «столь же хороши, как» или «эквивалентны» рецензии от разработчиков, которые фактически знают язык, который вы используете. По существу, это происходит потому , что делает один язык вид похож на другой, как правило , скрывают тонкие различия, делая один язык , ведут себя , как другой (особенно в случае C ++ и Java) может быть не-идиоматических для языка и / или может оказаться слишком запутанной для рецензентов.

Во-первых, давайте подумаем о том, что значит сделать C ++ «похожим» на Java. В простом случае вы можете использовать newдля создания объектов, как в Java:

Foo foo = new Foo();

Но объекты, созданные таким способом, используют ->вместо .вызова методов, поэтому, если вы хотите, чтобы вызовы методов выглядели как Java, вы должны вместо этого написать:

Foo& foo = *new Foo();

Но это не идиоматично; в частности, память должна быть позже очищена с использованием delete &foo, что некоторые опытные разработчики C ++ могут даже не осознавать, что это законный код . В любом случае, есть смешные , не Java-подобные символы пронизывают, поэтому мы не можем достаточно сделать язык «выглядеть» Java. (Вы можете отказаться от *newиспользования #define New *newили, что еще хуже, #define new *newно тогда вы просто умоляете своих коллег-разработчиков ненавидеть вас.) И, как упоминалось выше, deleteв Java не существует, так что в любом случае (как упоминалось в другом ответе) ) вы никогда не сможете заставить объект «выглядеть» так, как в Java, без утечек памяти.

Но современный C ++ включает в себя интеллектуальные общие указатели, которые во многом похожи на управляемые памятью ссылки на переменные в Java. Поэтому везде, где вы можете писать на Java Foo foo = new Foo();, вы можете написать:

std::shared_ptr<Foo> foo = std::make_shared<Foo>();

Теперь вы используете языковую функцию, которая на самом деле очень похожа на Java. Но вдруг вам есть что объяснить рецензентам, не относящимся к C ++: что это за shared_ptrштука? Какие тонкие хитрые "ошибки" из make_shared? (Он использует совершенную пересылку, которая имеет некоторые случаи сбоя и может привести к вызову «неправильного» конструктора.) Почему необходимо вызывать методы с помощью ->, но .компилятор допускает использование с некоторыми методами? ( shared_ptrимеет свои собственные методы.) Если метод Foo::reset(void)существует, неосторожный разработчик может попытаться вызвать его с помощью foo.reset()которого (если имеется только один общий указатель, указывающий на тот случай, Fooкогда происходит вызов) удалит базовую память и обнулит foo, а также Java-разработчики вряд ли поймут эту проблему.

Кроме того, C ++ имеет много из ловушек , которые специфические для языка, Насколько я могу судить, большинство разработчиков C ++ учатся справляться с этими подводными камнями, постепенно разрабатывая свою собственную идиому для «безопасных» практик C ++, которая часто несколько уникальна для них или для их команды разработчиков (см., Например, существующий ответ, в котором упоминается Практика кодирования Google и комментарий к ней гласят, что «Опытные ветераны C ++ обычно отвергают правила кодирования Google»). Все утверждения о том, что язык может быть слишком сложным, кажется (по моему опыту, по крайней мере), обычно встречаются с некоторым изменением «ну, перестань использовать его неправильно». Я понимаю, что это крайне негативное мнение сообщества C ++, и, конечно, есть опытные разработчики, более охотно помогающие изучающим язык, но они Кажется, это определенная защита, например, в отношении неопределенного поведения (см., например, большую часть обсуждения в моей ссылке «Подводные камни» выше).

Java-разработчики просто не помогут найти и исправить эти ошибки с помощью анализа кода.


Вас могут попросить преобразовать код в Java когда-нибудь.

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

Но, во-первых, это конкретное соображение кажется отдаленной возможностью: код, как правило, либо повторно используется как есть (например, вы можете подключить часть или весь работающий код C ++ в какое-то будущее программное обеспечение Java с использованием интерфейса JNI), либо переписать полностью чем напрямую вручную «транскрибировать».

И, во-вторых, вы позже говорите,

Каждая особенность языка C ++ (например, множественное наследование) должна иметь альтернативы для реализации в Java ....

Это по существу отменяет вашу точку «конвертировать в Java». Если программное обеспечение написано на идиоматическом C ++, а затем преобразовано в идиоматическую Java, нет никаких оснований ожидать, что это преобразование будет (или могло бы!) Быть выполнено путем применения точного однозначного отображения функций C ++ к функциям Java.


Код без специфических особенностей C ++ обычно более удобен в обслуживании.

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

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

ПОЖАЛУЙСТА, ОБРАТИТЕ ВНИМАНИЕ: Если вы фанат C ++ и вы добрались до этого момента в моем ответе и чувствуете склонность перейти к комментариям, чтобы доказать, что автор FQA на самом деле не понимает C ++ или неискренен в большинстве своих аргументов Обратите внимание, что (1) ровно через два предложения после того, как я его цитирую, я признаю, что FQA - это очень предвзятый источник, и (2) не имеет значения, что я пытаюсь сказать, понимает ли автор FQA C ++ и я не пытаюсь использовать C ++, и вы должны прочитать остальную часть поста, не предполагая, что я анти-C ++ только потому, что я цитировал FQA. Конец примечания.

Точно так же Линус Торвальдс ненавидит C ++ по существу по этой причине (предупреждение: ссылка включает в себя много ругательств в истинно печально известном стиле Линуса).

Очевидно, что это очень предвзятый подход к делу, но даже сторонники C ++ часто говорят, что вам не следует использовать весь набор языковых функций (еще раз, см. Рекомендации по кодированию Google; также, Бьярн Страуструп, создатель C ++) публично заявил: «В C ++ существует гораздо меньший и более чистый язык, изо всех сил пытающийся выйти»).

Поэтому я думаю, что есть некоторая заслуга в том, что функции C ++ могут быть слишком просты для неправильного использования, особенно если вы работаете в Java. Кроме того, есть смысл в том, чтобы облегчить эти проблемы, ограничив себя каким-то подмножеством языка.

Однако решение о том, какое подмножество использовать на основе другого языка, не кажется правильным подходом, если только «другой язык» не является C, поскольку в действительности существует C-подобное подмножество языка C ++. (Линус ссылается на это в своей статье выше, а Скотт Мейерс даже называет это подмножество «подъязыком».) Парадигма времени выполнения Java (сборщик мусора, работающий на виртуальной машине) настолько принципиально отличается от C ++, что это Не ясно, есть ли какие-то полезные уроки, которые можно извлечь из использования C ++, и, как отмечалось выше, попытка извлечь уроки о C ++ непосредственно из Java может привести к очень неидиоматическому коду.

Вместо этого попытайтесь определить свое «приемлемое подмножество» языка, понимая, как язык можно использовать идиоматически. Если вы хотите получить довольно ограниченное подмножество, которое по-прежнему использует многие из функций C ++, помимо того, что предлагает C, вышеупомянутая рекомендация по Google Coding может быть хорошим началом. Конечно, вы получите разработчиков, которые скажут, что для некоторых ограничений Google «нет рациональных аргументов» , но если вы не хотите нанимать Александреску подальше от его работы над языком D (который сам должен вам что-то сказать), это наверное хорошо Это, безусловно, лучше, чем пытаться превратить C ++ в Java.

Еще одна хорошая отправная точка для набора рекомендаций по коду - это новые основные принципы C ++ , работа которых ведется Бьярном Страуструпом и Хербом Саттером.

Единственный другой способ справиться с недостатками C ++ - это выбрать другой язык. Похоже, вам нравится Java, и вы думаете, что есть шанс, что этот проект в конечном итоге может быть преобразован в Java. Как отмечено в другом ответе, вы можете просто ... начать с Java.

Есть две причины, по которым вам действительно может понадобиться что-то, кроме Java:

  1. Вам действительно нужна производительность во время выполнения. В этом случае обращение с C ++ как с Java, вероятно, на самом деле вам не поможет, потому что Java-подобные методы, такие как shared-указатели, снижают вашу производительность во время выполнения.
  2. Вам нужно программное обеспечение для работы на малоизвестной платформе, которая еще не поддерживает JVM. В этом случае вы, вероятно, застряли с языками, которые имеют интерфейсы GCC или Clang. C и C ++ являются очевидными кандидатами, но вы также можете посмотреть что-то вроде Rust. (Быстрый плагин: я не использовал Rust широко, но он выглядит потрясающе, и мне не терпится поработать над крупным проектом Rust, как только я смогу, и я думаю, что все, кто рассматривает возможность запуска проекта C ++, должны рассмотреть Rust в качестве альтернативы.)

Каждая особенность языка C ++ (например, множественное наследование) должна иметь альтернативы для реализации в Java. Если это не так, значит, шаблон проектирования или архитектура кода проблематичны.

Я уже несколько об этом говорил, но намеренно пропустил ваше второе предложение.

Я не уверен, что что-то подобное constexpr, что не имело бы никакого смысла в частично JIT-языке, таком как Java, указывает на неверную архитектуру. Я более открыт к идее, что чрезмерное использование шаблонного метапрограммирования может быть более сложным, чем оно того стоит, особенно сейчас, когда constexprсуществует оценка функций во время компиляции, но из случая видно, constexprчто нет недостатка в дизайне, если вы вы используете его: вы просто гарантируете, что некоторые вычисления выполняются еще до запуска кода, что является огромным приростом производительности (см., например, эту запись для проблемы n-body в The Benchmark Game , которая превосходит все остальные записи, кроме другой написанный на C ++,

Кайл Стрэнд
источник
5
Автор FQA определенно попадает в группу «понимают не более 20% языка». Там есть несколько ответов, которые на самом деле неверны, и еще куча ответов, которые просто упускают суть, проиллюстрированные на примере «соломенный человек».
Бен Фойгт
2
Многие (почти все?) Жалобы в C ++ FQA - чепуха. Современные языки огромны. C ++ довольно мал по сравнению с Python, Ruby, Perl и, да, Java. Задайте основной вопрос на этих языках на StackOverflow и первый ответ почти неизбежно вдоль линий «Почему ты не import SomeVeryBasicPackageи просто сделать это ?» Задайте продвинутый вопрос и первый ответ почти неизбежно вдоль линий «Почему ты не import SomeMagicalPackageи просто делать что
Дэвид Хаммен
1
@DavidHammen Я думаю, что разделение 80/20 относится к базовым языковым функциям, а не только к стандартным компонентам библиотеки, и в этом случае упомянутые вами языки, за исключением, возможно, Perl, на самом деле не кажутся такими большими и сложными, как C ++. В любом случае, это была очень маленькая часть моего ответа, и я признал, что это необъективный источник.
Кайл Стрэнд,
1
Виртуальные / управляемые языки, очевидно, намного сложнее под поверхностью, но я имею в виду сложность с точки зрения использования.
Кайл Стрэнд
1
Я понятия не имею, верна ли ваша теория, хотя в моем случае я определенно изучал C ++ и C по отдельности, и мой класс C ++ был действительно довольно тщательным. Но полная цитата о расхождении 20/80 состоит в том, что каждый программист знает разные 20% языка, что не объясняется большинством программистов, которые изучают часть языка C независимо. Во всяком случае, если вы хотите подробно объяснить, как C ++ позволяет более надежное программирование (я утверждаю, что я видел раньше, но не понимаю), мы, вероятно, лучше сделать это в чате или чем-то, а не в комментариях здесь ,
Кайл Стрэнд,
5

Предположим, я ограничен в использовании C ++ средой в проекте. Хорошо ли предотвращать использование некоторых языковых функций, которые есть в C ++, но нет в Java (например, множественное наследование, переопределение операторов)?

Нет.

Если «из-за среды проекта» вы ограничены использованием C ++, то нет смысла даже думать о какой-либо другой технологии, независимо от того, насколько вы лично предпочитаете / надеетесь ее использовать / пропагандировать.
Независимо от того, поддерживает ли «Технология X» или «Y» какую-либо конкретную функцию, не должно быть никакого отношения к тому, как вы создаете свое приложение C ++.
Это приложение на C ++, предположительно для некоторой «доброй причины» (сейчас или в прошлом), поэтому вы должны написать его как приложение C ++, используя все, что обеспечивает этот конкретный «инструментарий».

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

Подобные дебаты («использовать или не использовать») проводились несколько лет назад в мире Visual Basic [.Net], где у кого-то возникла блестящая идея, что вы должны писать приложения на Visual Basic без использования какого-либо [основного языка] функциональность, предоставляемая пространством имен Microsoft.VisualBasic. Это все равно что пытаться написать приложение на C ++ без пространства имен std ::; Хорошо, это возможно, но с какой стати кто-то в здравом уме потрудится сделать это?

Фил В.
источник
1
К вашему последнему замечанию о Visual Basic: проблема с такими библиотеками поставщиков заключается в том, что они являются проприетарными. Использование их означает приковывание себя к этому поставщику. Поставщику понравится, что вы прикованы цепью, но в долгосрочной перспективе вы этого не сделаете: вы не сможете использовать программное обеспечение другого поставщика, не переписав все, что зависит от его функциональности. Чем больше вы используете специфичную для поставщика функциональность, тем выше становится стоимость смены поставщиков, что позволяет вашему поставщику навязывать вам изменения. Это одна из причин, по которой свободное (как и в случае свободы!) Программное обеспечение имеет большое значение.
Мастер
Пространство Microsoft.VisualBasicимен немного растянуто. Прошло много лет с тех пор, как я последний раз использовал его, но, по крайней мере, вначале он был нацелен на обратную совместимость с VB6 (и / или чтобы программисты VB6 чувствовали себя «как дома»); в основном это обеспечивало функциональность, которая уже была доступна в остальной части фреймворка в более современной (и лучше интегрированной) форме, поэтому в новых проектах редко имело смысл использовать ее. Напротив, std::пространство имен находится там, где находится вся стандартная библиотека - избегать его - все равно, что избегать всего BCL в .NET.
Маттео Италия
2

Все текущие ответы говорят, что это плохая вещь, так как вы должны воспользоваться языком, который вы используете, а также объяснить, почему функция C ++ не является «плохой» только потому, что она не в jave. Я отвечу на это под другим углом.

Одно дело избегать сложных функций C ++, таких как множественное наследование, перегрузка операторов и определение собственного шаблона.

Но любая проблема, которая делает больше, чем самая простая задача:

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

Не существует общего подмножества Java и C ++, которое допускает вышеизложенное, поэтому то, что вы просите, сделать невозможно. (Если бы вы спрашивали о Java и C #, у вас было бы гораздо больше шансов, так как они оба использовали сборщики мусора.)

Однако вы можете потребовать, чтобы код был написан так, чтобы Java-разработчик мог понять, что делает (но не детальное «как»), и это было бы разумно.

Вы также можете создать свой собственный язык, который вы реализовали в C ++ и JAVA .....

Ян
источник
0

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

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

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

Это был аргумент о проблемах перехода программистов на BASIC на объектно-ориентированные языки. Дело не в том, что они внедряют ООП-практику в ущерб новым разработчикам, которые этого не понимают, а в том, что они вообще не реализуют это. Если они это делают, они обычно ошибаются. Если что-то сделано плохо, его нужно удалить независимо от причины.

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

JeffO
источник