ALT Linux Team development discussions
 help / color / mirror / Atom feed
From: "Evgeny Sinelnikov" <sin@altlinux.ru>
To: "ALT Linux Team development discussions" <devel@lists.altlinux.org>
Subject: Re: [devel] Управление группами пользователя
Date: Sun, 16 Nov 2008 21:39:12 +0300
Message-ID: <921f6bb40811161039x7a781d97p79e78d8c753c1ae6@mail.gmail.com> (raw)
In-Reply-To: <47c0071b0811160946t75d174b3if319ef0fe41305c9@mail.gmail.com>

16 ноября 2008 г. 20:46 пользователь Dmitriy M. Maslennikov
<maslennikovdm@gmail.com> написал:
> 16 ноября 2008 г. 19:50 пользователь Andrey Rahmatullin
> <wrar@altlinux.ru> написал:
>> On Sun, Nov 16, 2008 at 07:39:08PM +0300, Dmitriy M. Maslennikov wrote:
>>> Согласен. Но все-таки, чем С++ плох? Хочется услышать именно
>>> конструктивную критику, а не заявления, типа, "плох и все".
>> http://yosefk.com/c++fqa/ ? :)
> Основные проблемы, я так понял по ссылке:
> http://yosefk.com/c++fqa/defective.html
> По пунктам:
> - No compile time encapsulation
>  Это верно и для С, и для всех компилируемых языков, которые я знаю. А где это
>  есть? В С++ проблему обходят создавая для кождого класса foo класс fooPrivate,
>  и помещая в основной ссылку на него.
> - Outstandingly complicated grammar
>  Проблема писателей компиляторов. Очень плохо, не спорю, но сейчас
>  уже недостатка в качественных компиляторах С++ не ощущается.
> - No way to locate definitions
>  ИМХО, небольшая проблема, впрочем характерная и для С.
> - No run time encapsulation
>  Что ж для кого-то факт того, что С++ - unmanaged - проблема, для кого-то -
>  достоинство. Впрочем, к С это так же относится.
> - No binary implementation rules
>  Так как у нас используется только один компилятор gcc-c++, то эта проблема
>  несущественна. В случае использования нескольких компиляторов, да, мне
>  это тоже не нравится.
> - No reflection
>  Ну что ж теперь. Нет, так нет) У С тоже reflection нет.
> - Very complicated type system
>  Да, С++ сложный язык, никто не спорит. Даже черезчур, согласен.
> - Very complicated type-based binding rules
>  Опять жалоба на то, что типов много, что при перегруженных функциях может
>  породит несколько экранов ошибок. Ну что ж, за гибкость надо платить.
> - Defective operator overloading
>  По сути говорят, что переопределять операторы так сложно, что мы ошибаемся
>  и у нас течет память и прочее. Что ж, не перегружайте).
> - Defective exceptions
>  Не совсем понял суть притензий к исключениям...
> - Duplicate facilities
>  На мой взгляд - не проблема. Проблема только на этапах обучения. Ну и
>  нехорошо, конечно, что многие библиотеки создают собственные строки,
>  списки и подобное. Впрочем в С это тоже делается для каждого проекта.
> - No high-level built-in types
>  Притензия к тому, что из-за того, что все высокоуровневые возможности не
>  встроены в язык, а реализованы на нем, нельзя инициализировать списки в
>  исходном коде коде, ну и как всегда: "компилятор выдает много ошибок".
>  Не считаю проблемой.
> - Manual memory management
>  Извечный и очень спорный вопрос, впрочем в С тоже памятью управляют
>  вручную.
> - Defective metaprogramming facilities
>  Ругают С макросы (именно ими метапрограммируется NSS :)) ). К счастью в
>  С++ это убожество не используется. Метапрограммирование на шаблонах
>  ругают так же. Если вспомнить историю, то создавались они не для этого, а
>  для обобщенного программирования. Метапрограммирование -- побочный
>  эффект, странно ожидать, что он случайно идеально впишется в систему.
>  Впрочем, то, что оно есть -- это хорошо.
> - Unhelpful standard library
>  Будем считать, что boost -- стандартная библиотека С++. А, вообще, в
>  случае создания довольно жирного десктопа (как в нашем случае)
>  недостатка в библиотеках на С++ не ощущается. Кроме того, доступны все
>  библиотеки для С.
> - Defective inlining
>  Ну некоторая придирка. Впрочем в С - тоже самое (если мы используем
>  макросы как функции)
> - Implicitly called & generated functions
>  Опять не уловил сути. Устал читать, видимо. Впрочем, все придирки
>  довольно стандартны.
>
> Вывод: С++ единственный язык полностью совместимый с С, но позволяющий
> оперировать высокоуровневыми конструкциями. Поэтому он прочно занял
> свою нишу, и я, таки, считаю, что он является прекрасной заменой С, в
> случае, если умело им пользоваться. Но из-за своей сложности он
> требует длительного изучения.
>
> Вопрос остается открытым: почему нельзя писать системные компоненты на С++?
>

