#|【C++】学习笔记[四]
文章目录
- 一、函数
-
- (一)函数声明、函数定义和函数调用
- (二)值传递
- (三)函数的份文件编写
- 二、指针
-
- (一)指针变量的定义和使用
- (二)指针所占的内存空间
- (三)空指针和野指针
- (四)const修饰指针
- (五)指针和数组
- (六)指针和函数
一、函数 (一)函数声明、函数定义和函数调用 作用:将一段经常使用的代码封装起来,减少代码重复
- 一个较大的程序,一般分为若干个程序块,每个模块实现特定的功能
#include
using namespace std;
int add(int a,int b);
//函数声明
//函数声明可以有多次,但是定义只有一次
//实现一个加法函数,传入两个数据,计算数据相加的结果,将结果返回
//函数定义
int add(int num1, int num2)//num1num2叫做形参
{ int sum = num1 + num2;
return sum;
}int main()
{ //a和b叫做实参
int a = 10;
int b = 20;
//函数调用
int sum = add(a, b);
//函数调用时实参会传递给形参
cout << sum << endl;
a = 100;
b = 500;
sum = add(a, b);
cout << sum << endl;
return 0;
}
文章图片
(二)值传递
- 所谓值传递,就是函数调用时实参将数值传入给形参
- 值传递时,如果形参发生改变,并不会影响实参
#include
using namespace std;
//如果函数不需要返回值,声明时可以写void
void Swap(int num1, int num2)
{ cout << "交换前:" << endl;
cout << "num1:" << num1 << endl;
cout << "num2" << num2 << endl;
//交换
int tmp = num1;
num1 = num2;
num2 = tmp;
cout << "交换后:" << endl;
cout << "num1:" << num1 << endl;
cout << "num2" << num2 << endl;
}int main()
{ //值传递
int a = 10;
int b = 20;
cout << "a:" << a << endl;
cout << "b:" << b << endl;
Swap(a, b);
cout << "a:" << a << endl;
cout << "b:" << b << endl;
return 0;
}
文章图片
从上面代码和运行结果来看,这个交换函数只是对形参变量进行了交换,而实参a和b还是原来的值,并没有给实参进行交换。
(三)函数的份文件编写 作用:让代码结构更加清晰
函数份文件编写一般有4个步骤:
- 创建后缀名为.h的头文件
- 创建后缀名为.cpp的源文件
- 在头文件中写函数的声明
- 在源文件中写函数的定义
文章图片
文章图片
文章图片
文章图片
二、指针 作用:可以通过指针间接访问内存
- 内存编号是从0开始记录的,一般用十六进制数字表示
- 可以用指针变量保存地址
#include
using namespace std;
int main()
{ //如何定义一个指针
int a = 10;
int* p = &a;
//指针p记录变量a的地址 cout << "a的地址为:" << &a << endl;
cout << "指针p为:" << p << endl;
//如何使用指针
//可以通过解引用的方式来找到指针所指向的内存
cout << "指针所指向的内存中的数据为:" << *p << endl;
cout << "a:" << a << endl;
*p = 1000;
cout << "*p的值为:" << *p << endl;
cout << "a的值为:" << a << endl;
return 0;
}
文章图片
(二)指针所占的内存空间
- 在32位操作系统中,指针占的内存为4个字节
- 在64位操作系统中,指针占的内存为8个字节
#include
using namespace std;
int main()
{ int a = 10;
int* pa = &a;
cout << "sizeof int *:" << sizeof(pa) << endl;
char b = 'b';
char* pb = &b;
cout << "sizeof char *:" << sizeof(pb) << endl;
double c = 34.7;
double* pc = &c;
cout << "sizeof double *:" << sizeof(pc) << endl;
return 0;
}
文章图片
(三)空指针和野指针 空指针:指针变量指向内存中编号为0的空间
用途:初始化指针变量
注意:空指针指向的内存是不可以访问的
#include
using namespace std;
int main()
{ int* p = NULL;
//*p = 100;
//运行时error 空指针不可以访问
//0-255之间的内存编号是系统占用的,因此不可以访问;
return 0;
}
野指针:指针变量指向非法的内存空间
#include
using namespace std;
int main()
{ //野指针----没有权力操纵的一块内存
int* p = (int*)0x1100;
cout << *p << endl;
//运行时崩溃 读取访问权限冲突 //在程序中尽量避免出现野指针
return 0;
}
结论:空指针和野指针都不是我们申请的空间,因此不能访问
(四)const修饰指针
- const修饰指针----常量指针----指针的指向可以修改,指针指向的值不可以修改
#include
using namespace std;
int main()
{ int a = 10;
int b = 10;
const int* p = &a;
//常量指针---指针的指向可以修改,指针指向的值不可以修改
*p = 20;
//error
p = &b;
//true
return 0;
}
- const修饰常量----指针常量----指针的指向不可以改变,指针指向的值可以改
#include
using namespace std;
int main()
{ int a = 10;
int b = 10;
int* const p = &a;
//指针常量---指针的指向不可以改变,指针指向的值可以改
*p = 20;
//true
p = &b;
//error
return 0;
}
- const既修饰指针,又修饰常量----指针的指向和指针指向的值都不可以被改变
#include
using namespace std;
int main()
{ int a = 10;
int b = 10;
const int* const p = &a;
//指针的指向和指针指向的值都不可以被改变
*p = 20;
//error
p = &b;
//error
return 0;
}
看const和*的位置:
const * //常量指
对解引用操作会出现问题* const //指针常量
对指针本身改变会出现问题
练习代码如下:
#include
using namespace std;
int main()
{ int arr[10] = {
1,2,3,4,5,6,7,8,9,10 };
int* p = arr;
//利用指针访问数组中的每个元素p++让指针p向后偏移4个字节(int型指针)
for (int i = 0;
i < 10;
i++)
{cout << *p << endl;
p++;
} return 0;
}
文章图片
(六)指针和函数 作用:利用指针作为函数参数,可以改变实参的值
练习代码如下:
#include
using namespace std;
void Swap(int *a, int *b)
{ int tmp = *a;
*a = *b;
*b = tmp;
}int main()
{ //地址传递----可以修改实参的值
int a = 10;
int b = 20;
Swap(&a, &b);
cout << "a:" << a << endl;
cout << "b:" << b << endl;
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 - 1 - i;
j++)
{if (arr[j] > arr[j + 1])
{int tmp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = tmp;
}
}
}
}void Printarr(int* arr, int len)//打印
{ for (int i = 0;
i < len;
i++)
{cout << arr[i] << " ";
}
cout << endl;
}int main()
{ int arr[10] = {
4,3,5,7,6,1,2,9,8,10 };
int len = sizeof(arr) / sizeof(arr[0]);
BubbleSort(arr, len);
Printarr(arr, len);
return 0;
}
???
加油!
推荐阅读
- 宽容谁
- 我要做大厨
- 增长黑客的海盗法则
- 画画吗()
- 2019-02-13——今天谈梦想()
- 远去的风筝
- 三十年后的广场舞大爷
- 叙述作文
- 20190302|20190302 复盘翻盘
- 学无止境,人生还很长