在学习的过程中,不要一味地去学习新知识,温故以前学习的知识也是很有必要的:下面是我自己前几天测试自己的一些基本的试题;拿出来分享一下
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!!!!继续加油!