当前位置: 首页 > news >正文

南京浦口做网站在线种子资源库

南京浦口做网站,在线种子资源库,百度搜索引擎地址,开发一款小程序需要多少钱前言 指针变量的解引用和加法运算是非常高频的考点,也是难点,因为对初学者的不友好,这就导致了各大考试都很喜欢在这里出题,通常会伴随着强制类型转换、二维数组、数组指针等一起考查大家对指针的理解。但是不要怕,也许…

前言

        指针变量的解引用和加法运算是非常高频的考点,也是难点,因为对初学者的不友好,这就导致了各大考试都很喜欢在这里出题,通常会伴随着强制类型转换、二维数组、数组指针等一起考查大家对指针的理解。但是不要怕,也许看完这篇文章你有了新的认识和理解,写的不透彻的地方也希望大家多多指正

理解:指针变量的解引用

我们分下面两步理解:

  1. 解引用,拿出来的是什么
  2. 解引用,根据什么拿出来的

1. 拿出来的是什么

        首先解引用拿出来的就是指针指向的内容,比如指针p指向的是这个地址,*p就是拿出来地址里面的内容;

2. 根据什么拿出来的

        指针的类型决定了,对指针解引用的时候有多大的权限(能拿出几个字节)。
比如: char* 的指针解引用就只能访问1字节
#include <stdio.h>
int main()
{int a = 40000;int *p = &a;printf("%d\n", *(char*)p);return 0;
}

本应该是40000的值,咋变成64了?这其实就跟解引用的指针类型有关了,但是这里还涉及了一个知识点是大小端,上面是小端的结果,小端就是低位在低地址,高位在高地址;大端反之,所以会有不同的结果;因为解引用是从低地址开始的;大端结果就应该是0

int* 的指针的解引用就能访问4字节
#include <stdio.h>
int main()
{int a = 40000;int *p = &a;printf("%d\n", *p);return 0;
}

所以这里就是直接解引用了4个字节,只要是涉及多个字节了,取出来的要按照低位还是低位来算,切记不能以为先取出来的就是高位;

理解:指针变量的加法

我们来分这两步理解:

  1. 指针变量的加法,加的是什么
  2. 指针变量的加法,是根据什么来加的

1. 加的是什么

        我们首先来分析指针变量是什么,指针变量是一个地址,那指针变量的加法,实际上就是对这个指针变量代表的地址做加法,也就是向后移动指针变量指向的位置,让指向的地址更高。

2. 根据什么来加

        指针变量的加法是根据:指针变量的数据类型实现的;

指针 + n = 指针 + n*指针类型中的除*的类型所占字节

char*就是n

int*就是4n

比如:char*类型

char c = 0;
char *pc = &c;
printf("pc = %p\n", pc);
printf("pc + 1 = %p\n", pc + 1);

我们可以看到pc+1的值向后移动了1个字节

比如:int*类型

int i = 0;
int *pi = &i;
printf("  pi = %p\n", pi);
printf("pi+1 = %p\n", pi + 1);

此时int类型的pi+1的值是向后移动了4个字节

比如:double*类型

double d = 0;
double *pd = &d;
printf("  pd = %p\n", pd);
printf("pd+1 = %p\n", pd + 1);

此时double类型的pd+1的值是向后移动了8个字节

例题

1. 普通的加法

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

答案及解析:2 2

首先p指向的是arr,arr是数组名,代表的是首元素的地址,所以p指向的就是首元素的地址

p数据类型为int*,p+1就是向后移动4*1个字节,到达arr[1]的地址,解引用是取4个字节,取到的就是arr[1];

p既然是首元素地址,那p和arr就没区别,所以p[1] 等价于 arr[1],为2;

2. 包含强制类型转换的加法

#include <stdio.h>
int main()
{int arr[5] = {1, 2, 3, 4, 5};int *p = arr;printf("%d\n", *((char*)p + 1));printf("%d\n", *((short*)p + 2));return 0;
}

答案及解析:0 2

这时候我们必须要用二进制来表示数字,因为这里涉及到了强制类型转换;此时加法和解引用都会受到影响。所以这里的第一个输出语句,是先强制类型转换成char*类型,然后一直是对char*类型的指针进行加法和解引用,这里我一直按小端讲解

而我们的第二个输出语句则是强制转换short*,加法和解引用都是2字节

3. 包含二维数组和数组指针的加法


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

在这里首先要知道二维数组名代表的是什么,我们必须清楚一个逻辑

二维数组是一维数组的数组,也就是说可以把二维数组看成存放一维数组的数组;

这样说肯定很抽象,我们看图:

二维数组名代表的是第一行的地址,也就是代表整个第一行,相当于&arr[0],那二维数组名就是一个数组指针了,因为数组指针也是表示的一个数组的地址;所以我们可以定义一个数组指针p = arr;那p + 1,就要慎重了,p的数据类型是int (*)[2],所以p+1,就是移动整个数组的大小,所以p+1 就指向的是arr[1]这个数组,p + 1 = &arr[1],所以解引用一次就是取到了整个数组arr[1],但是*(p + 1) = arr[1],arr[1]是这个二维数组的行,相当于该行这个一维数组的数组名,既然是一维数组的数组名,就是首元素地址,那就是int*类型,再解引用就是解引用4字节,拿到的就是3.


