今日学习任务
C语言的函数指针,数组指针,指针数组,main函数命令行
今日任务完成情况
void (*p)() 定义变量 定义一个函数指针
int(*p)()和int *p()区别
int (*p)()是一个变量说明,说明p是一个指向函数入口的指针变量,该函数的返回值是整型量,(*p)的两边的括号不能少。
int *p()则不是变量说明而是函数说明,说明p是一个指针型函数,其返回值是一个指向整型量的指针,*p两边没有括号。
一个数组的元素值为指针则是指针数组。
指针数组的所有元素都必须是具有相同存储类型和指向相同数据类型的指针变量。
int a[5][10]与 int (*p)[10]
二维数组名是一个指向有10个元素的一维数组的指针常量
p=a+i 使p指向二维数组的第i行
*(*(p+i)+j)==a[i][j]
二维数组形参实际上是一维数组指针变量,
即int x[][10] == int (*x)[10]
malloc申请一段空间
strcpy 拷贝函数
argc:参数的个数
argv: 指针数组,具体的参数
今日开发中遇到的问题汇总
无法准确理解指针、指针的指针、指针的指针的指针相互之间对应的存储关系,以及相关作用
今日未解决问题
基本解决
今日开发收获
对C语言的数组以及函数知识有了大体的回顾,大概想起了关于C语言指针的一些知识体系,可以使用C语言来编写一些简单程序,也学到了一些新的知识点,学会了编程过程中的一些思路,可以进行一些简单的编程。
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;
}
C语言的函数指针,数组指针,指针数组,main函数命令行
今日任务完成情况
void (*p)() 定义变量 定义一个函数指针
int(*p)()和int *p()区别
int (*p)()是一个变量说明,说明p是一个指向函数入口的指针变量,该函数的返回值是整型量,(*p)的两边的括号不能少。
int *p()则不是变量说明而是函数说明,说明p是一个指针型函数,其返回值是一个指向整型量的指针,*p两边没有括号。
一个数组的元素值为指针则是指针数组。
指针数组的所有元素都必须是具有相同存储类型和指向相同数据类型的指针变量。
int a[5][10]与 int (*p)[10]
二维数组名是一个指向有10个元素的一维数组的指针常量
p=a+i 使p指向二维数组的第i行
*(*(p+i)+j)==a[i][j]
二维数组形参实际上是一维数组指针变量,
即int x[][10] == int (*x)[10]
malloc申请一段空间
strcpy 拷贝函数
argc:参数的个数
argv: 指针数组,具体的参数
今日开发中遇到的问题汇总
无法准确理解指针、指针的指针、指针的指针的指针相互之间对应的存储关系,以及相关作用
今日未解决问题
基本解决
今日开发收获
对C语言的数组以及函数知识有了大体的回顾,大概想起了关于C语言指针的一些知识体系,可以使用C语言来编写一些简单程序,也学到了一些新的知识点,学会了编程过程中的一些思路,可以进行一些简单的编程。
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;
}