程序员考试笔记十:数组

企业动态
程序员考试笔记(连载中...)

        今天接着上天的二维数组,我们看看指向二维数组的指针是怎么的。在讲之前我想再重复一次,如果你自己理解好二维数组的就按你以往的去理解吧。不过多想想几种方法也是一件好事,那么下面就来讲讲了。

  现在来看看昨天的那个二维数组图,第九天图一。我们定义一个指向二维数数的指针 

         int a[3][4];
         int *p;
         p=a;

  其实这也指向一维数组的指针完全没有分别,二维数组因为是行优先的,一行下来就是列顺序了,我们可以这样来用指针指向列,如下: 

         p++;

  我们这里就是指向了第0行的第1列了,那么我们怎么可以到第下一行呢,其实定义数组时内存就给数组分配好一连串的连续空间,我们直接可以将指针继续往下移,当移到了0行***一列时,加移的话就到了第1行了。其实C语言里还有一种更方面的指向方法,看如下:

        int (*p)[4] /*这里是定义一个数指针,而这个指针是指向有数组四个元素的指针*/

我们看看这种定义的方式,*p为什么一定要括号括住呢,因为[]这个运算符比*优先,如果不加括号的话就变成了定义另一个指针最,至于是什么指针在最面就会讲到了,现在先来看看这种指针。 

         p=a;
         p++;

这样会得到什么的结果呢?就是直接往下移一行了,这也是和前天说过的那个道理一样,是按照定义的类型结合来到运算的。我们知道了如何可以移行,那么该怎么移列呢?这个问题又更复杂一点了,试着把指针移到第1行第2列看看。我们先来看看这个表达式代表什么吧,a+1 这就是***行的首地址吧,同理p+1也是指向***行的首地址。至于列呢?先想想一维数组是怎么移到列的,就是首地址加上列序吧!那么我们就可以先表达出一维数组的首地址先,*(p+1)+2,看,这样是不是指向了***行第二列了呢。我们不可以简单的理解(p+1)为行,从另一种意义上可以看成是列的首地址了(这里实在太难理解了,明还是有一点明,不过我还想用回自己一直对指针的理解好了,千万不要综合起来理解喔,这样就太错特错了)。 

       好了说回了二维数组成的现在来看看还有其它的什么指针,字符指针是比较简单的,不过也有它的一些特别之处。我们来看看以下的一些程序:
        char *p;
        p="ABC"; /*这里说说,既然是字符串就是一定有结束符的,这是和字符数组不同的*/
这样的赋值是可以的,这里是将字符串ABC的首地址赋给指针p,下现再看看另一个程序:
        char a[4];
        a="ABC";
  这里有错吗?对于C语言来说是错了的了,因为字符数组a是一个常量,不能给赋值。其它的高级语言就可以直接赋值给它就回事了,那么我们想把ABC赋给字符数组该怎么呢,这里有几种方法,一种就是一个一个字符赋值,一种就是利用指针,不过这里还是用回C语言函数库里的复制字符串函数完成strcpy();大家应该都对这个函数不默生吧,那好,现在就给五分钟做做练习,编制一个类于strcpy()的函数。…………时间真的过得快,我把我做的写出来吧。 

        mycpy(char *s1,char *s2)
          { for(;*s1++=*s2++; }
好了,就这么短短二行就完成了复制功能,这只有C语言才能做到的。
现在再来看看以下两个程序吧 。

         char *p,*q; char *p,*q,*r;
         p="ABC"; r="ABC";
         q="ABC"; p=r;
         *q='D'; q=r;
         printf("%s",%s",p,q); *q='D';
         printf("%s,%s",p,q);

这里的答案是什么呢?自己先想想吧。

  好了,应该都想完了吧,现在就给出正确的答案,***条程序是输出ABC,DBC,而第二条程序就是输出DBC,DBC。这里为什么呢?其实是因为***个程序都是指向了同一个地址,那当然就是值一样啦。

现在就剩下函数指针了,其实我们平常也不怎么多人,但是老师还是给我们讲了一下,也提出了一个特别的地方,是今天我们才发现的,程序如下:

         int b=0;
         int a[2]={10,20};
         int *ab(int *p)
           {
               p++;
               return (p);
           }
         main()
           { 

               b=*ab(a); /*这里我们试着将调用的函数返回的地址再加*号,看看可不可以指到那个值,至于结果怎么样,我们也没有试过,我在写这篇日记时也没有上过机试,大家有兴趣也试试吧,这个问题我们是怎么引出来的呢,其实我们一开始定义了一个指向函数的指针,就比如(*cd)()吧,我们提出了如果没有了括号会怎么样,因为本来(*cd)()就是指向一个返回指针值的函数,那么我们为了试验所以另编一个返回地址的函数来试试*/
               printf("%d",b);
            }

  好了,今天就将指针讲完了,不过指针的运用就还有很多在后面呢,就我知道的就有结构体和共用体还可以用到指针,跟着就是其它的一个综合运用链表、堆栈、队列等等的。我想我就是这方面还一点经验都没有吧,之前看了一下数据结构也没有太大的兴趣看下去了,因为我看到一大堆的指针都已经头晕了。不过近几天拿回来看看又好像明了些什么似的,反正就觉得不太头晕了吧。

【相关文章】

  1. 程序员考试笔记九:C语言指针
  2. 程序员考试笔记八:诺汉塔的原理
责任编辑:丁小雨 来源: 51CTO
相关推荐

2009-01-07 21:03:53

程序员循环语句

2009-01-19 19:18:44

程序员考试笔记

2009-01-07 21:00:05

2009-01-08 21:25:51

程序员笔记

2009-01-08 21:21:45

程序员笔记

2009-01-10 23:38:16

程序员考试笔记

2009-01-05 15:56:00

软考程序员

2012-09-28 10:09:35

程序员码农谎言

2014-09-19 09:27:46

程序员

2011-04-15 10:51:47

程序员

2010-05-31 09:18:42

程序员文档注释

2013-05-30 09:55:51

程序员分歧程序员失业的程序员

2019-05-16 08:36:53

Eureka缓存网关

2012-03-06 09:22:46

程序员

2013-08-20 09:33:59

程序员

2015-05-25 11:16:23

2009-05-21 15:58:12

程序员工作经验职场

2011-05-13 14:34:02

程序员

2019-08-19 08:42:44

程序员技能开发者

2015-04-10 19:37:34

程序员
点赞
收藏

51CTO技术栈公众号