在学习的过程中,不要一味地去学习新知识,温故以前学习的知识也是很有必要的:下面是我自己前几天测试自己的一些基本的试题;拿出来分享一下
1.写一个指针数组;
2.写一个数组指针;
3.写一个函数指针;
4.写一个函数指针数组;
5.写一个函数指针数组指针;
6.用自己的话解释含义: int* ( *fun ( double , char* ) ) ( char*, int** );
7.模拟实现strstr;
8.迷你实现strcpy;
以上是本人对自己的测试题;如有兴趣大家可以动手写一写;都是一些和基础的东西;
我的解答:
1.int* arr[10]={0};
2.int (*arr)[10]=NULL;
3.int ( *fun ) (int,int);
4.int ( *fun[10] )(int ,int);
5..int (* (*fun)[10] )(int ,int);
6. 解释这个:int* ( ) ( char*, int** );
解释含义:首先fun是一个函数声明;这个函数有两个参数,第一个参数是double类型,第二个参数是char*类型;这个函数的返回值是一个函数指针类型,这个函数指针类型的指针可以指向一个函数,能够指向的这个函数的类型是:第一个采纳数为char*,第二个参数为int**,返回值为int*。
相当于这么写: int*(*)(char*, int**) fun( double , char* );这样写就是普通函数定义的模式;大家也可以很好的理解;
7.模式实现strstr
strstr;查找一个字符串的字串是否存在;若果查找的字符串在原字符串中;则输出该字符串在原字符串首字符的位置;
程序实现:
#include<stdio.h> #include<assert.h> #include<string.h> char* my_strstr(const char*s1,const char*s2) { const char*str1=s1; const char*str2=s2; const char*p1=NULL; assert(s1); assert(s2); while(*str1) { p1=str1;//用p1空指针保存每次进来的str1的地址; while((*str1==*str2)&&*str1&&*str2) //当条件成立时 { str1++; //str1和str2向后移动; str2++; } if(*str2=='\0')//如果str2走到'\0'了说明找到了 { return (char*)p1;//返回str1进入循环时的初地址 } else str1=p1+1;<strong><span style="font-size:24px;"><span style="font-size: 24px;"></span></span></strong><pre name="code" class="cpp"> //如果没有找到则str1在进入循环的初位置向后挪动一个字符;str2=s2;//str2回到原始位置}return NULL;}int main(){char *p1="aaadeffffdefcccc";char *p2="def";char *p3=my_strstr(p1,p2);printf("%s",p3); return 0;} 讲解:
8.模拟实现strcpy
含义:讲一个字符串拷贝到另一个字符串中;注意:'\0'一起拷贝进去;
代码实现:
#define _CRT_SECURE_NO_WARNINGS 1 #include<stdio.h> #include<stdlib.h> #include<assert.h> char *my_strcpy(char *dest, char *src) { assert(dest); assert(src); char *ret = dest; while ((*dest++ = *src++) )//连同‘\0’一起拷贝了 { ; } /*while (*src) { *dest = *src; dest++; src++; }*/ //原串为‘\0’时跳出,并未拷贝‘\0’,要赋值*dest = '\0' //*dest = '\0'; return ret; //自加有副作用,因此return dest 可能读到最后'\0'就不输出了 }
ok!!!!继续加油!