学习日志第四天

                                                               学习日志                                          

                                                                                    姓名:陈长稳        日期: 7.12

今日学习任务

今天主要学习函数指针,指针数组,指针的指针及main函数,学习及巩固指针的相关知识

今日任务完成情况          

 今天主要学习了函数指针,指针数组,指针的指针及main函数

今日开发中出现的问题汇总

1.值传递和地址传递的区别没分清

2. int(*p)()和int *p()的区别

今日未解决问题

指针定义的不同含义,指针的具体使用方法

今日开发收获

一.函数与指针
    int (*pf)()
    表示Pf是一个指向函数入口的指针变量,该函数的返回值是整型
   #include <stdio.h>
   #include <string.h>


   void print()
{
printf("helloworld!\n");
}


void add(int x,int y)
{
printf("%d\n", x+y);
}


int main()
{
int a=1,b=2;
void (*p)();  //定义变量  定义一个函数指针
void (*p2)(int, int);
print(); //函数调用


p=print;
p();   //通过函数指针调用函数

p2 = add;
p2(a,b);
return 0;
}
  
      2. int(*p)()和int *p()的区别
         变量说明    函数说明
int *(*(*fp)(int ))[10];
fp是一指针,指向函数,函数有一个int类型参数,函数返回值是一个指针,指向一个有10个元素的数组,每一个元素都是一个整形指针
int *(*(*array[5])())();
array是一个有5个元素的数组,每个元素都是指针,指向一个没有参数的函数,函数返回值是一个指针,指向一个没有参数的函数,返回值
是一个整型指针

二.指针数组
    &a    数组的地址        
    a       数组首行地址
    a[0]  *a  *(a+1)    首行首元素地址

    a+1  &a[1]       第二行地址


void InitMemory(char **s)
{
(*s) = (char*)malloc(sizeof(char)*64);
}
int main()
{
char *ptr = NULL;


InitMemory(&ptr);    //地址传递
strcpy(ptr,"helloworld");
printf("%s\n",ptr);

while(1);
return 0;
}

三.main函数
   argc: 参数的个数
   argv: 指针数组,具体的参数

自我评价

 学习指针这一块感觉有点吃力,有点跟不上老师的进度。编写代码的速度也要多加练习,加快打字速度。


作业:

1、字符串排序:

#include<stdio.h>

#include<string.h>

#include<stdlib.h>

#define SIZE 3 

void sort(char *string[],int length)

{

int i,j;

char *t;

for(j=0;j<length-1;j++)

{

    for(i=0;i<length-j-1;i++)

{

    if(strcmp(string[i],string[i+1])>0)

{

      t=string[i];

       string[i]=string[i+1];

                      string[i+1]=t;

}

}

}

}

int main(int argc, char *argv[])

{

int i;

sort(argv,argc-1);

printf("The string after sort:\n");

for(i=1;i<argc;i++)//输出

               {

  printf("%s ",argv[i]);

}

    while(1);

    return 0;

}

2、冒泡排序程序

#include <stdio.h>

void sort(int *a[],int argc)

{

    int i, j, tmp;

for (i = 0; i < argc - 1; i++)

{

for (j = 0; j < argc - i - 1; j++)

{

if (a[j] < a[j + 1])

{

tmp = a[j];

a[j] = a[j + 1];

a[j + 1] = tmp;

}

}

}

}

void print(int *a[],int argc)

{

        int i;

for (i = 1; i < argc; i++)

{

printf("%d ", a[i]);

}

printf("\n");

}

int main(int argc, int *argv[i])

{

 sort(argv,argc);

print(argv,argc);

while (1);

return 0;

}


猜你喜欢

转载自blog.csdn.net/baqidemingzi/article/details/81019895