码迷,mamicode.com
首页 > 移动开发 > 详细

IOS 阶段学习第八天笔记(指针)

时间:2015-06-27 23:58:52      阅读:337      评论:0      收藏:0      [点我收藏+]

标签:

                                                        IOS学习(C语言)知识点整理

一、指针

1)概念:存储变量的地址的一个变量。

2) 数据存储类型分析

   1、text (代码段) :存储二进制的可执行代码

   2、data(初始化的数据段) 存储初始化的全局变量以及初始化的static修饰的变量,分为只读数据段

     (如:字符串常量,整型常量)及可读可写数据段,静态存储。

   3、data(未初始化的数据段)存储未初始化的全局变量及未初始化的static修饰的变量,静态存储。

   4、heap(堆区) 内存使用需要手动申请,手动释放,空间非常大,通常存储大容量的数据,执行效率比较低

       使用比较麻烦,动态存储。

 5、stack(栈区)内存空间比较小,函数调用局部变量开辟都是栈上,使用效率非常高。

3)取地址符 “&”,间接寻址符 “ * ”,“%p” 打印地址的格式字符

4)指针标示符:* 例如: int *p   表示定义了一个指针p,*是指针标示,int表示p指向的类型(里面存储的是int型变量的地址)

5)各种类型的指针,在内存中拥有的空间都是一样的,64位系统下面都是8个字节(32位是4个字节)。 

6)指针运算 指针对象 ++,表示指向地址向后偏移,偏移量为sizeof(指向的类型);- -则表示向前偏移。

7)野指针:未初始化值的指针,里面是个随机地址,去操作可以修改该地址的变量的值,会给系统造成不可控制的影响。

8)空指针 p=NULL=0; 0是非法地址,0地址不可赋值,不可读写。

9)指针的优点

   1、为函数提供修改调用变量的灵活手段

   2、可以使函数有多个返回值

   3、可以改善某些子程序的效率 ,在传递数据时,如果数据块较大(比如数据缓冲区域或比较大的结构),这时   就可使用指针传递地址而不是实际数据,

   即可提 高传输速度,又节省大量内存。

   4、为动态数据结构(如 二叉树、链表)提供支持。

10)void* 指针,通配指针,可是指向任意类型。

11)指针的应用,函数中指针作为函数的入参。

12)int *a;  指针变量,指向int型数据。

13)指针数组  即指向一个数组类型的指针   

     例如: int *p[4] : 表示4个指向int的指针.每个指针都是独立的,没有关系; p[i] 是一个 int 型指针

          p[i]=*(p+i)

 实例代码:

 1 int add(int *a[],int len1,int len2)
 2 {
 3     int sum = 0;
 4     for(int i=0;i<len1;i++){
 5         //a[i]第i个指针=第i个一维数组
 6         for(int j=0;j<len2;j++){
 7             sum = sum + *(a[i]+j);
 8         }
 9     }
10     return sum;
11 }
12 
13 int main()
14 {
15 
16     int a[4][3]={{1,2,3},{4,5,6}, {7,8,9},{10,11,12}};
17     int *p[4];//指针数组,没初始化不能用,野指针组
18     for(int i=0;i<4;i++){
19         p[i]=a[i];//a[i]表示第i行的一个数组
20     }
21 
22    int sum = add(p,4,3);
23    printf("sum = %d\n",sum);
24    return 0;
25 }

14)数组指针 

实例代码:

 1 int add(int(*p)[3],int len)
 2 {
 3     int sum = 0;
 4     for(int i=0;i<len;i++){
 5         //p+i 表示指向第i个数组 *(p+i)=a[i]
 6         for(int j=0;j<3;j++){
 7         //a[i][j] = *(a[i]+j) = *(*(p+i)+j)
 8             sum = sum + *(*(p+i)+j);
 9         }
10     }
11 
12     return sum;
13 }
14 
15 int main()
16 {
17     int a[4][3]={{1,2,3},{4,5,6}, {7,8,9},{10,11,12}};
18 
19     //a[0],a[1],a[2],a[3]:4个数组都有3个元素
20 
21     int(*p)[3];//可以指向一个有3个元素的数组
22 
23     //p = &(a[0]);//&a[0] = &(*(a+0))
24 
25     p = a;//由上面的那个式子化简
26 
27     int sum =add(a, 4);//既然p=a,就可以这么写
28 
29     printf("sum %d \n",sum);
30 
31  }

