Windows系统下GCC配置, MinGW-W64 GCC安装与配置,Dev-C++、CodeBlocks

2024-01-20 22:10

本文主要是介绍Windows系统下GCC配置, MinGW-W64 GCC安装与配置,Dev-C++、CodeBlocks,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在Windows系统下,除微软的VS外,大多使用GCC作为编译,现在的GCC并不是只能在Linux系统上才能使用的编译器,早已移值到了Windows系统下了。

由于VS的庞大,很多人员只是学习一下C/C++语言,庞大的VS功能大多是用不到的,这时在Windows系统下GCC就是一个不错的选择。(需要学习Windows下应用程序开发的建议还是使用VS做为开发工具

现在的GCC其实是一个套件,可以编译C语言程序,也可以编译C++语言程序

编译C语言可以使用:gcc 命令

编译C++语言可以用:g++ 命令

Windows系统下的IDE集成GCC编译器有:Dev-C++(Dev CPP)、CodeBlocks等常见的IDE里。

Dev-C++(Dev CPP)、CodeBlocks 所使用的GCC
Dev-C++ v5.11gcc version 4.9.2 (tdm64-1)
CodeBlocks v17.12gcc version 5.1.0 (tdm-1)

GCC各发行版简介:

MinGW、MinGW-w64、TDM-GCC编译之间的区别
MinGW只有32位版---------------不推荐使用
MinGW-w64提供 32位和64位--------更新最快,基本上gcc更近后几周内就会跟进
TDM-GCC提供32位和64位---------更新速度也不怎么样

编译器或IDE下载地址:

MinGW:http://www.mingw.org

MinGW-w64:http://www.mingw-w64.org

TDM-GCC:http://tdm-gcc.tdragon.net

Dev-C++ v5.11:https://sourceforge.net/projects/orwelldevcpp

CodeBlocks v17.12:http://www.codeblocks.org


MinGW-W64 GCC安装与配置

MinGW-w64下载地址:https://sourceforge.net/projects/mingw-w64/files/

选择合适的版本

i686纯32位版供32位win系统使用
x86_64是64位系统用的版本

seh结尾是纯64位编译
sjlj结尾是32 64两种编译,需加-m32或-m64参数

posix通常用于跨平台,比win32兼容性好一些

 我这里选择的是:MinGW-W64 GCC-8.1.0 x86_64-posix-sjlj  (已经编译好的压缩包,并非在线安装程序)


配置过程:

  1. 下载压缩包
  2. 将压缩包解压到硬盘
  3. 配置编译环境

假设我这里将下载的压缩包解压到:D:\mingw64 目录下


配置环境变量(以Win7为例Win10类似):

 简便操作过程:

右击“计算机” --》属性 --》高级系统设置 --》环境环境 --》系统变量 --》“Path”变量 --》编辑,追加 ;D:\mingw64\bin

设置系统环境变量具体步骤

详细操作过程:

在桌面选择“计算机” --》右击选择“属性” --》进入“控制面板\所有控制面板项\系统”选项 --》选择左边的“高级系统设置” --》弹出的系统属性,选择“环境变量” --》在系统环境变量里,找到变量名为“Path” --》双击“Path”变量 --》在结尾追加“;D:\mingw64\bin”

Windows的“Path”环境变量是以分号为分隔符(“;”是英文的分号),不是中文的分号,切记!最后一个“Path”环境变量不需要分号!


验证环境是否安装

开始菜单 ---> 附件 ---> “命令行提示符”  或 “Win键+R”组合键,输入:cmd

在命令行下输入:gcc -v

如有输出GCC信息则配置成功,配置成功如图:

MinGW-W64 GCC 配置成功输出信息

 环境变量添加错误将会提示无效命令。

添加make命令

make命令是Linux上用的比较多的命令,方便面快捷的编译C/++程序。

进入D:\mingw64\bin目录,拷贝复制一份“mingw32-make.exe”在该目录,并重命名为“make.exe”

MinGW-W64默认把它命名为“mingw32-make.exe”文件名,也可以直接更改该文件名为“make.exe”,这里为了以后有其它的工具会调用到“mingw32-make.exe”,特复制一份并命名为“make.exe”文件而已。


Dev-C++、CodeBlocks环境变量添加

Dev-C++和CodeBlocks想要在控制台下使用,请添加如下环境变量到系统的“Path”变量当中

这里我的假设是将Dev-C++和CodeBlocks安装在D盘上,如不是安装在D盘下,请自行更改相应的目录

Dev-C++: D:\Dev-Cpp\MinGW64\bin

CodeBlocks: D:\CodeBlocks\MinGW\bin

make命令也是进入相应的 bin 目录复制“mingw32-make.exe”文件并重命名为“make.exe”文件


编译第一个C/C++源代码文件

源代码:

// tex.c
#include <stdio.h>int main(void)
{printf("Hello World\n");return 0;
}

编译运行:

编译C源代码文件,并运行编译好的程序

小技巧:

在命令行下经常需要切换目录,是一件比较麻烦的一件事。可以新建个“*.bat”文件,内容为"start",将该批处理文件放置到所建的工程目录下,要使用命令行时,直接双击打开就可以了,不用切换目录了。


GCC、make命令及Makefile简单介绍

CGG参数(更多参数请输入:gcc --help)

选项说明
-E只进行预编译,代码送往标准输出
-S

编译生成汇编代码

-c编译生成目标文件”.o”,不链接成可执行文件
-o out_filename保存为指定的文件名,不指定默认为a.*文件
-g在可执行程序中包含标准调试信息,要调试源文件须添加
-On这里的“n”指的是数字,选择程序要使用的优化级别,分别为-O1,-O2,-O3,一般使用-O2就可以了
-std=选择C准备,如:C99,C11等(例:-std=c11)
-Wall

打开所有类型语法警告,建议养成使用该选项的习惯(不包括-pedantic选项)

-pedantic

能够帮助程序员发现一些不符合ANSI/ISO C标准的代码(如未定义行为提示)

make命令

make命令执行时,需要一个 Makefile 文件,以告诉make命令需要怎么样的去编译和链接程序。

Makefile文件简介

makefile带来的好处就是——“自动化编译”,一旦写好,只需要一个make命令,整个工程完全自动编译,极大的提高了软件开发的效率。make是一个命令工具,是一个解释makefile中指令的命令工具,一般来说,大多数的IDE都有这个命令,比如:Delphi的make,Visual C++的nmake,Linux下GNU的make。可见,makefile都成为了一种在工程方面的编译方法。

 Makefile文件是没有文件名后缀的,就一个名为“Makefile”的文件

更多的Makefile文件资料请自行搜索查看

下边贴出我常用测试使用的Makefile文件,“#”开头为注释,请按提示修改相应选项

all : tex# 请根据自己的工程修改相应的选项内容,文件为*nix(unix,Linux)格式,可用Notepad++等打开
# Windows系统记事本打开不会换行# 要编译的常用参数选项
CFLAGS=	-Wall -pedantic -O2#要编译的文件名
obj = tex
#要编译文件后缀
suffix = .c
#要使用的编译器(gcc或g++)
cc = gcc
#编译标准(C:-std=c11,C++:-std=c++14)
Std = -std=c11
#要编译成32或64位程序
Bit = -m32
#编译文件需要连接的其它库文件CFLAGS+= $(Std)
CFLAGS+= $(Bit)tex : $(obj)$(suffix)$(cc) $(obj)$(suffix) $(CFLAGS) $(LINK) -o $(obj)@./$(obj)@echo Error : %ERRORLEVEL%.PHONY : clean
clean:-del $(obj).exe

将上边内容保存为一个“Makefile”,记得第一个字母为大写,其它都是小写(Windows会稍微宽一些,全小写也可以),并把“Makefile”文件放在要编译的C/C++源文件目录下,打开命令行执行:make

# 执行编译
D:\测试时间>make
gcc tex.c -Wall -pedantic -static -O2 -std=c11 -m32  -o tex
Hello World
Error : 0# 执行清除
D:\测试时间>make clean
del tex.exeD:\测试时间>

 简单的一个C编译工程:Hello World目录

简单的一个学习测试目录文件​​​​​

 编译并执行、清除文件:

make命令截图

本文中用的测试文件:https://gitee.com/duke56/test_time

本文没有啥技术含量,纯粹是给C/C++新学员参考配置学习环境用的!

这篇关于Windows系统下GCC配置, MinGW-W64 GCC安装与配置,Dev-C++、CodeBlocks的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/627505

相关文章

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

Centos7安装Mongodb4

1、下载源码包 curl -O https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-4.2.1.tgz 2、解压 放到 /usr/local/ 目录下 tar -zxvf mongodb-linux-x86_64-rhel70-4.2.1.tgzmv mongodb-linux-x86_64-rhel70-4.2.1/

基于人工智能的图像分类系统

目录 引言项目背景环境准备 硬件要求软件安装与配置系统设计 系统架构关键技术代码示例 数据预处理模型训练模型预测应用场景结论 1. 引言 图像分类是计算机视觉中的一个重要任务,目标是自动识别图像中的对象类别。通过卷积神经网络(CNN)等深度学习技术,我们可以构建高效的图像分类系统,广泛应用于自动驾驶、医疗影像诊断、监控分析等领域。本文将介绍如何构建一个基于人工智能的图像分类系统,包括环境

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

hadoop开启回收站配置

开启回收站功能,可以将删除的文件在不超时的情况下,恢复原数据,起到防止误删除、备份等作用。 开启回收站功能参数说明 (1)默认值fs.trash.interval = 0,0表示禁用回收站;其他值表示设置文件的存活时间。 (2)默认值fs.trash.checkpoint.interval = 0,检查回收站的间隔时间。如果该值为0,则该值设置和fs.trash.interval的参数值相等。

NameNode内存生产配置

Hadoop2.x 系列,配置 NameNode 内存 NameNode 内存默认 2000m ,如果服务器内存 4G , NameNode 内存可以配置 3g 。在 hadoop-env.sh 文件中配置如下。 HADOOP_NAMENODE_OPTS=-Xmx3072m Hadoop3.x 系列,配置 Nam

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<

wolfSSL参数设置或配置项解释

1. wolfCrypt Only 解释:wolfCrypt是一个开源的、轻量级的、可移植的加密库,支持多种加密算法和协议。选择“wolfCrypt Only”意味着系统或应用将仅使用wolfCrypt库进行加密操作,而不依赖其他加密库。 2. DTLS Support 解释:DTLS(Datagram Transport Layer Security)是一种基于UDP的安全协议,提供类似于