创建新项目,选择创建C++的空项目:
选择项目名称与位置:
在源文件中添加C++文件:
# include
using namespace std;
int main()
{
// 不换行
cout << "hello world" ;
// 换行,换行加个 << endl
cout << "hello world" << endl;
// 所以说,这个就是单纯的换行
cout << endl;
system("pause");
return 0;
}
# include
using namespace std;
// 1.单行注释
/*
多行注释
*/
int main()
{
cout << "hello world" << endl;
system("pause");
return 0;
}
就是给一个指定的空间起名,方便操作这个空间。
创建变量:数据类型 变量名 = 变量初始值;
常量:记录程序中不可更改的数据
定义常量的方法:
# include
using namespace std;
# define Weekday 7
int main()
{
const int a = 10;
cout << "a = " << a <<endl;
cout << "一周有:" << Weekday << "天" << endl;
system("pause");
return 0;
}
数据类型存在的意义: 给变量分配一个合适的内存空间。
科学计数法:
数据类型 | 占用空间 | 取值范围 |
---|---|---|
short(短整型) | 2字节 | (-215 ~ 215-1 ) |
int(整形) | 4字节 | (-231 ~ 231-1 ) |
long(长整形) | Windows为4字节,Linux为4字节(32位),8字节(64位) | (-231 ~ 231-1 ) |
long long(长长整形) | 8字节 | (-263 ~ 263-1 ) |
统计数据类型所占内存大小
数据类型 | 占用空间 | 有效数字范围 |
---|---|---|
float(单精度) | 4字节 | 7位有效数字 |
double(双精度) | 8字节 | 15~16位有效数字 |
用于表示单个字母
# include
using namespace std;
int main()
{
char ch = 'a';
cout << ch << endl;
cout << sizeof(ch) << endl;
/*
a
1
*/
// 字符型变量对应的ASCII编码
// a 97
// A 65
cout << (int)ch << endl;
// 97
// 可以通过ASCII给字符型变量赋值
char ch2 = 98;
cout << ch2 << endl;
// b
system("pause");
return 0;
}
常见错误:
ASCII值 | 控制字符 | ASCII值 | 字符 | ASCII值 | 字符 | ASCII值 | 字符 |
---|---|---|---|---|---|---|---|
0 | NUT | 32 | (space) | 64 | @ | 96 | ` |
1 | SOH | 33 | ! | 65 | A | 97 | a |
2 | STX | 34 | " | 66 | B | 98 | b |
3 | ETX | 35 | # | 67 | C | 99 | c |
4 | EOT | 36 | $ | 68 | D | 100 | d |
5 | ENQ | 37 | % | 69 | E | 101 | e |
6 | ACK | 38 | & | 70 | F | 102 | f |
7 | BEL | 39 | , | 71 | G | 103 | g |
8 | BS | 40 | ( | 72 | H | 104 | h |
9 | HT | 41 | ) | 73 | I | 105 | i |
10 | LF | 42 | * | 74 | J | 106 | j |
11 | VT | 43 | + | 75 | K | 107 | k |
12 | FF | 44 | , | 76 | L | 108 | l |
13 | CR | 45 | - | 77 | M | 109 | m |
14 | SO | 46 | . | 78 | N | 110 | n |
15 | SI | 47 | / | 79 | O | 111 | o |
16 | DLE | 48 | 0 | 80 | P | 112 | p |
17 | DC1 | 49 | 1 | 81 | Q | 113 | q |
18 | DC2 | 50 | 2 | 82 | R | 114 | r |
19 | DC3 | 51 | 3 | 83 | S | 115 | s |
20 | DC4 | 52 | 4 | 84 | T | 116 | t |
21 | NAK | 53 | 5 | 85 | U | 117 | u |
22 | SYN | 54 | 6 | 86 | V | 118 | v |
23 | TB | 55 | 7 | 87 | W | 119 | w |
24 | CAN | 56 | 8 | 88 | X | 120 | x |
25 | EM | 57 | 9 | 89 | Y | 121 | y |
26 | SUB | 58 | : | 90 | Z | 122 | z |
27 | ESC | 59 | ; | 91 | [ | 123 | { |
28 | FS | 60 | < | 92 | \ | 124 | | |
29 | GS | 61 | = | 93 | ] | 125 | } |
30 | RS | 62 | > | 94 | ^ | 126 | ~ |
31 | US | 63 | ? | 95 | - | 127 | DEL |
作用: 用于显示一些不能直接表示出来的ASCII字符。
转义字符 | 含义 | ASCII码值(十进制) |
---|---|---|
\a | 警报 | 007 |
\b | 退格(BS)将当前位置移到前一列 | 008 |
\f | 换页(FF)将当前位置移到下页开头 | 012 |
\n | 换行(LF)将当前位置移到下一行开头 | 010 |
\r | 回车(CR)将当前位置移到本行开头 | 013 |
\t | 水平制表(HT)(跳到下一个TAB位置) | 009 |
\v | 垂直制表(VT) | 011 |
\\ | 代表一个反斜线字符"\" | 092 |
\’ | 代表一个单引号字符 | 039 |
\" | 代表一个双引号字符 | 034 |
\? | 代表一个问号 | 063 |
\0 | 数字0 | 000 |
\ddd | 8进制转义字符,d范围0~7 | 3位8进制 |
\xhh | 16进制转义字符,h范围09,af,A~F | 3位8进制 |
表示一串字符
代表真或者假的值
只有两个值:
他们本质上就是0或者1,bool类型就占1个字节大小。
从键盘获取数据
关键字:cin
# include
using namespace std;
int main()
{
// 1.整形
int a = 0;
cout << "请给整型变量a赋值:" << endl;
cin >> a;
cout << "整型变量 a = " << a << endl;
// 2.浮点型
float f = 3.14f;
cout << "请给浮点型变量f赋值:" << endl;
cin >> f;
cout << "整型变量 f = " << f << endl;
// 3.字符型
char ch = 'a';
cout << "请给字符型变量ch赋值:" << endl;
cin >> ch;
cout << "整型变量 ch = " << ch << endl;
system("pause");
return 0;
}
运算符类型 | 作用 |
---|---|
算术运算符 | 用于处理四则运算 |
赋值运算符 | 用于将表达式的值赋给变量 |
比较运算符 | 用于表达式的比较 |
逻辑运算符 | 用于根据表达式的值返回真值或假值 |
运算符 | 术语 | 解释 |
---|---|---|
+ | 正号 | 符号 |
- | 负号 | 符号 |
+ | 加 | |
- | 减 | |
* | 乘 | |
/ | 除 | |
% | 取模(取余) | 取余数(两个小数是不能取模的) |
++ | 前置递增 | 先加一,后表达式的运算 |
++ | 后置递增 | 先表达式的运算,后加一 |
– | 前置递减 | 同上 |
– | 后置递减 | 同上 |
运算符 | 术语 |
---|---|
= | 赋值 |
+= | 加等于 |
-= | 减等于 |
*= | 乘等于 |
/= | 除等于 |
%= | 模等于 |
运算符 | 术语 |
---|---|
== | 等等于 |
!= | 不等于 |
> | 大于 |
< | 小于 |
>= | 大于等于 |
<= | 小于等于 |
运算符 | 术语 |
---|---|
! | 非 |
|| | 或 |
&& | 与 |
# include
using namespace std;
int main()
{
int score = 0;
cout << "请输入您的分数:" << endl;
cin >> score;
// 单行if语句:if(条件) {条件满足执行的语句}
if(score>=60){
cout << "您及格了" << endl;
}
// 多行if语句:if(条件) {条件满足执行的语句} else {条件未满足执行的语句}
if(score>=60){
cout << "您及格了" << endl;
}else{
cout << "您未及格" << endl;
}
// 多条件的if语句:if(条件1) {条件1满足执行的语句} else if (条件2) {条件2满足执行的语句}...... else {所有条件都未满足执行的语句}
if(score>=90)
{
cout << "成绩优秀" << endl;
}
else if(score>=60)
{
cout << "成绩及格" << endl;
}
else
{
cout << "未及格" << endl;
}
// 嵌套if语句:if(条件1) {if(条件2){if(条件3){}}}
if(score>=60)
{
cout << "成绩及格" << endl;
if(score>=90)
{
cout << "成绩优秀" << endl;
}
}
else
{
cout << "未及格" << endl;
}
system("pause");
return 0;
}
# include
using namespace std;
int main()
{
// 表达式1?表达式2:表达式3;
// 如果表达式1为真则执行表达式2,否则执行表达式3
// 输出最大数
int a = 10;
int b = 20;
int max = a>b?a:b;
cout << max << endl;
system("pause");
return 0;
}
# include
using namespace std;
int main()
{
// 多条件分支语句
/*
switch(表达式)
{
case 结果1:
执行语句;
break;
case 结果2:
执行语句;
break;
case 结果3:
执行语句;
break;
case 结果4:
执行语句;
break;
...
default:执行语句;break;
}
*/
system("pause");
return 0;
}
系统生成随机数:
//time系统时间头文件
# include
// 添加随机数种子,利用当前系统时间生成随机数,防止每次随机数都一样。
srand((unsigned int)time(NULL));
rand() % 100 + 1;
// rand() 生成随机数
// rand() % 100 生成 0 ~ 99 的随机数
// rand() % 100 + 1 生成 1 ~ 100 的随机数
# include
using namespace std;
int main()
{
/*
while(循环条件)
{
循环语句
}
*/
system("pause");
return 0;
}
# include
using namespace std;
int main()
{
/*
先执行一遍循环语句,再进行判断循环。
do
{
循环语句;
}
while(循环条件);
*/
system("pause");
return 0;
}
# include
using namespace std;
int main()
{
/*
for(起始表达式;条件表达式;末尾循环体)
{
循环语句;
}
*/
system("pause");
return 0;
}
# include
using namespace std;
int main()
{
/*
for(起始表达式;条件表达式;末尾循环体)
{
循环语句;
for(起始表达式;条件表达式;末尾循环体)
{
循环语句;
}
}
*/
system("pause");
return 0;
}
跳出选择结构或循环结构
作用: 在循环语句中,跳过本次循环中余下尚未执行的语句,继续执行下次循环。
不推荐使用
# include
using namespace std;
int main()
{
/*
作用:无条件跳转
用法:goto 标记; 执行到goto语句时,如果标记的名称存在,会跳转到标记的位置。
*/
cout << "第一个" << endl;
goto FLAG;
cout << "第二个" << endl;
cout << "第三个" << endl;
FLAG:
cout << "第四个" << endl;
cout << "第五个" << endl;
cout << "第六个" << endl;
system("pause");
return 0;
}
数组就是里面放着相同元素的一个集合
特点:
作用: 将一段经常使用的代码封装起来,减少代码重复,较大程序会分为若干个程序块,每个模块实现特定的功能。
/*
语法:
返回值类型 函数名(参数列表)
{
函数体语句
return表达式
}
*/
# include
using namespace std;
// 函数的声明:如果要调用的函数定义在需要调用它的后面,则需要声明函数。
int add(int num1,int num2);
int main()
{
int a = 1;
int b = 2;
// 调用函数的时候,传过去的a,b有实际的数值,他们成为实参。
int c = add(a, b);
cout << "c=" << c << endl;
system("pause");
return 0;
}
// 定义的时候num1与num2没有真正的数据,此时它是形参。
int add(int num1, int num2)
{
int sum = num1 + num2;
return sum;
}
注意: 值传递时形参在函数中发生任何改变,都不会影响实参值。
作用: 让代码结构更清晰
步骤:
// swap.h
# include
using namespace std;
// 函数的声明
void swap(int a, int b);
// swap.cpp
# include "swap.h"
void swap(int a, int b)
{
int temp = a;
a = b;
b = temp;
cout << "a = " << a << endl;
cout << "b = " << b << endl;
}
// main函数所谓源文件
# include
# include "swap.h"
// 使用双引号括起来是自己写的,使用尖括号括起来是调用别人写的。
using namespace std;
int main()
{
int a = 1;
int b = 2;
swap( a, b);
system("pause");
return 0;
}
作用: 通过指针间接访问内存。
# include
using namespace std;
int main()
{
// 定义指针
int a = 10;
// 指针定义的语法:数据类型 * 指针变量名;
int * p;
//指针变量记录变量a的地址
p = &a;
// 使用指针
cout << "a的地址为:" << &a << endl;
cout << "a的地址为:" << p << endl;
// 可以通过解引用的方式找到指针指向的内存存储的值。
cout << "指针p指向内存空间所存储的值" << *p << endl;
// 可以通过这种方式来改变指定内存空间存储的值
*p = 100;
cout << "a = " << a << endl;
cout << "*P = " << *p << endl;
system("pause");
return 0;
}
在32位操作系统下指针所占内存空间固定为4字节,64位操作系统为8字节(无论是int、double… 各种类型的指针都一样)
空指针: 指针变量指向内存中编号为0的空间。
用途: 初始化指针变量。
注意: 空指针指向的内存是不可以访问的。
野指针: 指针变量指向非法的内存空间,在程序中避免出现野指针。
// 定义空指针
int *p = NULL;
// 定义野指针
int *p = (int *)0x1234;
// 0x1234这个内存空间并不是自己的,没有操作它的权限。
const修饰指针的三种情况:
/*
常量指针
特点:指针的指向可以修改,但是指针指向的值不可以修改。
*/
const int * p = &a;
/*
指针常量
特点:指针的指向不可以修改,指针指向的值可以修改。
*/
int * const p = &a;
/*
const即修饰指针,又修饰常量
特点:指针的指向不可以修改,指针指向的值也不可以修改。
*/
const int * const p = &a;
# include
using namespace std;
void swap(int * p1, int * p2)
{
int temp = *p1;
*p1 = *p2;
*p2 = temp;
}
int main()
{
int arr[10] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
// 利用指针访问数组中的元素
int *p = arr; // arr就是数组的首地址
cout << "利用指针访问第一个元素:" << *p << endl;
p++; // 让指针向后便宜4个字节,此时指针指向第二个元素。
cout << "利用指针访问第二个元素:" << *p << endl;
cout << "利用指针遍历数组:" << endl;
// 利用指针便利数组
int * p2 = arr;
for (int i = 0; i < 10; i++)
{
cout << *p << endl;
p++;
}
//地址传递,会改变实参值
int a = 10;
int b = 20;
swap(&a, &b);
cout << "交换后的a:" << a << endl;
cout << "交换后的b:" << b << endl;
system("pause");
return 0;
}
// 封装一个使用冒泡排序对整形数组进行升序排列的函数
# include
using namespace std;
void bubbleSort(int * arr, int len)
{
for(int i = 0; i < len - 1; i++)
{
for(int j = 0; j < len - i - 1; j++)
{
if(arr[j] > arr[j+1])
{
int temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
}
int main()
{
int arr[10] = {4, 3, 6, 9, 1, 2, 7, 5, 8};
bubbleSort(arr, 9);
system("pause");
return 0;
}
结构体属于用户自定义的数据类型,允许用户存储不同的数据类型
语法: struct 结构体名 {结构体成员列表};
通过结构体创建变量的三种方式:
#include
using namespace std;
#include
struct Student
{
string name;
int age;
int score;
}s3;
// 定义结构体的时候顺便创建变量
int main()
{
// struct关键字在创建变量时可以省略
struct Student s1;
s1.name = "张三";
s1.age = 15;
s1.score = 90;
struct Student s2 = {"李四", 16, 89};
s3.name = "王五";
s3.age = 16;
s3.score = 91;
system("pause");
return 0;
}
结构体数组: struct 结构体名 数组名[元素个数] = {{},{},{},…}
通过指针访问结构体中的成员
#include
using namespace std;
#include
struct Student
{
string name;
int age;
int score;
};
int main()
{
// 创建学生结构体变量
Student s = {"张三", 18, 100};
// 通过指针指向结构体变量
Student *p = &s;
// 通过指针访问结构体变量中的数据
cout << "姓名:" << p->name << "年龄:" << p->age << "分数:" << p->score << endl;
system("pause");
return 0;
}
#include
using namespace std;
#include
struct Student
{
string name;
int age;
int score;
};
struct Teacher
{
int id;
string name;
int age;
struct Student stu;
};
int main()
{
// 创建老师
Teacher t;
t.id = 100;
t.name = "老王";
t.age = 50;
t.stu.name = "小王";
t.stu.age = 18;
t.stu.score = 89;
cout << "老师的姓名:" << t.name << "老师的年龄:" << t.age << "老师的编号:" << t.id << << "老师的学生的姓名:" << t.stu.name << "老师的学生的年龄:" << t.stu.age << "老师的学生的成绩:" << t.stu.score << endl;
system("pause");
return 0;
}
与普通的参数一样,值传递只是传递值,改变形参不会改变实参。
作用: 防止误操作
#include
using namespace std;
#include
struct Student
{
string name;
int age;
int score;
};
void printStudents(const Student * s)
{
//s->age = 100; // 使用const修饰后,一旦有修改的操作就会报错,可以防止误操作。
// 在这里,如果不使用地址传递,直接用值传递,就算修改了也不会改变最原始数据的值,那么为什么不用呢?
// 因为如果使用值传递,就需要重新开辟一块地址空间,如果传过来的数据量太大,会消耗大量空间,而使用地址传递,只需要开辟一块指针的空间。
cout << "学生姓名:" << s->name << " 年龄:" << s->age << " 分数:" << s->score << endl;
}
int main()
{
// 创建学生结构体变量
Student s = {"张三", 18, 100};
printStudents(s);
cout << "姓名:" << s.name << "年龄:" << s.age << "分数:" << s.score << endl;
system("pause");
return 0;
}