C语言第12轮:指针

【学习目标】

1.        指针

2.        指针与数组

A: 指针的概念

内存存储单元按字节排序。每一个字节编有序号。我们称之为地址。因为能够通过地址就能够找到所要的内存单元,所以我们把地址成为指针。指针是个特殊的变量,它里面存储的数值被解释为内存里的一个地址

作用:

(1)       指针能够有效地表示复杂数据结构,如队列、栈、链表等

(2)       指针能够像汇编一样处理内存地址,为动态内存分配提供支持

(3)       指针能够实现对数组和字符串的方便使用,提高程序的效率

B: 指针变量的定义

数据类型  * 指针变量;

如:

   int*p2;        /*p2是指向int型的指针变量*/
float*p3; /*p3是指向float型的指针变量*/
char*p4; /*p4是指向char型的指针变量*/

说明:数据类型并非指变量本身的类型,而是该变量所指向目标变量的类型。指针变量仅仅能指向同类型的变量。

//指针的定义
#include <stdio.h> int main( void )
{ //野指针:不是NULL指针,是向被释放的或者訪垃圾内存的指针
int *ptr1; //ptr1为int型指针,野指针,里面为垃圾地址
char *ptr2; //ptr2为char型指针,野指针,里面为垃圾地址
//在VC中编译,会提示ptr1和ptr2没有初始化 float*ptr3= NULL; //ptr3为float型指针,不是野指针,已经初始化为NULL //查看地址
printf("( ptr1 )= %p\n", ptr1 );
printf("( ptr2 )= %p\n", ptr2 );
printf("( ptr3 )= %p\n", ptr3 ); return 0;
}

C: 指针的赋值(注意:类型要匹配)

(a)使用地址运算符&:

如:

int a =133;
int * p1;
p1= & a; //使用地址运算符把a的值赋值给指针p1

(b)将一个已具有指向的指针变量赋值给还有一个指针变量

如(接上面的):

int*  p2;

p2=p1;      //p1和p2同一时候指向变量a

(c)  指针与数组的赋值

   int a[5],*pa;
pa=a; //(数组名表示数组的首地址,故可赋予指向数组的指针变量pa)
//也可写为:
pa=&a[0]; //数组第一个元素的地址也是整个数组的首地址,
//当然也可採取初始化赋值的方法:
int a[5];
int *pa=a;

(d) 字符串与指针的赋值。

比如:

    char *pc;
pc="C Language";
//或用初始化赋值:
char *pc="C Language";

PS: 不同意把一个数直接赋予指针变量。

如:

   int *p;
p=1000; //类型不匹配。提示错误
//改进方式
P= ( int * )100; //强制类型转换。

D:  & 和 * 的使用

(a) 合法的使用取地址符能够得到一个变量的地址

如:

  int a;
int score[5]= {80, 90, 97, 98, 63};
&a,&score[0]; //该操作合法
&(a+5); // 该操作非法,越界
&a=123; //该操作非法,须要的话必须的强制转换
&score; //该操作非法,score本身代表score的首地址

(b)使用* 运算符,间接存取指针所指向的目标标变量的值(类型要匹配)

itn  a = 234;
int * p1;
p1=& a; //p1指向数组a
printf(“%d\n”, *p ); //符号*是把地址中的内容取出。

E: 指针与整数相加减

意义:表示指针的移动

如: p+n   p-n  p++   p--  ++p  --p

PS:

(1)   当中的n为整数。地址的移动不能为小数。

(2)   加法表示指针p向地址增大的方向移动。

(3)   减法表示指针p向地址减小的方向移动

(4)   至于移动的长度,是由计算机决定。

如:设p是指向type(类型)类型的指针。n为整型表达式,则p+(或—)n为一个新的地址。其值为p+(或-)n*sizeof(type)。

F: 指针与数组

因为数组中的各元素的存储单元是连续分配的。因此能够用指针来訪问数组,数组名就是该数字的首个地址。

如: int a[]=“abcdefg”;

a 就是该数组的首地址。等价于&a[0]

PS: 通过收地址,能够非常快的、方便的訪问数组中的其它元素。方法例如以下:

首地址+ 偏移量

a[ i ]能够转化为:  *(a+i),  *(&a[0]+i)

指针与数组的比較

指针

数组

保存数据的地址,不论什么存入指针变量的数据都会被当做地址来处理。

保存数据。数组名为数组首元素的首地址。

间接訪问数据。通过获取指针变量中的内容(地址),然后从这个地址提取数据。

指针能够使用指针形式訪问数据,也能够使用下标形式訪问数据。

直接訪问数据。能够通过指针的形式訪问数据,也能够使用下标訪问数据。

通经常使用于动态数据结构

通经常使用于存储固定数目

使用malloc,calloc,recalloc和free函数分配内存

不能删除分配的内存,能够删除数据

【指尖的微笑】错误在所难免。希望得到大家的指正^-^