После долго разговора в #altlinux, мне кажется, что я понял... :)

Проблема вот в чём. GCC и GLIBC - это стандартные компоненты. Но GLIBC
считается первичной, а GCC могут быть разными.

Так вот линковка системного модуля с libstdc++ одного ABI, который при
этом грузится динамически, потенциально может быть критична для тех
приложений, которые слинкованы с libstdc++ другого ABI. Это, вероятно,
может проявится и в случае со статической линковкой. Это можно и нужно
проверять, но проблема вроде бы очевидна, хотя детали мне не ясны -
буду смотреть... Не понятно тогда, а как же обходятся пропиетарные
приложения, линкуясь со старыми версиями GLIBC - ведь работают же :)

В этой потенциальной проблеме, как я понял, и состоит конструктиваня
критика технических аспектов реализации.

В общем, вопрос ставится так: "Крайне не желательно писать NSS-модули
на C++". Это связано в особенностями архитекутры NSS. Мне теперь надо
обдумать этот вопрос...

Я крайне разочарован тем, что вместо такого простого объяснения, мы
два дня препирались о применимости C++, как системного языка. К
сожалению, как мне кажется, призывая понять проблему, нас скорее
провоцировали, чем указывали на неё...

-- 
Sin (Sinelnikov Evgeny)

  parent reply	other threads:[~2008-11-16 18:39 UTC|newest]

