- MinGW — бесплатный С и С++ компилятор для Windows
- Обзор GCC
- Установка MinGW
- Borland C++ Compiler для Windows
- Отзывы о программе Borland C++ Compiler
- MinGW — c и c++ компилятор для Windows
- Войдите в MinGW
- Настройка процесса сборки
- С make
- С CMake
- Особенности библиотек
- А как насчет этих зависимостей?
- Библиотеки DLL
MinGW — бесплатный С и С++ компилятор для Windows
Предоставляет полный набор инструментов для компилирования и линковки программ без использования каких либо платных библиотек или инструментов.
Все утилиты предназначены для работы из командной строки, но могут использоваться такими популярными IDE как NetBeans, Eclipse и DevCPP, которые предоставляют графический интерфейс к компиляторам GCC.
Обзор GCC
GCC — GNU Compiler Collection, первый С компилятор с открытым исходным кодом, он был выпущен в 1987 г. Возможность создавать С++ программы была добавлена в 1992 г.
Впоследствии функциональность компилятора была расширена и включена поддержка таких языков программирования как Objective-C, Java, Fortran, ADA и другие.
GCC — очень мощный инструмент, распространяемый под лицензией GNU GPL (GNU General Public License), написан на языке С и в данный момент является кроссплатформенным — может работать практически под любой современной операционной системой и компилировать программы под различные типы процессоров, в том числе для микроконтроллеров, портативных устройств и 64-разрядных процессоров.
Установка MinGW
Официальный сайт MinGW http://www.mingw.org. Чтобы скачать комплект, перейдите на страницу http://sourceforge.net/downloads/mingw, вам понадобится файл «mingw-get-inst» с расширением EXE.
Для установки требуется подключение к сети интернет.
Рзмещайте все файлы по стандартному пути, например, «C:\MinGW».
В данном случае выбраны компилятор С и С++, инструменты для разработки и комплект утилит командной строки — MSYS.
Если всё выбрано правильно, жмём «Install».
Закройте окно установщика — нажмите «Finish».
Нам потребуется значение переменной PATH, там должны быть прописаны пути к папкам с исполняемыми файлами MinGW и MSYS, в данном случае это директории «C:\MinGW\bin» и «C:\MinGW\msys\1.0\bin».
Если эти значения не были автоматически добавлены в переменную в процессе установки, допишите их вручную, добавте в начало строку «C:\MinGW\bin;C:\MinGW\msys\1.0\bin;», только без кавычек.
Если в вашей операционной системе отсутствует переменная PATH, то создайте её самостоятельно.
Теперь, когда все инструменты установлены, можно использовать GCC компиляторы в режиме командной строки или настроить их использование в своей IDE.
Borland C++ Compiler для Windows
Оценка: |
4.38 /5 голосов — 480 |
Лицензия: | Бесплатная |
Версия: | 5.5.1 | Сообщить о новой версии |
Обновлено: | 30.08.2015 |
ОС: | Windows 8.1, 8, 7, Vista, XP |
Интерфейс: | Английский |
Разработчик: | Borland Software Corporation |
Категории: | C, C++, C# — Компиляторы |
Загрузок (сегодня/всего): | 5 / 308 657 | Статистика |
Размер: | 8,52 Мб |
СКАЧАТЬ |
Borland C++ Compiler — Компилятор языка программирования Borland C++ 5.5 Комментарии излишни.
Borland C++ Compiler — Компилятор языка программирования Borland C++ 5.5 Комментарии излишни.
Bloodshed Dev-C++ — Редактор и компилятор для написания программ на C++.
Resource Builder — профессиональный редактор ресурсов для Windows приложений. Предоставляет полный.
Система Русских Справок по C++Builder и Turbo C++ — система русских справок (файлов HELP) по C++Builder.
Convert .NET — конвертер языков программирования. Преобразует C # код в эквивалентный код VB.NET и.
Справочник по С++Builder — справочник с примерами и советами по программированию в среде С++Builder.
Отзывы о программе Borland C++ Compiler
Александр про Borland C++ Compiler 5.5.1 [17-06-2019]
эх, прошло уже 17 лет, а этой штукой всё ещё некоторые пользуются. Даже те, кого этот компилятор старше.
3 | 2 | Ответить
Сергей про Borland C++ Compiler 5.5.1 [31-03-2016]
для тех, кто не понял: это компилятор, а не интегрированная среда разработки.
А запуск компилятора через консоль — нормальная практика.
10 | 19 | Ответить
Юрик про Borland C++ Compiler 5.5.1 [14-04-2014]
А нельзя было сделать так, чтобы открыть можно было через ярлык.
9 | 15 | Ответить
dieudonne в ответ Юрик про Borland C++ Compiler 5.5.1 [19-03-2016]
Мишка про Borland C++ Compiler 5.5.1 [13-07-2012]
Советую создать в папке «Windows», ярлык «bcc32.exe»
И запускать в командной строке так:
«bcc32.lnk c:\. путь до файла\file.cpp»
Либо просто кидать исходники в папку «bin» и писать
«bcc32.lnk file.cpp»
11 | 15 | Ответить
Бесиев про Borland C++ Compiler 5.5.1 [13-07-2012]
Старая рухлядь. На свалку его пора, как и всей продукции Борланд.
Лучше компилятора чем Microsoft Visual C++ — НЕТ!
3 | 7 | Ответить
Алекс в ответ Бесиев про Borland C++ Compiler 5.5.1 [09-07-2014]
Может и рухлядь но вы обратите внимание на дату публикации.
В 2002 году вполне была актуальна.
2 | 2 | Ответить
MinGW — c и c++ компилятор для Windows
Если говорить о релизах современных видеоигр, то всегда возникает вопрос о многоплатформенной поддержке. Когда вы создаете браузерную игру, браузер — это ваша платформа, и вы действительно не беспокоитесь об ОС под ней. При использовании популярного движка вы можете проверить, работают ли различные версии, но вы все еще в основном полагаетесь на способность оригинальных разработчиков заставить его работать на всех платформах.
Но все совершенно по-другому, когда ваша игра работает без движка или использует движок вашего собственного производства. Вы должны сами позаботиться о том, чтобы программа работала нормально на тех платформах, которые вы хотите поддерживать. Но еще до запуска есть вопрос сборки – вы должны фактически скомпилировать программу для целевой платформы.
Одним из способов сделать это, конечно, является наличие машины, работающей на указанной платформе (возможно, в режиме мультизагрузки), которая поставляется со своим собственным набором неприятностей. Другое решение — кросс – компиляция, и именно это я вкратце опишу здесь.
Войдите в MinGW
Для кросс-компиляции программ на C / C++ большинство разработчиков используют MinGW – минималистичный GNU для Windows, который, как следует из названия, представляет собой набор программ (порты gcc, gdb и т. Д.), заголовков и статических библиотек, позволяющих кросс-компиляцию материала для MS Windows на других платформах.
Настройка среды MinGW с нуля может быть утомительной, но, к счастью, самый популярный дистрибутивный пакет MinGW сам по себе и порты MinGW некоторых библиотек находятся в их репозиториях. Установить компилятор MinGW из дистрибутива так же просто, как и любое другое программное обеспечение.
# При установке на 64-битную Windows
root $ dnfinstall mingw64-gcc mingw64-gcc-g++ mingw64-…
# При установке на 32-битную Windows
root $ dnf установите mingw32-gcc mingw32-gcc-g++ mingw32-…
Настройка процесса сборки
Как только вы установили компилятор, пришло время взглянуть на ваш собственный проект и его систему сборки.
С make
Если вы используете make для управления процессом сборки, то, скорее всего, ваш Makefile уже отлично работает для кросс-компиляции, и вам не нужно будет вносить никаких изменений.
В принципе, на этом этапе есть два требования:
- Должна быть возможность указать, какой компилятор C / C++ следует использовать (например, через CC)
- Должна быть возможность указывать флаги компоновщика (например, через LDLIBS)
Если вы используете жестко закодированное имя компилятора или флаги, то пришло время отредактировать файл Makefile и привести его в форму. Как только все это будет сделано, просто укажите флаги кросс-компилятора MinGW и специфичного для Windows компоновщика, и все готово.
# Для 64-битных сборок
user $ CC=x86_64-w64-mingw32-gcc LDLIBS=-lmingw32 make [args…]
# Для 32-битных сборок; аналогично приведенному выше, отличается только имя компилятора
user$ CC=i686-w64-mingw32-gcc LDLIBS=-lmingw32 make [args…]
Если вы компилируете C++, а не C, вы захотите использовать переменную CXX и …компилятор mingw32-gcc-g++.
С CMake
При использовании CMake вам нужно будет внести одно небольшое изменение в ваш CMakeLists.txt: то есть добавление библиотеки mingw32 в вашуtarget_link_libraries(). Вы можете посмеяться над этим и сказать: «О, я могу просто использовать — DCMAKE_EXE_LINKER_FLAGS», но проблема с использованием этой переменной заключается в том, что при вызове компилятора содержимое переменной помещается перед именами объектов, например:
x86_64-w64-mingw32-gcc -Wall -Wextra -lmingw32 -lm -o «build/my-game.exe» build/mygame.o build/stuff.o build/fluff.o
Поскольку порядок аргументов важен для компоновщика (библиотеки должны следовать за объектами, которые ссылаются на них), сборка, скорее всего, завершится неудачей с большим количеством ошибок «неразрешенной ссылки».
При указании библиотек через target_link_libraries () команда строится с именами библиотек, следующими за именами объектов, и все заканчивается прекрасно и денди. Как только вы внесете указанное изменение, продолжайте запускать CMake с помощью файла MinGWtoolchain.
# Для 64-битных сборок; другие дистрибутивы могут поместить файл toolchain под другой путь
user $ cmake-DCMAKE_TOOLCHAIN_FILE=/usr/share/mingw/toolchain-mingw64.cmake [args…]
# Для 32-битных сборок; то же самое, что и выше, но с использованием 32-битного профиля
user $ cmake-DCMAKE_TOOLCHAIN_FILE=/usr/share/mingw/toolchain-mingw32.cmake [args…]
# Как только файлы сборки будут сгенерированы с помощью правильного файла toolchain,
# вам больше не нужно ссылаться на него, и вы можете просто выполнить обычную сборку
Если вам кажется, что ваш дистрибутив не предоставляет готовый файл toolchain, вы можете попробовать взять его из Fedora и соответствующим образом отредактировать
Особенности библиотек
В зависимости от используемых библиотек могут потребоваться некоторые дополнительные шаги. Например, при использовании SDL2 вам также нужно будет добавить библиотеку SDL2main к флагам компоновщика. Причина этого заключается в том, что в MS Windows существует строгое разделение между «консольными» и «ГРАФИЧЕСКИМИ» программами – первые всегда порождают cmd.exe window (оболочка MS Windows), где они выполняют свой stdin/stdout IO, в то время как у вторых этого нет.
В то время как консольные программы начинают свое выполнение с функции main (), графические программы обычно начинают свое выполнение с функции WinMain ().
Чтобы избавить вас от необходимости иметь две версии вашей основной функции, статическая библиотека SDL2main предоставляет свою собственную реализацию WinMain(), которая выполняет некоторый дополнительный код инициализации SDL, а затем вызывает вашу основную функцию ().
Этот подход обычно встречается в других библиотеках – например, библиотеки программирования игр Allegro и SFML предоставляют свои соответствующие статические библиотеки allegro_main и sfml-main.
А как насчет этих зависимостей?
Написание игры с использованием собственного движка уже является мазохизмом, поэтому, если вы не пытаетесь достичь новых крайностей и используете только собственные API, ваша игра, вероятно, зависит от какой-то популярной мультимедийной библиотеки, такой как Allegro, SDL или SFML. Чтобы успешно скомпилировать вашу игру для MS Windows, вам также нужно позаботиться об этом.
Простой способ: установка зависимостей из дистрибутива репо
Если вам посчастливилось и весь ваш набор зависимостей имеет версии MinGW, доступные в менеджере пакетов, то просто установите что-нибудь из репозитория, и все будет в порядке.
root $ dnf install mingw64-SDL2 mingw64-SDL2_image mingw64-SDL2_mixer mingw64-SDL2_ttf
Способ средней сложности: установка предварительно скомпилированных зависимостей вручную
Хотя описанный выше сценарий, безусловно, самый простой, обработка зависимостей не так уж и сложна, если их авторы предоставляют файлы разработки MinGW. Например, рассмотрим библиотеку Аллегро. Релизы на GitHub содержат множество загружаемых вариантов каждой версии, среди которых есть наборы MinGWdev. Если вы загрузите один из них (выберите тот, который подходит для вашей цели кросс-компиляции) и распакуете архив, вы увидите такую структуру каталогов:
Каталоги в этом архиве содержат DLL-файлы (в bin/), заголовки (в include/) и файлы .a – проще говоря, все, что вам нужно, чтобы иметь возможность компилировать и связывать программу с Allegro, не компилируя саму Allegro. Теперь все, что осталось сделать, это скопировать эти файлы в MinGWroot – это /usr/x86_64-w64-mingw32/sys-root/mingw/ для 64-битных библиотек и /usr/i686-w64-mingw32/sys-root/mingw/ для 32-битных библиотек.
Сложный способ: компиляция зависимостей из исходного кода
В конце списка находится, конечно же, компиляция зависимостей из исходного кода. Хотя это и отнимает много времени, но все же относительно легко, так как вам просто нужно применить описанный выше подход к каждой нужной вам библиотеке.
По моему опыту, самая трудная часть компиляции всей цепочки зависимостей-это настройка каждого файла Makefile / CMakeLists.txt когда вы идете, чтобы заставить каждую библиотеку распознавать, где находятся ее зависимости – хотя вы можете избежать этого, установив каждую скомпилированную библиотеку в корневой каталог MinGW (если вы не возражаете против беспорядка, то есть).
Библиотеки DLL
Как только вы скомпилируете свою игру, последнее, что вам остается сделать, — это упаковать и опубликовать ее. Но для правильной работы исполняемого файла вам понадобятся все библиотеки DLL, от которых он зависит. Чтобы узнать, какие общие объекты динамически загружаемые библиотеки необходимы, вы можете использовать программу objdump:
user$ objdump -x my-awesome-game.exe | grep ‘Имя DLL:’
Теперь, когда вы знаете, какие библиотеки DLL необходимы, вам нужно найти и скопировать их. Если вы хотите сделать это вручную, имейте в виду, что библиотеки DLL могут зависеть от других библиотек DLL, поэтому захвата только прямых зависимостей EXE-файла вашей игры может быть недостаточно. Если вы ищете простой, автоматизированный способ, вы можете использовать copydeps, небольшую программу на Python, которая отлично подходит именно для этой цели.