第一个C++程序
基础程序
使用DevC++5.4.0
写一个C++程序
在屏幕上打印hello world
#include <iostream>
using namespace std;int main()
{cout << "hello world" << endl;return 0;
}
运行这个C++程序
F9->编译
F10->运行
F11->编译+运行
main函数
main函数是程序的⼊⼝,C++的程序不管有多少⾏代码,都是从main函数开始执⾏的,main函
数也被叫做主函数。
main前⾯的int表⽰main函数执⾏结束的时候返回⼀个整型类型的值,⽽在main函数的最后写return 0; 正好前后呼应。
- main函数是程序的入口
- main函数有且只有一个
- 一个项目中可以有多个.cpp文件,但是只能有一个main函数(因为程序的入口只能有一个)
int - 数据类型 - 整型类型 - 表示整数
字符串
在C语⾔中,使⽤单引号括起来⼀个字符,表⽰字符字⾯值,即字符常量,⽐如: ‘1’ , ‘a’,使⽤双引号括起来多个字符表⽰⼀个字符串,⽐如: “abcdef” , “hello world” ,字符串中可以有⼀个或者多个字符,也可以没有任何字符, " " 表⽰空字符串。
上⾯代码中的 “hello world!” 就是⼀个字符串。这类字符和字符串表⽰的⽅式在C++也完全⽀持
的。
在C++的STL中⼜引⼊了string来表⽰字符串,功能更加强⼤,C语⾔不⽀持。
头文件
iostream 输入输出流,使⽤ #include <>
的形式进⾏包含。
iostream⽂件中的io指的是输⼊(进⼊程序的信息,简单理解就是可以给程序输⼊数据)
和输出(从程序中输出的信息,简单理解就是程序会打印数据在屏幕上)。
在C++程序中要完成输⼊和输出的操作会涉及到iostream⽂件中的多个定义,所以就要包含这个头⽂件。⽐如:代码中的cout是输出流对象,就是⽤来完成数据输出的,就需要包含头⽂件。
C++的编译器⾃带了很多头⽂件,每个头⽂件都⽀持⼀组特定的⼯具。
C++库函数相关头⽂件:C++ 标准库标头 - cppreference.com
在代码中如果使⽤了某个头⽂件中的定义,就得包含对应的头⽂件。
- 在C语⾔中头⽂件的扩展名是 .h ,但是C++中的⽤法发⽣了⼀些变化,对⽼式C的头⽂件保留了扩展名 .h ,但是C++⾃⼰的⽂件没有扩展名了。C语⾔头⽂件:C 标准库头文件 - cppreference.com
- 有些C的头⽂件被转换成C++头⽂件,这些⽂件名被重命名,去掉了.h扩展名,并在⽂件名的前⾯加上了前缀c(表⽰来⾃C语⾔);例如:C语⾔中有关数学的头⽂件名字是 math.h ,在C++中就是 cmath 。当然还得注意,有时头⽂件的C语⾔版本和C++版本相同,⽽有时候,新版本做了⼀些修改。
头文件类型 | 约定 | 实例 | 说明 |
---|---|---|---|
C++旧式风格 | 以.h结尾 | <iostream.h> | C++程序可以使⽤,⼀些新的IDE可能不再⽀持 |
C旧式风格 | 以.h结尾 | <math.h> | C、C++程序可以使用 |
C++新式风格 | 没有扩展名 | <iostream> | C++程序可以使用,使用namespace std |
转换后的C | 加上前缀,没有扩展名 | <cmath> | C++程序可以使用,可能包含不是C的特性 |
cin和cout初识
cout << "hello world!" << endl;
这句代码在上⾯的程序中是最重要的代码,其他所有的
代码都是为了编写这句代码。
代码中的 cout
是标准输出流对象(针对控制台,也就是屏幕),其实还有标准输⼊流对象(针对的是键盘) cin
。
cout
是告诉程序把后⾯双引号中的内容打印到标准输出设备(屏幕)上,双引号中的内容可以替换的。
#include <iostream>
using namespace std;int main()
{int num; // num 其实是一块空间,可以存放一个整数 cin >> num; // 输入操作, 输入一个整数存放在num中 cout << num; // 输出操作, 将num中的值打印在屏幕上 return 0;
}
- cin 和 cout 是全局的流对象,cin负责输⼊数据,cout负责输出数据。
- endl 是C++中⼀个特殊的操作符,效果是换⾏和刷新缓冲区,使⽤时必须包含在iostream头⽂件。
- << 是流插⼊运算符,和 cout 配合使⽤, >> 是流提取运算符,和 cin 配合使⽤。
- 使⽤C++输⼊输出更⽅便,不需要像 printf / scanf 输⼊输出时那样,需要⼿动控制格式。C++的输⼊输出可以⾃动识别变量类型。
#include <iostream>
using namespace std; int main()
{ float score = 0; cin >> score; // 直接读取的就是浮点数 cout << score; // 直接输出的就是浮点数 return 0;
}
名字空间
using namespace std;
这句代码的意思是:使⽤名字空间 std (名字空间也叫命名空间)。
为了理解什么是名字空间,名字空间要解决什么问题,⼤家先看⼀下下⾯的例⼦:
[!NOTE] eg
⼀个学校⾥学⽣可能有重名,假设这个学校有3个叫张三的同学,那么每次⽼师喊张三的时候,其他两个张三就会误会,是不是在喊⾃⼰,这就是因为这三个张三其实在同⼀个范围(空间)内的,就会名字的冲突。
但是如果这个学校的学⽣分为三个班,分别是1班、2班、3班,把三个张三分别安排在不同的班级,那么⽼师以后喊:1班的张三,那么2班、3班的张三就不会误会了,这是不是就很好的解决了名字冲突的问题。
Contents
其实这⾥的本质就是:
- 将名字进⾏了隔离
- 在使⽤名字之前先交待使⽤哪个班级的名字
在C++中,变量、函数和类都是⼤量存在的,这些变量、函数和类的名称如果都存在于全局作⽤域中,可能会导致很多冲突。使⽤ 名字空间 的⽬的是对标识符的名称进⾏隔离,以避免命名冲突或名字污染, namespace 关键字的出现就是针对这种问题的。
std 是C++标准库的名字空间名,C++将标准库的定义实现都放到这个命名空间中,当我们需要使⽤标准库中的内容时,就需要加上: using namespace std;
当有了这句代码的时候,表⽰名字空间 std 中信息都是可⻅和可⽤的,⽐如: cin 、 cout 、 endl 等。
直接使⽤ using namespace std;
是⼀种简单粗暴的做法,直接这样使⽤,就意味着后续在std 这个名字空间中的各种定义都可以直接使⽤,但是我们往往只是使⽤部分。所以名字空间其实也可以这样使⽤:
#incldue <iostream> int main()
{ std::cout << "hello world" << std::endl; return 0;
}
代码中的 std::cout 的意思就是使⽤ std 名字空间中的 cout
注释
C++⾥主要有两种形式:单⾏注释 //
和多⾏注释 /* */
注释本来是对代码进⾏解释的⽂字,要放在代码中,但是⼜⽆需编译。注释是给程序员⾃⼰看的,编译器会忽略注释,基于注释是被编译器忽略的这个特点,在代码中有些代码不再需要的时候也会使⽤注释的⽅式屏蔽。
单⾏注释:指的是当前⾏不参与编译和运⾏
多⾏注释:指的是被包含在内的多⾏不参与编译和运⾏
在VS环境中注释和取消注释的快捷键: Ctrl + K + C , Ctrl + K + U
在DevC++中注释和取消注释的快捷键: Ctrl + /