Thread overview: 101+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2008-11-14 16:53 Dmitriy M. Maslennikov
2008-11-14 18:01 ` Alexander Bokovoy
2008-11-14 18:35   ` Dmitriy M. Maslennikov
2008-11-14 18:49     ` Alexander Bokovoy
2008-11-14 19:11       ` Dmitriy M. Maslennikov
2008-11-14 19:28         ` Evgeny Sinelnikov
2008-11-14 19:45         ` Alexander Bokovoy
2008-11-14 19:51           ` Dmitriy M. Maslennikov
2008-11-14 19:55         ` Led
2008-11-14 19:56           ` Dmitriy M. Maslennikov
2008-11-14 20:01             ` Led
2008-11-14 20:07               ` Stanislav Ievlev
2008-11-14 20:10                 ` Pavlov Konstantin
2008-11-14 20:20                   ` Stanislav Ievlev
2008-11-14 20:24                   ` Led
2008-11-14 20:28                     ` Stanislav Ievlev
2008-11-14 20:29                     ` Dmitriy M. Maslennikov
2008-11-14 22:00                       ` Денис Смирнов
2008-11-15  6:29                         ` Dmitriy M. Maslennikov
2008-11-16 14:40                           ` Stanislav Ievlev
2008-11-16 15:15                             ` Evgeny Sinelnikov
2008-11-16 15:54                               ` Alexander Bokovoy
2008-11-16 16:39                                 ` Dmitriy M. Maslennikov
2008-11-16 16:50                                   ` Andrey Rahmatullin
2008-11-16 16:52                                     ` Mikhail Gusarov
2008-11-16 17:46                                     ` Dmitriy M. Maslennikov
2008-11-16 17:54                                       ` Andrey Rahmatullin
2008-11-16 18:39                                       ` Evgeny Sinelnikov [this message]
2008-11-16 18:45                                         ` Led
2008-11-16 18:56                                           ` Evgeny Sinelnikov
2008-11-16 19:02                                             ` Dmitry V. Levin
2008-11-16 19:35                                               ` Dmitriy M. Maslennikov
2008-11-16 19:42                                                 ` Alexander Bokovoy
2008-11-16 19:49                                                   ` Evgeny Sinelnikov
2008-11-16 19:57                                                     ` Alexander Bokovoy
2008-11-16 20:04                                                       ` Dmitriy M. Maslennikov
2008-11-16 19:50                                                   ` Dmitriy M. Maslennikov
2008-11-16 19:56                                                     ` Alexander Bokovoy
2008-11-16 17:14                                   ` Alexander Bokovoy
2008-11-19 12:25                                   ` [devel] [JT] " Michael Shigorin
2008-11-19 12:38                                     ` Dmitriy M. Maslennikov
2008-11-19 13:35                                       ` Денис Смирнов
2008-11-19 13:44                                         ` Evgeny Sinelnikov
2008-11-19 13:44                                           ` Mikhail Gusarov
2008-11-19 13:54                                             ` Dmitriy M. Maslennikov
2008-11-19 14:12                                               ` Michael Shigorin
2008-11-19 14:15                                                 ` Mikhail Gusarov
2008-11-19 14:17                                                   ` Andrey Rahmatullin
2008-11-19 14:46                                                   ` [devel] [JT] " Michael Shigorin
2008-11-19 14:05                                           ` Michael Shigorin
2008-11-19 14:22                                           ` [devel] [JT] " Alexey I. Froloff
2008-11-19 14:25                                             ` Evgeny Sinelnikov
2008-11-19 14:28                                               ` Mikhail Gusarov
2008-11-19 15:27                                               ` Alexey I. Froloff
2008-11-19 16:33                                                 ` Evgeny Sinelnikov
2008-11-19 17:57                                           ` Денис Смирнов
2008-11-19 21:21                                             ` Evgeny Sinelnikov
2008-11-19 21:24                                               ` Денис Смирнов
2008-11-19 21:38                                                 ` Evgeny Sinelnikov
2008-11-19 21:26                                               ` Mikhail Gusarov
2008-11-19 21:39                                                 ` Evgeny Sinelnikov
2008-11-19 21:49                                                   ` Mikhail Gusarov
2008-11-20  8:53                                                     ` Evgeny Sinelnikov
2008-11-20  9:31                                                       ` Mikhail Gusarov
2008-11-20 13:21                                                         ` Evgeny Sinelnikov
2008-11-20 13:36                                                           ` Mikhail Gusarov
2008-11-20 15:48                                                             ` Evgeny Sinelnikov
2008-11-20 15:50                                                               ` Mikhail Gusarov
2008-11-20 15:44                                                           ` Alexey I. Froloff
2008-11-20 15:54                                                             ` Evgeny Sinelnikov
2008-11-20 15:57                                                               ` Damir Shayhutdinov
2008-11-20  7:33                                                   ` Andrey Rahmatullin
2008-11-19 21:52                                                 ` Mikhail Gusarov
2008-11-19 12:46                                     ` Alexey I. Froloff
2008-11-16 15:38                             ` [devel] " Dmitriy M. Maslennikov
2008-11-16 15:54                               ` Led
2008-11-16 18:08                           ` Dmitry V. Levin
2008-11-14 20:13                 ` Led
2008-11-19 12:20                 ` [devel] [JT] alterator (was: Управление группами пользователя) Michael Shigorin
2008-11-14 19:54       ` [devel] Управление группами пользователя Led
2008-11-14 19:10     ` Stanislav Ievlev
2008-11-14 19:52     ` Led
2008-11-14 19:54       ` Dmitriy M. Maslennikov
2008-11-14 19:59         ` Led
2008-11-14 20:03           ` Dmitriy M. Maslennikov
2008-11-14 20:09             ` Led
2008-11-14 20:11               ` Dmitriy M. Maslennikov
2008-11-14 20:06           ` Dmitriy M. Maslennikov
2008-11-14 20:14             ` Led
2008-11-14 20:24               ` Dmitriy M. Maslennikov
2008-11-14 20:58         ` Sergey Bolshakov
2008-11-14 22:25           ` Evgeny Sinelnikov
2008-11-16 20:07   ` Dmitry V. Levin
2008-11-16 20:17     ` Evgeny Sinelnikov
2008-11-16 23:44       ` Vitaly Lipatov
2008-11-17  0:29         ` Evgeny Sinelnikov
2008-11-14 20:16 ` Alexey I. Froloff
2008-11-14 20:23   ` Stanislav Ievlev
2008-11-14 20:37     ` Alexey I. Froloff
2008-11-16 14:44       ` Stanislav Ievlev
2008-11-14 20:26   ` Dmitriy M. Maslennikov

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=921f6bb40811161039x7a781d97p79e78d8c753c1ae6@mail.gmail.com \
    --to=sin@altlinux.ru \
    --cc=devel@lists.altlinux.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link

ALT Linux Team development discussions

This inbox may be cloned and mirrored by anyone:

	git clone --mirror http://lore.altlinux.org/devel/0 devel/git/0.git

	# If you have public-inbox 1.1+ installed, you may
	# initialize and index your mirror using the following commands:
	public-inbox-init -V2 devel devel/ http://lore.altlinux.org/devel \
		devel@altlinux.org devel@altlinux.ru devel@lists.altlinux.org devel@lists.altlinux.ru devel@linux.iplabs.ru mandrake-russian@linuxteam.iplabs.ru sisyphus@linuxteam.iplabs.ru
	public-inbox-index devel

Example config snippet for mirrors.
Newsgroup available over NNTP:
	nntp://lore.altlinux.org/org.altlinux.lists.devel


AGPL code for this site: git clone https://public-inbox.org/public-inbox.git