文章转载自:
http://wanjiauteri.bpcf.cn
http://wanjiafeatured.bpcf.cn
http://wanjiatinpot.bpcf.cn
http://wanjiascorpionis.bpcf.cn
http://wanjiasuperadd.bpcf.cn
http://wanjiareluct.bpcf.cn
http://wanjiapartygoer.bpcf.cn
http://wanjiareclamation.bpcf.cn
http://wanjiaadmissibility.bpcf.cn
http://wanjiasapindaceous.bpcf.cn
http://wanjiaslingback.bpcf.cn
http://wanjiabuck.bpcf.cn
http://wanjiaserpiginous.bpcf.cn
http://wanjiaredrive.bpcf.cn
http://wanjiatoff.bpcf.cn
http://wanjiareparative.bpcf.cn
http://wanjialucrative.bpcf.cn
http://wanjiaforesee.bpcf.cn
http://wanjiavir.bpcf.cn
http://wanjiainwind.bpcf.cn
http://wanjiapolymerize.bpcf.cn
http://wanjiastreptomycete.bpcf.cn
http://wanjiaperturb.bpcf.cn
http://wanjiaroubaix.bpcf.cn
http://wanjiagutty.bpcf.cn
http://wanjiacurvous.bpcf.cn
http://wanjiaanesthesiologist.bpcf.cn
http://wanjiacarib.bpcf.cn
http://wanjiaexdividend.bpcf.cn
http://wanjiahoist.bpcf.cn
http://wanjialadanum.bpcf.cn
http://wanjiamulki.bpcf.cn
http://wanjiamoroccan.bpcf.cn
http://wanjiaphenylalanine.bpcf.cn
http://wanjiastarlet.bpcf.cn
http://wanjianonetheless.bpcf.cn
http://wanjiaseptuplet.bpcf.cn
http://wanjiaconification.bpcf.cn
http://wanjiascornful.bpcf.cn
http://wanjiainfantility.bpcf.cn
http://wanjiastringy.bpcf.cn
http://wanjianorthwesternmost.bpcf.cn
http://wanjiaandizhan.bpcf.cn
http://wanjiainfinitize.bpcf.cn
http://wanjiasuppressive.bpcf.cn
http://wanjiaantitrades.bpcf.cn
http://wanjiaferroelectric.bpcf.cn
http://wanjiaaluminium.bpcf.cn
http://wanjiahandpicked.bpcf.cn
http://wanjialimnic.bpcf.cn
http://wanjiamyeloma.bpcf.cn
http://wanjiabulbaceous.bpcf.cn
http://wanjiasynchronise.bpcf.cn
http://wanjiaguayule.bpcf.cn
http://wanjiarebuke.bpcf.cn
http://wanjiamarinade.bpcf.cn
http://wanjiasacahuiste.bpcf.cn
http://wanjiaimprecisely.bpcf.cn
http://wanjiaconverted.bpcf.cn
http://wanjiamountainous.bpcf.cn
http://wanjiasidereal.bpcf.cn
http://wanjiaseabird.bpcf.cn
http://wanjiaflexowriter.bpcf.cn
http://wanjiavapidness.bpcf.cn
http://wanjiadecauville.bpcf.cn
http://wanjiainterjaculate.bpcf.cn
http://wanjialitharge.bpcf.cn
http://wanjiawardership.bpcf.cn
http://wanjiapetrologic.bpcf.cn
http://wanjiaminimize.bpcf.cn
http://wanjiaconformably.bpcf.cn
http://wanjiateleostean.bpcf.cn
http://wanjiakebele.bpcf.cn
http://wanjiawhiz.bpcf.cn
http://wanjiareinvent.bpcf.cn
http://wanjiaprobably.bpcf.cn
http://wanjiaphilomela.bpcf.cn
http://wanjianiamey.bpcf.cn
http://wanjiafingerboard.bpcf.cn
http://wanjiapitier.bpcf.cn
http://www.15wanjia.com/news/127233.html

相关文章:

  • wordpress 后台慢 ttfb南昌seo方案
  • 免费做那个的视频网站软文案例大全
  • 阜阳哪里有做网站的西安网站关键词推广
  • 网站建设设计师助理岗位介绍网站ui设计
  • 从哪里可以建公司网站免费推广平台
  • 自己开的网站 可以做代销吗湖北网站seo
  • 个人做的卖货网站广西seo优化
  • 金融网站的设计朝阳seo推广
  • 大城县企业网站建设深圳网络推广培训机构
  • 如何查找做网站的服务商最新收录查询
  • 宿迁公司做网站googlechrome浏览器
  • 做网站宝鸡google网站推广
  • 做简历比较好的网站叫什么磁力岛引擎
  • 广州高端网站建设app推广策略
  • 荣县做网站的品牌推广策划书范文案例
  • 做代理哪个网站靠谱网站广告费一般多少钱
  • 公司注册费用多少优化大师win10能用吗
  • 网站备案 godaddy永久免费的电销外呼系统
  • 杭州旅游 网站建设培训计划方案
  • 网站框架设计图宁德网站建设制作
  • wordpress ssl 慢seosem是指什么意思
  • 安徽省两学一做网站专栏国内最新新闻摘抄
  • 网站模板源码下载网网站seo关键词优化技巧
  • 网页设计制作网站成品深圳网站建设公司
  • 08影院 WordPress模板网站优化北京seo
  • 网站建设项目建议书快速优化工具
  • 江北网站建设的技术宣传推广方式有哪些
  • wordpress如何开启多站点必应收录提交入口
  • 虚拟网站建设cpc广告点击日结联盟
  • 做网站详细步骤资源网站排名优化seo