指针(二)

来源:互联网 发布:护眼仪哪个牌子好 知乎 编辑:程序博客网 时间:2024/05/18 02:02

1、指向数组的指针

例子:

int a[]={'a','b','c'};

int *p=a;

则*(p+i) 等价于a[i]

亲,注意不要越界噢,尤其是处理字符窜的时候,注意\0!!

2、指针数组

还是一个数组,只不过数组元素是指针了

例子:

char *argv[]就非常典型

3、指针与字符窜

处理字符窜的时候要主意\0这个小子

例子:

 /*                                                                                                             2  *功能:自己实现strcmp函数  3  *心得:记住要入口检测;另外要注意程序的版式,即代码风格  4  * */  5 #include <stdio.h>  6 #include <stdlib.h>  7 /*strcmp:  8  * if s<t return<0  9  * if s==t return=0 10  * if s>t return>0*/ 11 /*int strcmp(char *s,char *t) 12 { 13     int i; 14     for (i = 0; s[i] == t[i]; i++) 15         if (s[i] == '\0') 16             return 0; 17     return s[i] - t[i]; 18 }*/ 19 /*strcmp:指针实现*/ 20 int my_strcmp(char *s,char *t) 21 { 22     for ( ; *s == *t;s++,t++) 23         if (*s == '\0') 24             return 0; 25     return *s - *t; 26 }27 int main() 28 { 29     char *s = "abcd"; 30     char *t = "abedc"; 31     printf("%d\n",my_strcmp(s,t));//返回-2 32     return 0; 33 }

4、指针与函数

在我看来,只有中国人需要搞清楚这两哥们的区别,语言问题,呵呵。

1、指针函数:注意哦,本质上是函数,只不过它的返回值类型是一个指针

例子:今天翻看自己原来写的数据结构程序,碰见了,就补充到这里

typedef int ELEM;struct ListNode{ELEM data;ListNode* link;};typedef ListNode* ListPtr;//生成一个含有n个节点的链表,头节点不存放数据ListPtrCreateList(void){int i,n=0;ListPtr head,last;ListPtr p1,p2;printf("请输入您要创建的链表的数目:\n");scanf("%d",&n);head=p1=p2 = (ListPtr)malloc(sizeof(struct ListNode));for(i=1;i<=n;i++){p2 = (ListPtr)malloc(sizeof(struct ListNode));p1->link = p2;printf("请输入第%d个节点的数据:\n",i);scanf("%d",&(p2->data));p1 = p2;}last = p1;last->link  =NULL;return head;}


2、函数指针:注意哦,本质上是指针,只不过它指向了一个函数的首地址,即该指针的值是一个函数的入口地址

例子:昨天写得太着急,没有认真举例子,今天反省一番,决定努力一把,争取以后每个知识点都附上一个可以运行的例子,才能做到栩栩如生,哈哈

#include <stdio.h>#include <STDLIB.H>/*完成两数相加,并返回*/int fun(int a,int b){return a+b;}int main(){//定义一个函数指针int (*pf)(int,int) = fun;//int ans = 0;ans = fun(2,2);//普通ans = (*pf)(2,2);//函数指针使用1ans = pf(2,2);//函数指针使用2printf("%d\n",ans);return 0;}




评注:因为总结得比较急忙,准备过几天在编写更经典的代码时,再修改这些日志,到时候会把例子的链接加上就好了吐舌头

原创粉丝点击