Оценка уровня профессиональных навыков программиста очень сложная задача. Каждый решает её по-своему: кто-то предлагает кандидату пройти очень объемный тест, состоящий из тысячи вопросов, кто-то предлагает решить сразу очень сложную задачу, и т.п. Данные подходы имеют право на существование, но они как минимум требуют много времени. Обычно требуется быстро оценить уровень, тогда проще всего предложить решить очень простую задачу на интересуемом языке программирования. Я предлагаю в качестве такой задачи использовать программу, с которой начинается изучение любого языка – «Привет мир!».
С одной стороны, это очень простая задача, но с другой, как показывает практика, даже она является в то же время очень сложной. Рассмотрим подробно какие варианты решения такой задачи пишут реальные люди и что они показывают.
Вариант 1-ый – правильная программа, работающая с ошибкой.
#include <stdio.h>
void main()
    {
    printf( "Hello, world!" );
    }


Что тут неправильного? В консоль выводится текст, программа вроде работает… Но, вспоминаем, в контексте операционной системы, любая программа возвращает код завершения. Данный код (нужно вспомнить ассемблер) храниться в регистре eax (на 32-х разрядной платформе, чтобы быть полностью корректным). В примере выше мы ничего в данный регистр не помещаем, но операционная система не меняет логики своей работы. Поэтому, скорее всего какой-то мусор, находящийся там, будет интерпретирован как результат работы нашей программы. А так как это скорее всего (99.99%) не нулевое значение, то это означает, что наша программа завершилась ошибочно.
Вот «правильный» вариант с точки зрения операционной системы:
#include <stdio.h>
int main()
    {
    printf( "Hello, world!" );
    return 0;
    }

В предпоследней строке мы в качестве результата работы возвращаем 0 – все успешно.
Идём дальше, уже лучше, но все равно есть что улучшить. Смотрим на строку с выводом строки в консоль, там есть повод для замечания от компилятора – небезопасный вывод. Вот более безопасный вариант:
#include <stdio.h>
int main()
    {
    printf( "%s", "Hello, world!" );
    return 0;
    }

Думаю, этот вариант понятен без объяснения (для остальных не составит труда найти объяснение в гугле).
Вроде последний вариант нельзя улучшить, или нет? Какие есть предложения? Как известно, программа без комментариев ничего не стоит, поэтому возможно здесь не хватает именно них или нет? Я считаю (и не только я один), что комментарий здесь также нужен, но какой? Что комментировать и как, чтоб не получилось масло масленое. Писать программы, понятные компьютеру, учат в школе в 9-м классе (или ещё раньше), но писать программы, понятные человеку, иногда не учат даже в университете.
Вот пример программы с комментариями (то есть документированной) в стиле системы автодокументирования Doxygen.
///@file hello_world.cpp
///@brief Учебная программа, выводящая в консоль приветствие «Hello, world!».
///@author idimm 

#include <stdio.h>

///@brief Главная функция, непосредственно выводящая в консоль приветствие. 
int main()
    {
    printf( "%s", "Hello, world!" );
    return 0;
    }

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

