• Где можно осуществлять продвижение конкурса по программированию?

    castomi
    @castomi
    Серверный администратор - tickets.settin.ru
    for gde in toster mail Хабрахабр Geektimes Вконтакте Фейсбук
    do
        Программисты $gde все на конкурс!!!!
    done
    Ответ написан
    Комментировать
  • Что есть в C++, чего нет в C#?

    15432
    @15432
    Системный программист ^_^
    На C/C++ можно написать системный драйвер или микропрограмму для железки.
    В C/C++ есть union
    В коде на C/C++ можно использовать ассемблерные вставки

    Как уже писали, из-за близости языка к ассемблеру и машинному коду, упрощается работа с структурами данных и указателями, отсутствуют проверки и прослойки, само исполнение кода производится быстрее. Не требуется наличие .NET Framework, можно создать программу, не требующую вообще никаких дополнительных библиотек и ПО.
    Ответ написан
  • Функция перебора всех подмножеств любого множества?

    lxsmkv
    @lxsmkv
    Test automation engineer
    Если считать в двоичном коде от нуля до n то все комбинации битов будут перебраны. Как вам такая мысль?
    Ответ написан
    3 комментария
  • Почему постоянно выбивает гугл каптчу?

    Steein
    @Steein
    Программист
    Данная проблема связана с политикой сетевой безопасности и настройками IP-фильтрации компании «Google».
    Ответ написан
    2 комментария
  • Какую http библиотеку посоветуете использовать?

    al_gon
    @al_gon
    Ответ написан
    Комментировать
  • Как применить динамическую память для хранения соразмерного количества символов с ввода?

    @abcd0x00
    Я так понял что инициализацию динамического массива надо делать внутри цикла и освобождать память здесь же.

    Нужно сначала выделить буфер, а потом войти в цикл и писать в него посимвольно. Если он переполняется, то, не выходя из цикла, нужно его увеличить (выделить новый, скопировать данные, освободить старый, поставить новый на место старого).
    Ответ написан
    7 комментариев
  • Какие знания по математике для создания игр на C++?

    chupasaurus
    @chupasaurus
    Сею рефлекторное, злое, временное
    От арифметики до теории гомотопий или струн. Всё зависит от проекта.
    Ответ написан
    3 комментария
  • Как зайти на сайт не указывая протокол?

    alsopub
    @alsopub
    Это называется "Редирект с http на https".
    Как? В зависимости от того что у вас - nginx, apache, можно на js.
    Ответ написан
    2 комментария
  • Высоконагруженные системы, каковы принципы разработки?

    Fesor
    @Fesor
    Full-stack developer (Symfony, Angular)
    давайте так, есть два вида задач:

    - CPU bound - различные алгоритмы, математика, кодирование/декодирование/шифрование... словом все что нагружает процессор.
    - I/O bound - собственно когда у нас идет множество операций с вводом/выводом, где-то 90% задач связанных с WEB и серверной разработкой.

    Для CPU bound стоит использовать языки вроде Си, Rust, Dlang, Go и т.д. Словом языки которые компилируются в эффективный машинный код.

    Для I/O bound - Go, NodeJS, Erlang, Java.... да в принципе не важно какой язык, главное что бы использовались неблокируемые вызовы и отсутствовали блокировки.

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

    Какие языки лучше использовать для этого? Какие не использовать?

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

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

    И на таких объемах даже если бы мы взял Си, если наш алгоритм имеет сложность O(N^2) то как бы ничего тут особо не поделать. И так и так медленно будет. А вот если мы возьмем какие-либо алгоритмы имеющие сложность O(NLogN) то уже возможно что алгоритм этот можно хоть на php/python/ruby имплементить. Так например у меня этот алгоритм реализован на Java и не самым эффективным образом. Справляется.

    Еще влияет скорость разработки (всякие ruby/python/node в этом плане хороши), стоимость поддержки (Си поддерживать сильно дороже чем Go например, хотя всегда можно написать все настолько плохо что проще выкинуть чем поддерживать), стоимость разработчиков.... Скажем найти дешевых сильных разработчиков на Go или Rust будет весьма проблематично.

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

    Собственно главное правило высоконагруженных систем - нагрузочное тестирование а потом уже оптимизации
    Ответ написан
    Комментировать