C语言指针的学习一

C指针详解


C指针功能强大,但是由于太过灵活,学习指针有一定难度。
我们先从一道题目开始说起:

题目描述:
int n = 0;
int *p = &n
int **q = &q;
问下面那个赋值是正确的:
A :p = 1
B : *q = 2
C : p = q
D : *p = 5

在看题目的时候不知道你是否有这样的疑惑:
我们一般学习的指针定义与赋值如下:

int  a = 5        //定义一个整型变量a 
int * p = NULL     //定义一个整型指针p,初始化指针
p = &a            //将a变量的内存空间赋值给指针p 
printf("%d\n",*p) // 输出 *p = 20

那么int *p = &n 表示什么呢?是表示p指向&n?还是*p指向&n?
为了搞清楚,我使用IDE编写如下程序:

#include<stdio.h> 
int main()
{
	int n = 0;
	int * p = &n;
	int ** q = &p;

	printf("&n : %d\n",&n);
	printf("n : %d\n\n",n);
	
	printf("&p : %d\n",&p);
	printf("p : %d\n",p);
	printf("*p : %d\n\n",*p);
	
	printf("q : %d\n",q);
	printf("*q : %d\n",*q);
	printf("**q : %d\n\n",**q);
	
	return 0;
}

运行结果如下:
在这里插入图片描述

看到运行结果,想必你也已经明白了,p指向&n ,*p = n
那么后面的二重指针q 就是 *q 指向p
三者之前的关系如下图所示:
在这里插入图片描述
疑惑解决,在回来看题目:
A选项:p是一个一重指针,指向n的空间地址,不能直接赋值为1
B选项:q 是二重指针,*q = p ,所以同样不能赋值
C选项:p = q ,不同类型的指针不能赋值
D选项:*P = 5 ,p指向5的空间地址。
所以题目答案为D
这题就选择而言是比较简单的,但由这题我们可以看出指针的灵活。
下面简单将一些关于指针最基本的应用于运算。

1、指针的初始化

指针没有初始化,例如:

int * p;
*p = 5;

由于指针没有初始化,我们无法确定5这个值存储的位置,如果指针恰好指向非法区域,程序就会出现运行错误,程序会终止
还有一种更可怕的情况,指针指向的是合法的区域,但是这个位置好存放的数据非常重要,但是你执行完赋值语句后,这个数据就会被覆盖为5,这样整个程序会出现给中不可预料的情况(上一种情况我遇到过,但这种情况我没有实际遇到过)。
所以,在使用一个指针之前必须确定这个指针已经初始化了。

程序说明
int * p = NULL;UNLL 是地址0,p初始化指向0
int a;int * p = &ap初始化a的空间地址

如果只是自己做一个小作品或者只是为了竞赛做题(ACM,NOI,NOIP等等)两种初始化方式都是可以的。
但如果你是做一个工程项目(有其他参与的人),如果你已经知道了这个指针需要指向的位置,就把他初始化为这个位置,如果无法确定,就初始化为NULL。

2、指针的+,-运算

#include<stdio.h>
int main()
{
	int a[10] = {2,5,6,9,8,2,3,4,1,3};
	int * p = a;
	printf("%d\n",*p);
	printf("%d\n",*p + 2);
	printf("%d\n",*(p + 2)); 
	p = p + 3;
	printf("%d\n",*p);
	p --;
	printf("%d\n",*p);
	return 0;
}

运行结果:
在这里插入图片描述

3、无类型的指针

    void * p = NULL;
#include<stdio.h>
int main()
{
	void * p;
	int a = 10;
	double b = 1.25;
	char c = 'a';
	
	p = &a;
	printf("a : %d\n",*(int*)p);

	p = &b;
	printf("b : %lf\n",*(double*)p);

	p = &c;
	printf("c : %c\n",*(char*)p); 
	return 0;
}

运行结果:
在这里插入图片描述

4、多重指针

多重指针就是我们讲解的那个题目中的指针q就是一个二重指针

int n = 0;
int * p = &n;
int ** q = &p;

例程

#include<stdio.h>
int main()
{
	int a = 10;
	int *p = &a;
	int **q = &p;
	
	printf("a : %d\n",a);
	printf("*p : %d\n", *p);
	printf("**q : %d\n",**q);
	 
	return 0;
}

运行结果:
在这里插入图片描述

内容概要:本文系统介绍了算术优化算法(AOA)的基本原理、核心思想及Python实现方法,并通过图像分割的实际案例展示了其应用价值。AOA是种基于种群的元启发式算法,其核心思想来源于四则运算,利用乘除运算进行全局勘探,加减运算进行局部开发,通过数学优化器加速函数(MOA)和数学优化概率(MOP)动态控制搜索过程,在全局探索与局部开发之间实现平衡。文章详细解析了算法的初始化、勘探与开发阶段的更新策略,并提供了完整的Python代码实现,结合Rastrigin函数进行测试验证。进步地,以Flask框架搭建前后端分离系统,将AOA应用于图像分割任务,展示了其在实际工程中的可行性与高效性。最后,通过收敛速度、寻优精度等指标评估算法性能,并提出自适应参数调整、模型优化和并行计算等改进策略。; 适合人群:具备定Python编程基础和优化算法基础知识的高校学生、科研人员及工程技术人员,尤其适合从事人工智能、图像处理、智能优化等领域的从业者;; 使用场景及目标:①理解元启发式算法的设计思想与实现机制;②掌握AOA在函数优化、图像分割等实际问题中的建模与求解方法;③学习如何将优化算法集成到Web系统中实现工程化应用;④为算法性能评估与改进提供实践参考; 阅读建议:建议读者结合代码逐行调试,深入理解算法流程中MOA与MOP的作用机制,尝试在不同测试函数上运行算法以观察性能差异,并可进步扩展图像分割模块,引入更复杂的预处理或后处理技术以提升分割效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值