Комментарии (153)


  1. VioletGiraffe
    14.06.2016 10:34
    +4

    ИМХО, конечно, но если вы используете printf, то вы пишете не на С++. Есть же iostream.


    1. MximuS
      14.06.2016 10:47
      -5

      А вы когда-нибудь сравнивали скорость работы printf/scanf и cin/cout?

      Если нет — попробуйте, будете очень удивлены, насколько iostream медленнее работает.


      1. snizovtsev
        14.06.2016 11:37

        С std::cout.sync_with_stdio(false) вроде уже не так тормозит. Но дизайн iostream все равно считается плохим, поэтому все рано или поздно переходят на самописные или third-party C++ потоки (т.е. более безопасные, чем printf/scanf).


      1. knstqq
        14.06.2016 11:43
        +4

        iostream работает не медленнее.
        По умолчанию включена синхронизация буферов/кэшей в iostream и stdio, её можно (и нужно, если нет каши из scanf+printf/cin+cout) отключать вызовом sync_with_stdio(0). После этого скорости становятся одинаковыми. К сожалению, некоторые компиляторы/реализации STL не поддерживают её правильно и всё равно тормозят в iostream (некоторые версии от MS говорят страдают)

        буду обновлять страницу перед отправкой комментария


        1. AllexIn
          14.06.2016 11:59
          +1

          Ваш комментарий все таки более расширенный и информативный, чем предыдущий.
          Так что, даже если обновляете перед отправкой — все равно отправляйте в таких случаях. :)


        1. EndUser
          14.06.2016 22:25

          И как будет работать
          int main()
          {
          puts(«input integers A and B»);
          int a, b;
          scanf("%d%d", &a, &b);
          printf(«sum of two = %ld», a+b);
          return 0;
          }
          в вашей трактовке с потоками?


          1. knstqq
            14.06.2016 22:35

            Прекрасно. Так же как и

            int main() {
              cout << "input integers A and B" << endl;
              int a, b;
              cin >> a >> b;
              cout << "Sum of two = " << a + b << endl;
            }
            


            А вот
            int main() {
              puts("input integer A and B");
              int a, b;
              cin >> a;
              scanf("%d", &b);
              cout << "sum of two = %d", a + b);
            }
            

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


            1. EndUser
              14.06.2016 23:21

              Во времена Borland C Compiller возраста 4..5 без синхронизации потоков вывод результата происходил до ввода чисел.
              Так чта, критика о медленности потоков (синхронизированных), да и тормоза общих расходов на виртуализацию, справедливы, хотя потоки и безопаснее, чем c-style IO.


      1. myxo
        14.06.2016 12:52

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


        1. Fil
          14.06.2016 13:13
          +1

          А почему удобнее? Неужели какое-нибудь

          printf("[%s]: from %X to %X. Size = %d bytes", name, begin, end, end-begin);
          

          менее наглядно чем
          std::cout << "[" << name << "]: from " << hex << begin << " to " << end << ". Size = " << dec << end - begin << " bytes";
          


          1. myxo
            14.06.2016 17:27

            В вашем примере, конечно, printf более нагляден и удобен. Но тут только примитивные типы данных. Я скорее имел в виду, что можно перегружать оператор << для вывода какого-нибудь класса.


  1. myxo
    14.06.2016 10:36
    +11

    комментарии


  1. MaximChistov
    14.06.2016 10:40
    +10

    Вот «правильный» вариант с точки зрения операционной системы:
    #include <stdio.h>
    int main()
        {
        printf( "Hello, world!" );
        return 0;
        }
    

    А вот вы и попались, не знающей стандартов Си :)
    http://stackoverflow.com/questions/22239/why-does-int-main-compile


    1. idimm
      14.06.2016 12:27
      -17

      Я — не знаю стандартов Си и не знаю человека, который их (полностью) знает… Стандарт может завтра поменяться, но архитектура CPU вряд ли завтра поменяется, а программа должна работать…


      1. lair
        14.06.2016 13:32
        +3

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


        1. idimm
          14.06.2016 19:29
          -3

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


          1. lair
            14.06.2016 20:51
            +5

            Компилятор пишут люди, а они могут ошибаться…


            Если предположить, что компилятор ошибается, мы вообще не можем рационально рассуждать о поведении написанного нами кода. Поэтому в подобных "заданиях" либо дается конкретный компилятор (если мы опираемся на его известное поведение), либо конкретный стандарт (и мы предполагаем, что компилятор ему полностью соответствует), либо предполагается некое — корректное! — усредненное поведение.
            Я лишь говорю о том, что даже простейшая программа (даже, наверное, самая простая) не так проста.


            Вы никак не подтвердили это свое высказывание. Три приведенных в статье пункта — это бессмысленные усложнения.
            И данный факт можно использовать для оценки навыков программирования автора данной программы.


            … только в рамках программирования аналогичных простых программ.


            1. idimm
              16.06.2016 10:32
              -2

              Не понимаю, почему столько минусов? Вполне честный ответ… Если кто-то говорит, что знает стандарты языка С полностью… Конечно, к этому надо стремиться. Если есть в чем-то сомнения, проще открыть стандарт и уточнить спорный момент. Вот несколько фактов:
              1. Официальные издания стандартов языка С публикуется ISO, и стоят денег.
              2. Существуют следующие международные стандарты (ISO):
              2.1 C90, определен в ISO/IEC 9899:1990.
              2.2 C99, определен в ISO/IEC 9899:1999.
              2.3 C11, определен в ISO/IEC 9899:2011.
              Объемы стандартов близки к 1’000 страниц английского текста.
              По поводу функции main:
              1. C11, ISO/IEC 9899:2011. (Черновик здесь http://www.open-std.org/jtc1/sc22/wg14/www/docs/n1570.pdf):

              The function called at program startup is named main. The implementation declares no prototype for this function. It shall be defined with a return type of int and with no parameters:
              int main(void) { /*… */ }
              or with two parameters (referred to here as argc and argv, though any names may be used, as they are local to the function in which they are declared):
              int main(int argc, char *argv[]) { /*...*/ }
              or equivalent; or in some other implementation-defined manner.

              «UNIX прост. Но надо быть гением, чтобы понять его простоту.» — Деннис Ритчи.


              1. lair
                16.06.2016 11:31
                +1

                Не понимаю, почему столько минусов?


                Потому что вы пренебрежительно относитесь к изучению языка, на примере которого рассуждаете об оценке навыков программирования. А еще потому, что ваш ответ никак не связан с тем комментарием, на который вы отвечаете.
                По поводу функции main:
                1. C11, ISO/IEC 9899:2011. (Черновик здесь http://www.open-std.org/jtc1/sc22/wg14/www/docs/n1570.pdf):



                Угу, там же, раздел 5.1.2.2.3, Program termination (всего лишь на страницу ниже вашей цитаты):
                reaching the } that terminates the main function returns a value of 0.


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


                1. idimm
                  16.06.2016 12:22
                  -3

                  Если вы не знаете стандартов языка, то о какой оценке навыков программирования может идти речь? и Потому что вы пренебрежительно относитесь к изучению языка, на примере которого рассуждаете об оценке навыков программирования. — Это ваше личное высказывание, которое нарушает требование данного ресурса: оскорблять других пользователей, не следить за эмоциями.
                  Далее
                  Угу, там же, раздел 5.1.2.2.3, Program termination (всего лишь на страницу ниже вашей цитаты):
                  reaching the } that terminates the main function returns a value of 0.
                  Также нарушает правила: Путать «Хабр» с Твиттером. Если я не прав, то я не так понимаю данные правила. Пусть тогда мне пояснят их пользователи с большими полномочиями. От вас я вижу много неконструктивной критики, с переходом на личности.


                  1. lair
                    16.06.2016 12:41
                    +2

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


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


                    А вы видите оскорбление в процитированных вами высказываниях? Вообще-то, не всякая оценка является оскорблением.
                    Угу, там же, раздел 5.1.2.2.3, Program termination (всего лишь на страницу ниже вашей цитаты):
                    reaching the } that terminates the main function returns a value of 0.


                    Также нарушает правила: Путать «Хабр» с Твиттером.


                    Это правило относится к публикациям, а не к комментариям.
                    От вас я вижу много неконструктивной критики, с переходом на личности.


                    Отнюдь, никакого перехода на личности. Это вы (а не я) написали "Я — не знаю стандартов Си". Я всего лишь говорю, что незнание стандартов ограничивает возможности корректно оценивать навыки программирование (в рамках конкретного языка), что и видно в конкретных примерах в посте.

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


                    1. idimm
                      16.06.2016 17:31

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


                      1. lair
                        16.06.2016 17:32

                        Вы ошибаетесь.


                      1. mird
                        17.06.2016 11:12
                        +3

                        Если вы ждете комментария модераторов — пишите модераторам. Зачем вы пишете тут в комментах?


  1. MaximChistov
    14.06.2016 10:45

    (удалено)


  1. apro
    14.06.2016 10:48
    +5

    void main


    А кто из современных компиляторов это проглотит? По стандарту main возвращает
    int и в C и в C++, и clang и gcc это проверяют.

    Можно кстати по стандарту не писать return 0; компилятор встроит его аналог за вас.
    printf( "%s", "Hello, world!" );


    Зачем? Если бы вы "Hello, world!" брали откуда-то извне, а так это бесмысленно.
    Опять же gcc/clang печатают предупреждение если строка форматирования не соотвествует
    аргументам, а с -Werror=format просто не скомпилируют такой код.


    1. VioletGiraffe
      14.06.2016 10:52

      MSVC проглотит. Я так долго писал, пока на Stackoverflow мне не указали, что в онлайн-компиляторах мой сэмпл-код не собирается.


  1. AllexIn
    14.06.2016 10:54
    +8

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


    1. idimm
      14.06.2016 11:04
      -9

      Во первых, return 0 важен, так как показывает связь CPU->asm->C->C++ (в контексте такой простой задачи), и это явно через гугл не найдешь. Во-вторых, безопасность printf — избитая тема, которая уже находится в другой плоскости.


      1. ChALkeRx
        14.06.2016 11:09
        +1

        Да, но вот только printf("…") — безопасен, а автор утверждает, что printf( "%s", "Hello, world!" ); безопаснее, чем printf( "Hello, world!" );.


        1. idimm
          14.06.2016 11:26
          -3

          Вот, например, описание из Википедии:
          Так как printf (и остальные функции семейства) могут выводить текст строки форматирования без изменений, если он не содержит управляющих последовательностей, то возможен вывод текста командой
          printf(text_to_print);
          В случае, если text_to_print получается из внешних источников (читается из файла, получается от пользователя или операционной системы), то наличие в получаемой строке знака процента может приводить к крайне нежелательным последствиям (вплоть до зависания программы).
          Пример некорректного кода:
          printf(" Current status: 99 % stored.");
          В этом примере содержится управляющая последовательность «% s», содержащая признак управляющей последовательности (%), флаг (пробел) и тип данных «строка» (s). Функция, приняв управляющую последовательность, попытается прочитать из стека указатель на строку. Так как функции не передавались дополнительные параметры, значение, которое будет прочитано со стека, не определено. Полученное значение будет интерпретировано как указатель на строку с завершающим нулём. Вывод такой «строки» может привести к выводу произвольного дампа памяти, ошибке доступа к памяти и разрушению стека.

          Таким образом, printf( «Hello, world!» ) — потенциально опасная строка, модификация «Hello, world!» может привести к ошибке.


          1. lpre
            14.06.2016 11:51
            +2

            Ну так и в «безопасном» варианте

            printf( "%s", "Hello, world!" );
            


            модификация строки формата "%s" может привести к ошибке :-)


          1. AllexIn
            14.06.2016 11:55
            +3

            Тогда любой код потенциально опасен. Его модификация может привести к ошибке. :)
            Но, printf( «Hello, world!» ) — безопасен. А если вы добавите управляющую последовательность — получите warning с информацией об этом.


            1. idimm
              14.06.2016 12:03
              -6

              Не совсем: printf( «Hello, world!» ) так же безопасен как int s = 2; int b = 4/s. Смотрите на мою статью как на взгляд на то, имеет ли смысл ожидать зеленого сигнала светофора если машин не видно, или не дожидаясь перейти на красный? Опыт желательно строить на ошибках других, не я один утверждаю что надо стремится к красивому (безопасному) коду.


          1. ChALkeRx
            14.06.2016 12:13

            Хм. А я этот ответ частично принимаю.


            Действительно, в большом проекте, который использует printf(), легче заставить всех писать printf("%s", "…") вместо printf("…") чем ждать, пока кто-то случайно туда управляющую последовательность вставит.


            Но:


            1. Вот на это уже действительно наорёт компилятор (а на printf("Hello, World") — не наорёт). Так что можно не париться и доверять компилятору.
            2. Если уж вы так беспокоитесь и почему-то не доверяете варнингам компилятора — можно завернуть в функцию-хелпер.


            1. idimm
              14.06.2016 12:17

              Я — доверяю. А остальное это как if ( 5 == a ) или if ( a == 5 ) — каждый сам выбирает как писать, но не каждый обьяснит, почему он сделал такой выбор.


              1. Igogo2012
                14.06.2016 14:17

                if ( 5 == a ) — это выбор мастера Йоды


              1. qqrm
                14.06.2016 15:19
                +1

                Не стоит выбирать использование магических чисел.


      1. AllexIn
        14.06.2016 11:24

        Я вот ничего не нагуглил на тему printf с выводом константной строки. И ни один компилятор у меня не выводит варнингов на printf с константной строкой…


  1. Fil
    14.06.2016 11:02
    +1

    Если написать, например:

    void my_print(const char *msg)
    {
      printf(msg);
    }
    

    можно получить предупреждение, что формат не является строковым литералом. Лучше заменить на
      printf("%s", msg);
    

    А что не так с printf( «Hello, world!» )?


    1. Alexeyslav
      14.06.2016 13:24

      Я так понял, что в случае какой-нибудь иньекции, если в вашем приложении изменят строку в ресурсах на «Hello, % sword!» то приложение на ровном месте получит проблемы. Это как важные документы хранить в мусорной корзине. Лежат они там довольно уютненько, до поры до времени.


      1. Fil
        14.06.2016 13:34
        +1

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


        1. Alexeyslav
          14.06.2016 16:41

          Зачем давать программе ещё один способ вызвать неприятности?
          К тому же литерал может быть доступен для изменения а таблица виртуальных методов в защищённой области памяти.


          1. lair
            14.06.2016 16:47
            +5

            Затем, что читаемость кода падает. А для атакующего нет никакой разницы, менять printf("Hello, world") на printf("%s"), или printf("%s", "Hello, world") на printf("%s %s", "Hello, world"), поэтому польза от такой "защиты" ничтожна.


            1. idimm
              14.06.2016 16:55

              Программа пишется один раз, а модифицируется много… Если предполагается развитие программы, то лучше писать безопасно, тем более, зная о явных проблемах printf. Это как с заземлением — может убить и при его наличии, не без него убьет точно.


              1. lair
                14.06.2016 17:01
                +2

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


                Как уже неоднократно говорилось, запись printf("Hello, world") — безопасна.


                1. idimm
                  14.06.2016 17:13
                  -2

                  Пишите тогда в Maйкрософт — для них само использование printf уже не безопасно…


                  1. lair
                    14.06.2016 17:35
                    +2

                    … тем не менее в вашем примере эта функция оставлена. Что же вы не прислушались к Майкрософту?


                    1. idimm
                      14.06.2016 21:07
                      -1

                      Этот пример придумали до меня, когда Майкрософт еще не было. Я его осмыслил и интерпретировал в некоторой новой плоскости.


                      1. lair
                        14.06.2016 21:10
                        +2

                        Тогда не ссылайтесь на мнение Майкрософта о безопасности printf.


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


      1. ChALkeRx
        15.06.2016 10:55
        +2

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


        Если подставить туда строковый литерал, как "Hello World!" — он не наругается. И это не опасно.


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


        1. profesor08
          16.06.2016 02:37

          А если сделать сразу безопасно, то каковы гарантии, что кто-то не подставит туда небезопасную штуку и не посмотрит на варнинги? Отвечу сразу — их нету. Этот спор ни о чем. Тут либо писать свое, либо писать обертку. И то не факт, что все будут этому следовать.


  1. ChALkeRx
    14.06.2016 11:06
    +2

    У вас во всех программах ошибка — отсутствует переход на новую строку.


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


    И да, если бы передо мной действительно стояла задача оценки навыков программирования по Hello World (уф), то мне бы ваша программа не понравилась =).


  1. profesor08
    14.06.2016 11:11
    +2

    int/void и наличие/отсутствие return 0; приводят к одному результату: «ConsoleApplication.exe» завершилась с кодом 0 (0x0).


  1. ditu
    14.06.2016 11:11
    -8

    Такая простейшая задача показывает только стокгольмский синдром у ментальных заложников описанного выше языка программирования и продуктов (ОС) написанных на этом языке.


    1. AllexIn
      14.06.2016 11:35
      +2

      С++ сложен.
      Я пишу на нем уже около 10 лет в профессиональной деятельности. А когда начал изучать — даже и не вспомню.
      Но вот прямо в данный момент читаю Мейерса и каждая страница открывает мне новые грани и понимание.
      С++ сложен и многогранен. И не знать его на 100% — нормально. Это не мешает писать на нём.
      Откровенно говоря, писать на С++ можно начать в первый же день знакомства с ним, если вы хотя бы чуть чуть понимаете что такое программирование.
      Основная фишка С++ в том, что он позволяет делать как простые конструкции в С стиле, так и создавать сложные арзитектурные решения с шаблонами и ООП.
      Просто с ростом знаний улучшается и упрощяется код и всё.
      int main(){printf(«Hello, world!»);} прекрасно справляется со своей задачей. И даже без знания нюансов вы напишите код, который убдет работать. Но глубокое знание С++ позволит быстро писать быстрый, качественный и легко расширяемый код.

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


    1. Ivan_83
      14.06.2016 12:24
      +6

      Приходите когда ваша ОС на вашем любимом языке хотя бы загрузится :)


      1. ditu
        15.06.2016 01:26

        А если грузится, то фич давай, а если с фичами, то рыночную ценность покажите… Плавали, знаем.
        http://www.ocp.inf.ethz.ch/wiki/OCP/Home


        1. Ivan_83
          15.06.2016 02:00
          -2

          За рыночную долю я не спрашиваю — сам сижу на FreeBSD.
          Фичи на любителя, если оно само работает и может приносить какую то практическую пользу — респект.

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


          1. Sirikid
            15.06.2016 02:14
            +2

            Ну пишут же на Rust + немного ASM (Redox), на Go один хабротоварищ писал.


            1. Ivan_83
              15.06.2016 03:04
              -2

              Само оно ещё не работает на реальном железе.
              Касательно практической пользы — тоже не видно.

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

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

              Я сам начинал с вижал бейсика, это точно такая же песочница для детей как Rust и Go сейчас, хотя они даже ещё во многом не дотягивают: там была IDE качественная и справка, плюс язык был довольно зрелым (5 версия).
              На си я всегда смотрел как на инструмент профи, с которым можно сделать всё, даже покалечится и это нормально для вещей взрослых. Примерно как лего и столярная мастерская.
              Сидеть в Rust/Go/… и ругать Си, это как не желание взрослеть, стремление всю жизнь жить в песочнице.
              При этом некоторые ещё активно говорят что все взрослые дураки, потому что делают что то беря на себя ответственность и рискуя покалечится.

              У меня нет претензий к адептам питон, пхп, джава и прочих языков которые не претендуют на нишу Си.


              1. DarkEld3r
                15.06.2016 17:31

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


                А по моему, это подмена понятий. Разве кто-то обещает избавить от "вообще всех" ошибок? Я таких утверждений в отношении упомянутого раста не видел. А вот обобщений в духе "не защищает от всего -> защита в принципе не нужна" хватает.
                их программы с безопасным языком работают в ОС написанной на типа не безопасном языке


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

                Если честно, вообще не понимаю сути претензий. Можно подумать, что у вас кто-то С насильно отбирает. Вот я пишу на С++ и хотя его принято ругать (причём не безосновательно) мне язык нравится. Но нравится и раст, хотя в нём недостатки тоже вижу. Нравится и как непосредственно язык и как "идея" — если не взлетит, то всё равно что-то в существующие языки войдёт и/или даст толчок чему-то новому. В конце концов, это просто интересно. (:

                И да, вижуал бейсик не родился в пятой версии, а дошёл до неё не сразу. И документация для раста имеется, ну а ИДЕ — дело наживное, хотя что-то имеется и сейчас.


                1. Ivan_83
                  16.06.2016 01:44
                  -1

                  Фанаты приходят в каждый топик где есть «Си» и «безопасность»: и транслируют что на Си вообще невозможно написать безопасный код… Некоторые намекают на свой печальный опыт с не рабочими хэлловорлд :)

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

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

                  2 Sirikid:
                  Я ваших языков не знаю, но:
                  1. От автоматического приведения типов я в своё время настрадался в вижал бейсике
                  2. Когда автоматического приведения типов нет, то они все нужны только для того чтобы подсказывать каких данных стоит ожидать. Если не брать в расчёт числовые типы, которые язык сам обрабатывает, то ко всем строкам я отношусь как кускам памяти в которых может быть что угодно.


                  1. Sirikid
                    16.06.2016 04:02
                    +1

                    В Go вообще есть только явно приведение, в Rust, по-моему, тоже. В Kotlin есть неявное приведение, но довольно хитрое, например

                    fun foo(bar: Any?) {
                      if (bar != null) {
                        // здесь тип bar уже Any, потому что была проверка на null
                        if (bar is String) {
                          // а здесь тип bar - String
                          println(bar.length) // компилируется
                        }
                      }
                    }
                    


                  1. lair
                    16.06.2016 09:39
                    +2

                    когда весь мир пишет на Си и догоняется питоном/перлом/пхп.


                    Вот так мило взяли и изничтожили весь .net, весь JVM и все функциональные языки.
                    Си в компах как английский в реальном мире.


                    М? Третий по распространенности после?..


                  1. DarkEld3r
                    16.06.2016 10:50

                    Вообще-то в этой ветке именно вы зачем-то заговорили о Go и Rust.

                    Я уже ходил по этому пути и больше не хочу.

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

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

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


                    1. Ivan_83
                      16.06.2016 19:29
                      -2

                      Через 2 года мне стало тесно в вижал бейсике, надоело руками писать декларации к винапи и ощущать себя человеком второго сорта глядя на примеры на Си ко всем АПИ.
                      Лет 5 я писал на ВБ, первые два года активно, потом перешёл на Си, а ВБ использовал в универе для всяких проектов.

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


                      1. DarkEld3r
                        17.06.2016 11:44

                        Наверное, продолжать спор нет смысла — слишком уж много тут субъективного окажется. Я пишу на С++ и крайне рад, что не приходится использовать "голый С". И да, раст, несмотря на то, что там нет кое-чего (может даже "много чего") из плюсов, мне всё равно кажется прогрессом.


                        Но дело даже не в этом. Из интереса брался за разные языки: за тот же лисп/ракет, например. Естественно, ниша у него другая, но это не мешало мне видеть удобные и крутые возможности, которые могли бы и в более низкоуровневые языки попасть. Да хотя бы (нормальные, не сишные) макросы. И я очень рад, что раст делает шаги в этом направлении.


                        Не стоит забывать ещё о том, что новым языкам сложнее пробиться: на существующих немало написано уже, есть литература, разнообразные курсы, готовые специалисты, их преподают в учебных заведениях. У них есть поддержка ИДЕ, профайлеров, отладчиков и прочих полезных вещей. На них написаны кучи библиотек и имеется биндинги к "чужим". Для новых языков это всё надо делать и оно не так просто, особенно учитывая, что некоторые из них делаются энтузиастами. Да даже мозилла весьма скромно смотрится на фоне майкрософта продвигающего C# или эпла со свифтом. Тем более, что "своей платформы" у них нет. А у какого-нибудь Nim есть тупо пару активных разработчиков и всё. Плюс инертность, которая зачастую оправдана — переписывать существующие проекты нет смысла за крайне редкими исключениями.


                      1. lair
                        17.06.2016 13:28

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


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


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


              1. Sirikid
                15.06.2016 22:04

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

                А насчет реально работающих ОС не на Си… Project Oberon вроде подходит.


  1. arteast
    14.06.2016 11:31
    +3

    > printf( «Hello, world!» );

    Не стоит доверять сообщениям компилятора, который ЭТО обзывает небезопасным. И уж тем более не надо втыкать костыли типа
    > printf( "%s", «Hello, world!» );

    > ///@file hello_world.cpp
    Бессмысленно — это часть метаданных файла, и ее не стоит дублировать в данных файла. Особенно если учесть, что файл потом могут переименовать

    > ///@author idimm
    Бессмысленно — если уж мы тут следуем лучшим практикам, то эта информация есть в системе контроля версий. Особенно если учесть, что файл потом могут редактировать другие люди


    1. AllexIn
      14.06.2016 11:36

      > ///@author idimm
      Бессмысленно — если уж мы тут следуем лучшим практикам, то эта информация есть в системе контроля версий. Особенно если учесть, что файл потом могут редактировать другие люди

      Не соглашусь. Особенно, если речь идет об Open Source.


      1. arteast
        14.06.2016 11:55
        +1

        Особенно это относится к Open Source:
        1) Подавляющая часть проектов использует систему контроля версий, и по git/mercurial/whatever репозиторию можно всегда посмотреть полную историю файла — кто написал первую версию, кто и что поправил и т.д. В случае git даже посылка изменений через патчи сохраняет правильную историю. Запись в заголовке файла в лучшем случае дублирует информацию, в худшем — просто недостоверна. Исключение составляют проекты со «сложной» историей — странные форки, мержи и т.д., когда информация из оригинального репозитория может быть утеряна
        2) Большая часть проектов также содержит файл README, или CREDITS, или MAINTAINERS, или что-то похожее, который указывает на людей, отвечающих за проект или за интересующую его часть.
        3) Как продолжение мысли из предыдущего пункта — очень часто в Open Source человек, который когда-то написал файл, уже давно им не занимается, а занимаются другие люди.


        1. AllexIn
          14.06.2016 11:57
          -1

          Важно превоначальное авторство.
          А код часто используется не целиком, а в виде отдельных файлов. А там, ни информции из VCS, ни README. Вообще ничего, кроме файла с кодом.
          Вы никогда не задумывались, почему GPL требует о себе писать в начале каждого текстового файла? Вот авторство надо писать по тем же причинам.


          1. arteast
            14.06.2016 12:10
            +2

            Я что-то плохо себе представляю такой часто встречающийся use case, который требует выдергивания отдельных файлов из проекта.
            Кроме того, зачем нужно первоначальное авторство файла? Как пример — замечательный 165Kb файл ffmpeg.c из одноименного проекта. Сверху как часть преамбулы GPL написано «Copyright © 2000-2003 Fabrice Bellard». Ну вот первоначальный автор указан, а толку с того? 13 лет с тех пор прощло, Беллард уже лет 10 как не касался FFmpeg вообще, файл был переписан чуть более, чем полностью десятками людей (буквально, git blame показывает, что за авторством Белларда в этом файле остались только пустые строчки и строчки из одного символа скобочки).
            Про GPL — подозреваю, требует такое для защиты от «включения дурака» по типу «ой а я не знал что этот файл был под лицензией, на нем же не написано».


            1. AllexIn
              14.06.2016 14:04
              -1

              Я что-то плохо себе представляю такой часто встречающийся use case, который требует выдергивания отдельных файлов из проекта.

              Мнге странно такое читать, потому что я постоянно встречаю цельные куски библиотек не в виде отдельных проектов, а в виде исходников засунутых в проект.
              Например, вот прямо сейчас я фрилансю над чужим проектом, внутри которого лежат libpng, libjpeg, openssl, tinyxml, ffmpeg. Каждый из них лежит в своем отдельном каталоге. Но в них только h и с файлы. Никаких readme и в помине нет. И я такое вижу постоянно. Мне даже немного завидно, что есть программисты которых это удивляет. :)


              1. arteast
                14.06.2016 14:24

                Ну извините, это не open source, а какой-то говнокод. Любые нормальные проекты либо вообще не включают в свое дерево другие библиотеки (а требуют их как зависимости), либо берут все дерево целиком со всеми файлами и просто подтачивают билд-машинерию под свои нужды (и трекают все изменения в своем репозитории).
                Брать только *.[ch]* — это как минимум некорректно по отношению к разработчикам, а как максимум — нарушает лицензию. К примеру, тот же GPL требует включить в каждый файл преамбулу, а в проект — полный текст лицензии. Взять файлы с преамбулой, выкинуть файл с текстом лицензии и распространять результат — нарушение прав разработчиков.
                С прагматичной точки зрения — пусть есть такой проект. Даже в нем очевидно, что файлы из каталога tinyxml относятся к tinyxml (да и в самих файлах написано, что это tinyxml); всё, можно закрывать проект и идти на сайт tinyxml — там вся информация по ответственным людям есть. Зато неочевидно, что весь код в этих файлах был написан авторами tinyxml, т.к. хрен его знает, что в этом проекте натворили еще, помимо собственно «кражи» кода из чужих проектов.
                И даже в этом примере информация о собственно авторе файла (физическом лице) не нужна. Максимум нужно знать проект, к которому относится файл (а ее обычно пишут как часть лицензионной преамбулы).


                1. AllexIn
                  14.06.2016 16:58
                  +1

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

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

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

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


                  1. arteast
                    14.06.2016 17:47
                    -1

                    Пример из того же FFMpeg (в заголовке каждого файла):
                    > You should have received a copy of the GNU Lesser General Public
                    > License along with FFmpeg; if not, write to the Free Software
                    > Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA

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

                    А теперь самое главное:
                    > ///@author idimm
                    это не копирайт и не лицензия, а просто комментарий об авторе кода. Который, по-моему, не имеет смысла. Я выдал аргументы, почему так считаю. Аргументов о противном пока не видел. Расскажите, пожалуйста, в чем польза этого комментария? Как вам он может быть полезен и для чего вы эту информацию можете использовать?


                    1. AllexIn
                      14.06.2016 17:51

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

                      Еще раз:
                      «GPL лицензия — общая на проект.»
                      Одна.
                      И я по прежнему не улавливаю связи между указанием авторства и файлом лицензии. Авторство не в лицензии пишут, а в README. GPL не обязывает копировать README.

                      это не копирайт и не лицензия, а просто комментарий об авторе кода.

                      Подпись авторства — частный случай копирайта.


                      1. lair
                        14.06.2016 17:55
                        +1

                        Подпись авторства — частный случай копирайта.


                        Вообще-то, нет. Между копирайтом и авторством связь весьма косвенная.


                        1. AllexIn
                          14.06.2016 17:59

                          Да нет, вполне прямая. Указание своих данных позволяет вам доказать, что авторское право на произведение принадлежит вам.
                          Подпись является частью авторского права(копирайта).
                          «Подпись авторства — частный случай копирайта.» Копирайт здесь как «обозначение авторского права, а не как само право».


                          1. lair
                            14.06.2016 18:01

                            Указание своих данных позволяет вам доказать, что авторское право на произведение принадлежит вам.


                            Авторское право или право авторства? Для доказательства авторства подпись не обязательна. А для доказательства наличия (всех) авторских прав подписи, наоборот, недостаточно.


                            1. AllexIn
                              14.06.2016 18:09

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


                              1. lair
                                14.06.2016 18:12

                                Это просто способ успросить себе жизнь и не более того.


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


                                1. AllexIn
                                  14.06.2016 18:15

                                  Я не юрист. Не вижу смысла глубоко в этом разбираться.
                                  Есть GPL, есть FSF, есть их рекомендации. Зачем что-то выдумывать, если можно просто им следовать?


                                  1. lair
                                    14.06.2016 18:25

                                    Я не юрист. Не вижу смысла глубоко в этом разбираться.


                                    Вот отсюда и появляются утверждения "Подпись является частью авторского права(копирайта)", хотя подпись — это просто подпись.
                                    Есть GPL, есть FSF, есть их рекомендации. Зачем что-то выдумывать, если можно просто им следовать?


                                    Затем, что надо понимать границы применимости этих рекомендаций. В частности, GPL явно ограничивает авторские права автора (простите) исходного кода.


                                    1. AllexIn
                                      14.06.2016 18:26
                                      -1

                                      В частности, GPL явно ограничивает авторские права автора (простите) исходного кода.

                                      Вы бред несете. GPL не распространяется на автора. Только на пользователей.
                                      Видимо вы «не юрист» еще больше чем я.


                                      1. lair
                                        14.06.2016 19:17

                                        Вы бред несете. GPL не распространяется на автора


                                        Правда? То есть любой исходный код может быть выпущен под GPL?


                                        1. AllexIn
                                          14.06.2016 19:32
                                          -3

                                          image


                                          1. lair
                                            14.06.2016 20:56

                                            Угу, а теперь на конкретном примере.


                                            Вот я автор, и у меня есть написанная мной программа. Бинарники, чтобы не связываться с вопросами распространения исходников. Программа написана только и исключительно мной, не по рабочему заданию, не в рабочее время, не использует чужой код — короче говоря, все авторские права бесспорно принадлежат мне. И вот я выпустил эту программу в мир под GPL.Внимание, вопрос: как этот выпуск изменил мои авторские права?


                                            1. AllexIn
                                              14.06.2016 21:57

                                              Никак.


                                              1. lair
                                                14.06.2016 22:07

                                                То есть я могу воспользоваться своими исключительными правами и продать эту — напоминаю, лицензированную по GPL — программу, запретив покупателю ее дальнейшее распространение?


                                                1. AllexIn
                                                  14.06.2016 22:11

                                                  Верно. Гуглите ситуацию с Emacs, который долгое время будучи под GPL распространялся без исходников.

                                                  Такие штуки нарушают «этические нормы Open Source», но не саму лицензию GPL.
                                                  Повторюсь(в третий раз?) GPL на автора не распространяется. Можете делать что угодно, но нарушить GPL не можете, потому что она на вас не распространяется.


                                                  1. lair
                                                    14.06.2016 22:16

                                                    Подождите, при чем тут исходники вообще? Я задал конкретный вопрос: можно ли, не нарушая GPL, продать программу, запретив ее дальнейшее распространение покупателем?


                                                    1. AllexIn
                                                      14.06.2016 22:23

                                                      Как при чем тут исходники? GPL предполагает возможность править исходники продукта.
                                                      Если вы отдали бинарники кому-то лицензированные по GPL, но не дали возможности получить исходники — этот кто-то не в праве рапространять бинарники!
                                                      Я еще раз повторю — гуглите ситуацию с Emacs. Там как раз пробелма была в том, что по сути кучу людей сделали нарушителями GPL, т.к. они рапространяли GPL EMacs и при этом исходников Emacs не было.

                                                      Я понимаю что вам лениво чё-то гуглить, тем более когда вы считаете себя правым. Но вот вам цитата от Столмана из-за той ситуации с EMacs:

                                                      If the Emacs release contains a compiled program and not its source code, anyone redistributing that release by itself would violate the GPL. We must not lead people to violate the GPL!


                                                      1. lair
                                                        14.06.2016 22:48

                                                        GPL предполагает возможность править исходники продукта.


                                                        Правда? А я думал, что GPL — это про свободное программное обеспечение.
                                                        Если вы отдали бинарники кому-то лицензированные по GPL, но не дали возможности получить исходники — этот кто-то не в праве рапространять бинарники!


                                                        Где в тексте GPL это явно написано? Я там вижу иное:
                                                        To “propagate” a work means to do anything with it that, without permission, would make you directly or secondarily liable for infringement under applicable copyright law, except executing it on a computer or modifying a private copy. Propagation includes copying, distribution (with or without modification), making available to the public, and in some countries other activities as well.

                                                        You may make, run and propagate covered works that you do not convey, without conditions

                                                        The GPL is a free software license, and therefore it permits people to use and even redistribute the software without being required to pay anyone a fee for doing so.


                                                        Другой вопрос в том, могу ли я вообще выложить (свои!) бинарники, не выкладывая исходников, и оставаясь в рамках GPL.

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


                                                        1. AllexIn
                                                          14.06.2016 23:13

                                                          Где в тексте GPL это явно написано?

                                                          Вам не понятен пример с Emacs? Слова лидера FSF вас не убидели? :)
                                                          Это явно не написано, но это следует из самой сути лицензии.
                                                          Да и в FAQ этот вопрос разобран:
                                                          «I downloaded just the binary from the net. If I distribute copies, do I have to get the source and distribute that too? (#UnchangedJustBinary)
                                                          Yes. The general rule is, if you distribute binaries, you must distribute the complete corresponding source code too. The exception for the case where you received a written offer for source code is quite limited.»

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

                                                          Вы можете распространять свой софт как вам угодно, но для того чтобы сделать ограничение на дальнейшее распространение — вам придется модифицировать лицензию. А её нельзя модифицировать. Можно только создать новую на её основе. Это уже не будет GPL. Так что нет, вы не можете сделать то что описываете. Но не из-за ограничений вашего авторского права, а из-за ограничений в использовании лицензии GPL. Это будет нарушением прав авторов лицензии.


                                                          1. lair
                                                            14.06.2016 23:31

                                                            Так что нет, вы не можете сделать то что описываете.


                                                            Это значит, что мои исключительные авторские права ограничены — до применения GPL я мог это сделать, а теперь не могу. О чем и речь.


                                                            1. AllexIn
                                                              14.06.2016 23:45
                                                              -1

                                                              Ерунда.
                                                              Это тоже самое, что сказать «Я сделал программу. Теперь я могу людей убивать?».
                                                              Нет, не можете. Но не из-за ограничения авторских прав.

                                                              Вы не ограничены в своих авторских правах. Вы не можете модифицировать GPL. Это касается не ваших авторских пра, а прав авторов GPL.

                                                              Модификация GPL вообещ с вашим продуктом не связана. Если вы ее отдельно модифицируете — это все равно будет нарушением. Также как и убийство кого нибудь никак не связано с вашей программой.


                                                              1. lair
                                                                14.06.2016 23:48

                                                                Вы не ограничены в своих авторских правах.


                                                                Как же так? У меня есть исключительное авторское право (закрепленное в ГК РФ) как угодно ограничивать распространение своего произведения. Если я приму решение выложить свое произведение под GPL, я потеряю это право.
                                                                Вы не можете модифицировать GPL.


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


                                                                1. AllexIn
                                                                  14.06.2016 23:52

                                                                  У меня есть исключительное авторское право (закрепленное в ГК РФ) как угодно ограничивать распространение своего произведения. Если я приму решение выложить свое произведение под GPL, я потеряю это право.

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

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

                                                                  И как вы это сделаете без модификации GPL?


                                                                  1. lair
                                                                    14.06.2016 23:57

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


                                                                    А нет никакой "обратной силы", я хочу установить лицензионные ограничения сразу при выпуске.
                                                                    И как вы это сделаете без модификации GPL?


                                                                    Очевидно, написав в лицензионном соглашении "предоставляется по GPL, за исключением..." Текст GPL не изменен.


                                                                    1. AllexIn
                                                                      15.06.2016 09:15

                                                                      Очевидно, написав в лицензионном соглашении «предоставляется по GPL, за исключением...» Текст GPL не изменен.

                                                                      В каком лицензионном соглашении? Если это GPL соглашение, то так делать нельзя. Если это НЕ GPL — то это НЕ GPL.


                                                                      1. lair
                                                                        15.06.2016 10:48
                                                                        -1

                                                                        так делать нельзя


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


                                                                        1. AllexIn
                                                                          15.06.2016 10:56

                                                                          ROFL.
                                                                          Еще раз написать?
                                                                          Ок:
                                                                          вы вправе делать с вашим продуктом все что захотите. Вы не вправе модифицировать GPL. GPL не имеет котношения к вашему продукту — это самостоятельный и отдельный продукт, не вашего авторства. Ограничения GPL — накладываются на использование GPL и к вашему продукту отношения не имеют, т.к. влияют на саму лицензию и только.

                                                                          Если вы по любым условиям(GPL, не GPL) отдаете продукт кому-то, то вы даете этому «кому-то» права, которыми он может воспользоваться. В конкретно вашем примере вы даете человеку право работать с вашим продуктом и распространять его. Это НЕ является ограниченим вашего права на рапространение, т.к. вы и пользуетесь этим правом отдавая продукт под определенные условия.


                                                                          1. lair
                                                                            15.06.2016 11:01

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


                                                                            Да ну? До того момента "воспользования", у меня был один набор исключительных прав, а после этого момента — другой, меньший набор исключительных прав. Это не ограничение, по-вашему?


                                                                            1. AllexIn
                                                                              15.06.2016 11:04

                                                                              Да никуда ваши права не делись. Вы вправе делать с вашим продуктом что захотите.
                                                                              Если автор печатает книгу и продает — он получает какие-то ограничения? Нет. Но те книги, котоыре он уже продал являются собственностью тех кому он их продал. А обственники могут книгку кому-то еще отдать или перепродать. По вашей логике — это тоже нарушение права автора на распространение?


                                                                              1. lair
                                                                                15.06.2016 11:06

                                                                                Вы вправе делать с вашим продуктом что захотите.


                                                                                Нет. Например, я не могу продать этот продукт кому-то, указав в договоре продажи, что покупатель получает единоличное и исключительное право использования продукта.
                                                                                Если автор печатает книгу и продает — он получает какие-то ограничения?


                                                                                Да, он больше не сможет заключить на эту книгу исключительный контракт.

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


                                                                                1. AllexIn
                                                                                  15.06.2016 12:20

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

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

                                                                                  С чего бы это вдруг? Лицензия не распространяет свое действие на продукт автора и на самого автора. Лицензия рапространяет своей действие только на копии продукта переданные третьи лицам.


                                                                                  1. lair
                                                                                    15.06.2016 12:57
                                                                                    -1

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


                                                                                    Вот только для объекта авторского права "копия" семантически эквивалентна продукту. Если я продал "копию" с правом бесконечного распространения, фактически, в бесконечное распространение попал продукт.
                                                                                    Лицензия не распространяет свое действие на продукт автора и на самого автора.


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


                                                                                    1. AllexIn
                                                                                      15.06.2016 13:05

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

                                                                                      GPL ничего не запрещает делать автору, но дает права пользователю.
                                                                                      Если для вас разрешение пользователям что-то делать является нарушением/ограничением прав автора… Странная форумлировка, ну ок.


                      1. arteast
                        14.06.2016 18:09

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


                        1. AllexIn
                          14.06.2016 18:14

                          Это не меняет сути. Речь про подпись авторства, а не про формат.
                          Знак копирайта © рядом с подписью роли не играет, как вы верно заметили. Как хочет так и записывает.


                          1. arteast
                            14.06.2016 18:25

                            Я как бы совершенно наоборот заметил. Правда, https://www.gnu.org/licenses/gpl-howto.en.html со мной не совсем согласны, но и с вами тоже. В любом случае надо указывать имя автора, а не ник, и год публикации. Если нет этих атрибутов — это не заявление о копирайте с правовой точки зрения, и его можно спокойно вырезать.
                            Давайте определимся — к моему первоначальному комментарию есть какие-либо возражения, помимо правовых вопросов? Если есть — давайте обсудим. Если нет — то я считаю, что Doxygen команда author сама по себе не несет правовых последствий, равно как и Doxygen команда copyright.


                            1. AllexIn
                              14.06.2016 18:28

                              Если ваш первоначальный комментарий читать как «не надо оставлять подпись в файлах», то я с вами не согласен. Я именно так прочитал и именно с этим спорил.

                              Если же читать как «подписывать надо подругому», то ок. Вопросов нет.


                              1. arteast
                                14.06.2016 18:38

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


                                1. AllexIn
                                  14.06.2016 18:40

                                  такая же строчка

                                  Это какая?
                                  2016 Иванов Сергей
                                  Это такая же?
                                  Если нет, то где ключевое отличие?


                                  1. arteast
                                    14.06.2016 18:57

                                    Из рекомендаций по использованию GPL:

                                    The copyright notice should include the year in which you finished preparing the release (so if you finished it in 1998 but didn't post it until 1999, use 1998). You should add the proper year for each release; for example, “Copyright 1998, 1999 Terry Jones” if some versions were finished in 1998 and some were finished in 1999. If several people helped write the code, use all their names.


                                    Always use the English word “Copyright”; by international convention, this is used worldwide, even for material in other languages. The copyright symbol “©” can be included if you wish (and your character set supports it), but it's not necessary. There is no legal significance to using the three-character sequence “©”, although it does no harm.

                                    \author serge — никак не работает
                                    2016 Иванов Сергей — тоже не работает.
                                    Copyright 2016 Иванов Сергей — работает.

                                    PS: и еще раз — дискуссия с моей стороны изначально велась без учета особенностей копирайта. Если отбросить всё, что связано с копирайтом, то остается только информация об авторе, которая доступна из других мест, или не имеет значения вообще


                                    1. AllexIn
                                      14.06.2016 19:35

                                      Даже если отбросить копирайт — информация об авторстве может быть нужна. А может быть не нужна. Решать может только сам автор.

                                      «доступна из других мест». Не доступна. Примеры приводил.
                                      Кстати, GPL была упомянута изначально как раз из-за того, что в ней и говорит о «доступности из других мест». Вернее о том, что этой доступности может не быть.


                                      1. arteast
                                        14.06.2016 21:35

                                        > «доступна из других мест». Не доступна. Примеры приводил.
                                        Мы ходим по кругу. Ну давайте еще раз. В вашем примере есть файл, скажем, 3rdparty/ffmpeg/libavutil/sha512.c. Хочется узнать, кто автор. Хм, откуда взяли этот файл? Может быть из (внезапно) ffmpeg? Идем на гитхаб, смотрим в репозиторий ffmpeg, находим там этот файл и смотрим его историю. Готово, задача решена.


  1. idimm
    14.06.2016 11:36
    -8

    Господа, на мелкие нападки нет времени отвечать (и смысла тоже). Предлагайте свой вариант «Привет, мир» с обоснованием.


    1. AllexIn
      14.06.2016 11:41
      +6

      Предлагаю:

      #include <stdio.h>
      void main(){
          printf( "Hello, world!" );
      }
      

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


      1. ChALkeRx
        14.06.2016 12:08

        Как С — соберётся, как C++ — 1.cpp:2:11: ошибка: «::main» должна возвращать «int». Это в стандарте, который g++ сейчас по умолчанию использует.


        А после сборки:


        $ ./test
        Hello, world![chalker@pc tmp] $


        1. AllexIn
          14.06.2016 14:07
          +2

          Нигде ж не говорится, что речь про С++.


      1. idimm
        14.06.2016 16:49
        -13

        Моя оценка по вашему коду:
        1. есть проблемы с комментированием и документированием: программа без комментария ничего не стоит, а ваша программа без комментариев.
        2. есть доверие компилятору разрешать много делать по умолчанию: любая процедура (функция) возвращает результат в регистре еаx (x86), здесь компилятор это делает за вас (если делает, то добавляет следующий ассемблерный код — xor eax, eax).
        3. на любое ваши замечание могу на спор придумать в 5-ть раз больше замечаний.
        А вообще ваш вариант вполне себе хорош.


        1. AllexIn
          14.06.2016 17:01
          +6

          1) Излишнее документирование вредно. За комментарии в кэп-стиле a+=b; //К a приблавляется b можно получить от старшего, который будет ревьювить по шее за засорение кода. Я, кстати, ваш код именно по этой причине не пропустил бы.
          Хороший код документирует себя сам. Исключение — это API, сложные алгоритмы и т.п.
          2) Я доверяю компелятору. Особенно в рамках стандарта. Если я не могу доверять компилятору — я им не пользуюсь.
          3) Аналогично.


        1. lair
          14.06.2016 17:03
          +4

          программа без комментария ничего не стоит


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


          1. idimm
            14.06.2016 19:57
            -1

            Не согласен — важен не только факт понимания программы, но и время, потраченное на это. Комментарий можно рассматривать как средство борьбы со сложностью программы.


            1. lair
              14.06.2016 20:57
              +2

              Вот только комментарий не обязательно уменьшает время понимания программы.


              1. idimm
                14.06.2016 21:01
                -1

                Повторю — комментарий можно рассматривать как средство борьбы со сложностью программы.


                1. lair
                  14.06.2016 21:02
                  +4

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


                  1. idimm
                    14.06.2016 21:24
                    -5

                    Повторю — программа без комментариев ничего не стоит. Это законченное утверждение. Как аксиома в геометрии — параллельные прямые не пересекаются. Не я его придумал — вот где это упоминается — Ален И. Голуб: Правила программирования на C и C++ — раздел 20. Если не согласны — это ваше личное мнение, не надо навязывать его другим. Писать или не писать комментарии — скажете это авторам сложного фрагмента кода, который нужно модифицировать вчера. Я считаю что писать комментарий нужно, просто этому не учат у университетах.


                    1. lair
                      14.06.2016 21:46
                      +4

                      программа без комментариев ничего не стоит. Это законченное утверждение.


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


                      Это не только мое личное мнение, это мнение, проверенное практикой. И вот вам цитата: "The main contributor to code-level documentation isn’t comments, but good programming style" (Steve McConnell, Code Complete, p. 778)


                    1. Fil
                      14.06.2016 21:55
                      +3

                      У следующих уважаемых ребят целые главы посвящены комментированию.
                      Фаулер «Рефакторинг»:

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

                      Макконнелл «Совершенный код»:
                      Если код настолько сложен, что требует объяснения, почти всегда разумнее улучшить код, а не добавлять комментарии


                      1. idimm
                        14.06.2016 22:26

                        Это теория. А вот практика. Что здесь происходит?

                        #include <stdio.h>

                        int main()
                        {
                        int flags = 0x5; // Некий набор флагов.

                        printf ("-parity\n" + ((flags & 0x1) != 0));
                        printf ("-break\n" + ((flags & 0x2) != 0));
                        printf ("-xon\n" + ((flags & 0x4) != 0));
                        printf ("-rts\n" + ((flags & 0x8) != 0));
                        return (0);
                        }


                        1. AllexIn
                          14.06.2016 22:29

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


                        1. Fil
                          14.06.2016 22:35
                          +3

                          переделать так

                          inline bool is_parity(int flags)
                          {
                            return flags & PARITY_MASK;
                          }
                          

                          аналогично для остальных.


                        1. lair
                          14.06.2016 22:51
                          +3

                          … а на практике этот код сам по себе ужасен, потому что использует магические числа. Пока не будет честных именованных констант, комментарии его не спасут, а после появления констант (а лучше — адекватных макросов/проверочных методов) комментарии будут избыточными.


                      1. idimm
                        14.06.2016 22:32

                        Вот из Википедии:
                        Давайте изменим традиционные приоритеты в создании программ: вместо представления о нашей задаче как о создании инструкций «Что делать?» для компьютера сконцентрируемся на объяснении другим людям описаний нашего видения того, что под управлением программы должен делать компьютер.

                        — Дональд Кнут, http://community.livejournal.com/ru_perl/249441.html


                        1. AllexIn
                          14.06.2016 22:35

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


                    1. INC_R
                      14.06.2016 22:33
                      +5

                      Будьте аккуратнее с аксиомами, а то если воспринимать их слишком буквально, придется комментировать i++.
                      Писать комментарии нужно там, где они действельно нужны. То есть в сложных системах, про которые вы упоминаете. И только если код не документирует сам себя.
                      Вы ссылаетесь на Алена Голуба. Если вы перевернете страницу, то увидите правило «Комментарий не должен подтверждать очевидное». Вот вы написали комментарий: ///@brief Главная функция, непосредственно выводящая в консоль приветствие. По коду же очевидно, что это главная функция и что она выводит текст в консоль, и второй раз повторять это нет смысла. Ваш код не буфетчица будет читать, а другие программисты, и уж если они это понять без комментария не могут, то проблемы тут явно не в отсутствии комментариев.


    1. TonyLorencio
      14.06.2016 12:08

      В данной задаче достаточно puts
      #include
      int main(void)
      {
      puts(«Hello, world!»);
      }


      1. AllexIn
        14.06.2016 14:06

        http://www.cplusplus.com/reference/cstdio/puts/
        говорит что include все равно нужен.


        1. Sirikid
          14.06.2016 22:05

          Это злой хабрапарсер (а язык скорее C)


  1. lpre
    14.06.2016 11:46
    +1

    GNU Hello:
    http://www.gnu.org/software/hello/

    :-)


  1. olekl
    14.06.2016 14:04
    +5

    Если уж и придираться, то почему оставили без внимания то, что принтф вообще-то возвращает результат, который почти никто никогда не проверяет?


    1. ksergey01
      14.06.2016 18:48

      А какие действия можно предпринять в случае ошибки?


      1. Einherjar
        14.06.2016 19:30
        +1

        Можно например вернуть не 0 из main.


      1. idimm
        14.06.2016 20:04

        Получить код ошибки, проанализировать и как-то отреагировать в зависимости от ситуации.


  1. EndUser
    14.06.2016 22:19

    http://netnotes.narod.ru/sbm/text/t18.html


  1. idimm
    15.06.2016 09:58

    Господа, появилось много отрицательных комментариев — видно многих очень сильно задело то, что кто-то учит их писать Hello world. Это не являлось целью статьи, так что извиняйте (видно все используют принцип KISS). Однако появилась новая пища для размышлений (как минимум для меня) — это https://habrahabr.ru/post/75971/ и http://www.gnu.org/software/hello/. Так что, если есть желание поддержать автора в его начинаниях (у многих ярых комментаторов 0 статей) подумайте еще раз над своей оценкой статьи и ее значении для вас и для автора. А конструктивная критика всегда приветствуется и будет учтена в последующей работе.


  1. mdl
    16.06.2016 10:31

    О возвращаемом значении позаботились, а о переводе строки — нет.