第一次写,整理一下如何运用指针在不用加号的情况进行加法运算

本文介绍了如何在不使用加号的情况下实现加法运算。通过指针和数组的知识,利用地址偏移的方法来达到加法的效果,并展示了如何通过指针判断编译器位数。

这是一个学长义务给我们大一的学生讲的第一节课,在此进行一下整理:

平常我们进行加法运算都是用类似以下的代码进行运算

#include<stdio.h>
int main()
{
	int a=2,b=3;
	printf("%d\n",a+b);
	return 0;
}

其结果为 5,对a和b进行了加法运算

但我们如何不用加号进行加法运算呢?先看一段数组运算

#include<stdio.h>
int main()
{
	int a[]={1,2};
	printf("%d\n",a[0]+a[1]);
	return 0;
}
运行结果是 3 ,它和以下这段代码是相同的

#include<stdio.h>
int main()
{
	int a[]={1,2};
	printf("%d\n",*(a+0)+*(a+1));
	return 0;
}
因为 a[i]=*(a+i) 

接下来我们简单运用一下指针

#include<stdio.h>
int main()
{
	int a=2,b=3;
	int *p=a,*q=b;
	printf("%d\n",*p+*q);
	return 0;
}
p和q分别指向了a和b的地址,将a和b的和计算,结果是 5

现在运用指针和刚才说的a[i]=*(a+i)和变量存放地址进行一下结合

#include<stdio.h>
int main()
{
	int a=2,b=3;
	int *p;
	printf("%d\t%d\n",&a,&b);
	p=&a;
	printf("%d\n",(int)&((char *)a)[b]);
	return 0;
}
输出结果是

1638212        1638208

5

前面两个值分别是a和b的地址,因为是int类型且在我用的32位编译器中是按四字节存储的,然而char类型是按照一个字节一个字节存储的,用指针p指向变量a,先看(char*)a,它是一个强制类型转换,将a这个变量强制转换成char*类型的地址,((char*)a)[b]则是将地址向后移b个字节,但此时的((char*)a)[b]等于*(a+b),我们知道&和*的作用相互抵消的,所以有了&((char*)a)[b],但此时它的类型仍为char*,前面的(int)则是将其强制转换位int进行输出。

当时那个学长讲的时候用的long定义的a和b,如果强制类型转换为int,long是八字节,而int是四字节,那么就会造成数据丢失。


最后说一下刚得知的,可以用指针测试编译器到底是64位还是32位,64位的编译器指针变量是8字节,32位的则是4字节。


第一次尝试写博客,写的不好或有不足甚至有错误希望指出,我会慢慢改进的,最后感谢为我们讲课的学长。

【电力系统】单机无穷大电力系统短路故障暂态稳定Simulink仿真(带说明文档)内容概要:本文档围绕“单机无穷大电力系统短路故障暂态稳定Simulink仿真”展开,提供了完整的仿真模型与说明文档,重点研究电力系统在发生短路故障后的暂态稳定性问题。通过Simulink搭建单机无穷大系统模型,模拟不同类型的短路故障(如三相短路),分析系统在故障期间及切除后的动态响应,包括发电机转子角度、转速、电压和功率等关键参数的变化,进而评估系统的暂态稳定能力。该仿真有助于理解电力系统稳定性机理,掌握暂态过程分析方法。; 适合人群:电气工程及相关专业的本科生、研究生,以及从事电力系统分析、运行与控制工作的科研人员和工程师。; 使用场景及目标:①学习电力系统暂态稳定的基本概念与分析方法;②掌握利用Simulink进行电力系统建模与仿真的技能;③研究短路故障对系统稳定性的影响及提高稳定性的措施(如故障清除时间优化);④辅助课程设计、毕业设计或科研项目中的系统仿真验证。; 阅读建议:建议结合电力系统稳定性理论知识进行学习,先理解仿真模型各模块的功能与参数设置,再运行仿真并仔细分析输出结果,尝试改变故障类型或系统参数以观察其对稳定性的影响,从而深化对暂态稳定问题的理解。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值