转载时保留原文的链接(http://it.bangedushuren.cn/)原创,转载请注明

版权声明:本文皆有[www.bangedushuren.cn]原版的,转载请注明http://dh.51zhui.cn/,谢谢

C语言第12轮:指针的更多相关文章

  1. 程序员之---C语言细节12(指针和数组细节,&quot;//&quot;的可移植性说明)

    主要内容:指针和数组细节,"//"的可移植性说明 #include <stdio.h> int main(int argc, char **argv) { int a[ ...

  2. C语言精要总结-指针系列(一)

    考虑到指针内容繁多,这里将指针作为一个系列,从简入繁,一点一点深挖并掌握这C语言的精华.初步计划如下 此文为指针系列第一篇: C语言精要总结-指针系列(一) 内存与地址 我们可以把内存看做一排连续的房 ...

  3. Go语言中时间轮的实现

    最近在工作中有一个需求,简单来说就是在短时间内会创建上百万个定时任务,创建的时候会将对应的金额相加,防止超售,需要过半个小时再去核对数据,如果数据对不上就需要将加上的金额再减回去. 这个需求如果用Go ...

  4. Atitit java方法引用(Method References) 与c#委托与脚本语言js的函数指针

    Atitit java方法引用(Method References) 与c#委托与脚本语言js的函数指针   1.1. java方法引用(Method References) 与c#委托与脚本语言js ...

  5. 【转载】C/C++语言void及void指针深层探索

    C/C++语言void及void指针深层探索 1.概述许多初学者对C/C++语言中的void及void指针类型不甚理解,因此在使用上出现了一些错误.本文将对void关键字的深刻含义进行解说,并详述vo ...

  6. 函数指针玩得不熟,就不要自称为C语言高手(函数指针是解耦对象关系的最佳利器,还有signal)

    记得刚开始工作时,一位高手告诉我说,longjmp和setjmp玩得不熟,就不要自称为C语言高手.当时我半信半疑,为了让自己向高手方向迈进,还是花了一点时间去学习longjmp和setjmp的用法.后 ...

  7. C语言中的函数指针

    C语言中的函数指针 函数指针的概念:   函数指针是一个指向位于代码段的函数代码的指针. 函数指针的使用: #include<stdio.h> typedef struct (*fun_t ...

  8. C语言精要总结-指针系列(二)

    此文为指针系列第二篇: C语言精要总结-指针系列(一) C语言精要总结-指针系列(二) 指针运算 前面提到过指针的解引用运算,除此之外,指针还能进行部分算数运算.关系运算 指针能进行的有意义的算术运算 ...

  9. C语言第八讲,指针*

    C语言第八讲,指针* 一丶简单理解指针 说到指针,很多人都说是C语言的重点. 也说是C语言的难点. 其实指针并不是难.而是很多人搞不清地址 和 值.以及指针类型. 为什么这样说. 假设有两个变量,如下 ...

随机推荐

  1. 基于HTML5气3D仿真培训系统

    根据最近的上线HTML5的燃气3D培训仿真系统.曾经的老系统是採用基于C++和OpenGL的OpenSceneGraph引擎设计的,OSG引擎性能和渲染效果各方面还是不错的,但由于这次新产品需求要求能 ...

  2. n每个计数的概率和发生骰子--动态规划

    称号:该n骰子在地板上.所有点骰子的向上一面和一个S.进入n,打印S所有可能的值的概率. 声明思想非原创!仅仅因动态规划思想的使用非常好,记下. 分析:动态规划就是分阶段考虑问题.给出变量.找出相邻阶 ...

  3. HDU 4896 Minimal Spanning Tree(矩阵高速功率)

    意甲冠军: 给你一幅这样子生成的图,求最小生成树的边权和. 思路:对于i >= 6的点连回去的5条边,打表知907^53 mod 2333333 = 1,所以x的循环节长度为54,所以9个点为一 ...

  4. POJ 3579- Median

     Description Given N numbers, X1, X2, ... , XN, let us calculate the difference of every pair of n ...

  5. C# 抽象类其中创建一个静态方法

    </pre><pre name="code" class="csharp"><span style="font-size ...

  6. fastboot完成自己主动命令

    于Ubuntu13.10后来Ubuntu 14.04上,由APT安装fastboot以及adb该工具后, 发现fastboot在主动补充一个问题,, fastboot flash 自己主动有问题完成后 ...

  7. 据序和中序序列或者也许为了一个二进制序列,恢复二进制和打印图像(c语言)

    首先要预购和序,以恢复它: 1.首先,我们使用的是递归的方式来完成 2.递归的最小单位:一个空的树和书的前言和第一序.该序列的第一个元素是树的第一序列根,调用这种方法 3.递归的终止条件是.当这棵树的 ...

  8. hdu 1159 Common Subsequence (dp乞讨LCS)

    Common Subsequence Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Other ...

  9. CloudFoundry.yml修订

    --- name: CFRELEASE02 director_uuid: fdd46e30-f2c5-41dc-9662-0976fdac5716 releases: - name: cf versi ...

  10. PC结束 Spark 二次开发 收到自己主动,并允许好友请求

    本次Spark二次开发是为了客服模块的开发, 能让用户一旦点击该客服则直接自己主动加入好友.而客服放则需自己主动加入好友,不同弹出对话框进行允许,这方便的广大客服. 如今废话不多说,直接上代码. pa ...