15)函数指针  int (*pfunc)(int,int); 定义了一个函数指针,必须要指向 int XXX(int a,int b) 这种样式的函数

 实例代码:

 1 int add(int a,int b)
 2 {
 3       return a+b;
 4 }
 5 
 6 int main(){
 7     int a = 10;
 8     int b = 20;
 9     int sum;
10     int (*pfunc)(int,int);
11 
12     pfunc = add;//函数名相当于一个指向其函数入口指针常量
13 
14     sum = pfunc(a,b);
15 
16     printf("sum = %d\n",sum);
17 
18     return 0;
19 
20   }

16) 使用指针 实现函数回调

 实现代码:

 1  void print_hello()
 2 {
 3     printf("hello world\n");
 4 }
 5 
 6  void print_date()
 7 {
 8     time_t rawtime;
 9 
10     struct tm * timeinfo;
11 
12     time ( &rawtime );
13 
14     //获取系统本地时间 需要引用 time包 ,#include <time.h>
15 
16     timeinfo = localtime ( &rawtime );
17 
18      printf ( "%4d-%02d-%02d %02d:%02d:%02d\n",1900+(*timeinfo).tm_year, 1+(*timeinfo).tm_mon,
19 
20             (*timeinfo).tm_mday,(*timeinfo).tm_hour,(*timeinfo).tm_min,(*timeinfo).tm_sec);
21 
22 }
23 
24 // void(*pfunc)()
25 void print_all(void(*pfunc)(),int count)
26 {
27     for(int i=0;i<count;i++){
28         pfunc();
29     }
30 
31 }
32 
33  
34 int main()
35 {
36 
37     print_all(print_date,4);//循环输出4次
38 
39     print_all(print_hello,1);
40 
41     return 0;
42 }

17)使用指针实现递归算法

 实现代码:

 1 void sort_array(int *a,int len){
 2 
 3     //冒泡排序
 4 
 5     int temp;
 6 
 7     for(int i=0;i<len-1;i++){
 8 
 9         for(int j=0;j<len-1-i;j++){
10 
11         if(*(a+j)>*(a+j+1))
12 
13             {
14 
15                 temp = *(a+j);
16 
17                 *(a+j) = *(a+j+1);
18 
19                 *(a+j+1) = temp;
20 
21             }
22 
23         }
24 
25     }
26 
27 }
28 
29  
30 int main(){
31 
32  int a[5]={1,20,30,4,5};
33 
34   int *p;
35 
36   p = a;
37 
38   //传递数组:2种形式 数组或者指针
39 
40   print_array(a, 5); 
41 
42   return 0;
43 
44 }

18)二级指针 指向指针的指针。

 实例代码:

 1 void swap(int **p,int **q)
 2 {
 3 
 4     int temp;
 5 
 6     temp = **p;
 7 
 8     **p = **q;
 9 
10     **q = temp;
11 
12 }
13  
14 
15 int main()
16 {
17 
18     int a = 10;
19 
20     int b = 20;
21 
22     int *p = &a;//p是一个指针,指向int型
23 
24     int **q;//q是一个指针,指向 int *型,int* 型就是指向int的指针类型,p就是这样一个类型
25 
26     q = &p;//*q=*(&p)=p
27 
28     printf("%d\n",**q);//*q=p,**q=*p=a
29 
30     int *p_b = &b;
31 
32     int **pp_b = &p_b;
33 
34     swap(q,pp_b);
35 
36     printf("a=%d,b=%d\n",a,b);
37 
38     return 0;
39 }

19)const 修饰符,只读  表现形式: const 数据类型 变量名 ,const 直接修饰的变量不可以改变,但加了*的变量可修改。

 实例代码:

 1 int main()
 2 {
 3 
 4     int value1 = 10;
 5 
 6     int value2 = 20;
 7 
 8     const int a = 100;
 9 
10     printf("a=%d\n",a);
11 
12     a = 20;//const修饰的变量不能修改
13 
14     const int *p = &value1;
15 
16     p = &value2;
17 
18     //*p = 100;//*p不可以修改,p可以改
19 
20     int const *m = &value1;
21 
22     m = &value2;
23 
24     //*m = 10;//*m不可以修改,m可以改
25 
26     int *const n;//n不可以改,*n可以改
27 
28     const int *const q//q不可以改,*q不可以改
29 
30     const int *const m,*n;//m,*m不可以改,n可以改
31 
32     *n =100;//*n也不可以改
33 
34     const int *const m, *const n;//m,*m,n不可以改
35 
36     *n = 100;//*n也不可以改
37 
38    int *const m, *const n;//m,n不可以改,*m,*n可以改,
39 
40     *n = 100;
41 }

 

IOS 阶段学习第八天笔记(指针)

标签:

原文地址:http://www.cnblogs.com/ChinaKingKong/p/4604934.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!