一点点指针的理解

原创 2016年08月30日 20:10:29
int *a, b, c;//看起来像是声明了三个指针,实际上只有a被声明为int *

int *a, *b, *c;//才是正确的声明三个指针的方式,因此让*跟在变量后面看起来会更合理。

Q : 这里会问,int本身是值类型,用int就可以表示一个整数,那么int *a这种仅仅是把一个单整数放在堆空间罢了?
A :不是的。看完下面这个例子,再一起总结。

    char *message = "Hello world!";

这条语句把message声明为一个指向字符的指针,并用常量中第一个字符的地址对该指针进行初始化。

也就是说,这个message可以当作数组来用啊。

所以声明 int *a; 这里a可以当作数组来用的!
因为堆是连续的!

但是这里的message声明,很容易让人产生误解:是把“Hello World”赋给 *message的,但是你想,message只是一个字符的指针,装不下这么大的!

这个声明其实等同于:

char *message;
message = “Hello World!”; //“Hello World!”过来是把自己的anchor:第一个字符的地址给message

Q : 以下代码会报错,segment fault: 11 , why?

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

但是,int array[] 与int *a单独使用都不出错,也就是int *a可以当作数组使用!

#include<stdio.h>
int main(void)
{
    int array[4] = {1,2,3,4};
    int *a = array;

    for(int i = 0; i < 4; i++)
    {
        printf("%d\n",a[i]);
    }
    return 0;
}

这样写也没任何问题,将数组array的首地址赋予了a,可以的。
这也解释了为什么在函数传参中,使用指针去接数组,当然用数组的形参去接数组,在征服C指针那本书中谈到了,是不存在,但是可以用的。

如下:

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

使用的是int array[ ]接收数组型的参数。

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

使用指针 int *a去接数组型的参数。

所以,只有在形参中,这二者才是等同的,事实上,都是翻译成指针的。

附录
typedef总结
typedef char *ptr_to_char;
ptr_to_char a; //这个时候a就是一个指向字符的指针了!
常量:
int const *pci; //可以修改指针的值,但是不可以修改*pci的值
int * const cpi; // 可以修改*cpi的值,但是不可以修改指针的值

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

C/C++函数返回数组指针的一点点小姿势

数组指针问题一直是C/C++语言初学者的头疼问题,这里图图和大家分享一下函数返回数组的问题。如果在函数里定义静态数组,那么函数结束时数组内存空间也就会被释放,这时候如果返回数组首地址的话,那么获得的指...

每天进步一点点——五分钟理解一致性哈希算法(consistent hashing)

本文转自:http://blog.csdn.net/cywosp/article/details/23397179/         一致性哈希算法在1997年由麻省理工学院提出的一种分布式...

每天进步一点点——swift对象副本修复之简单理解

一直以来都在使用openstack的swift来做分布式存储,至于为什么使用其来做存储在这里就不说明(网上搜搜其的优点就知道了), 随着项目的步步深入,越来越多的问题也随之而来。在项目进行的过程中对s...
  • cywosp
  • cywosp
  • 2013年10月18日 11:26
  • 11147

对Java中String类的一点点理解

最近在复习Java的时候遇到关于String类型的一些疑惑,查阅了一些资料后算是有一点点心得,记于此。 一、看如下代码: String a = "programming"; Strin...

每天进步一点点——五分钟理解一致性哈希算法(consistent hashing)

转载自:http://blog.csdn.net/cywosp/article/details/23397179 一致性哈希算法在1997年由麻省理工学院提出的一种分布式哈希(DHT)实现算法,...

我对搜索算法的一点点理解

大家在学习算法参加信息学竞赛的过程中会遇到一种很暴力的“搜索·”算法,说他很暴力是因为他真的很暴力(哈哈,开个玩笑),搜索在最坏情况下的时间复杂度相当于暴力。与此同时,搜索有时能够解决所有问题的一种方...

对Dijkstra的一点点理解。

Dijkstra算法是图论中求单源最短路的一种算法,基本思想可以看啊哈算法,里面讲的比较详细。这里主要说一下我的一点心得,Dijkstra算法的实现由距离数组dis[len],标记数组book[len...

每天进步一点点——五分钟理解一致性哈希算法(consistent hashing)

五分钟让你深入了解分布式系统中常用的一致性哈希算法
  • cywosp
  • cywosp
  • 2014年04月11日 00:21
  • 321243

每天进步一点点——五分钟理解一致性哈希算法(consistent hashing)

转载请说明出处:http://blog.csdn.net/cywosp/article/details/23397179     一致性哈希算法在1997年由麻省理工学院提出的一种分布式哈希(DHT...
  • awhip9
  • awhip9
  • 2017年07月27日 18:51
  • 80

每天进步一点点——五分钟理解一致性哈希算法(consistent hashing)

一致性哈希算法在1997年由麻省理工学院提出的一种分布式哈希(DHT)实现算法,设计目标是为了解决因特网中的热点(Hot spot)问题,初衷和CARP十分类似。一致性哈希修正了CARP使用的简 单哈...
  • JIESA
  • JIESA
  • 2017年01月22日 14:36
  • 151
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:一点点指针的理解
举报原因:
原因补充:

(最多只允许输入30个字)