作业
①实现strcat、strcmp函数
#include <stdio.h>
#include <string.h>
char *mystrcat(char *dest,char *src)
{
strcpy(dest+strlen(dest),src);
return dest;
}
int mystrcmp(char *s1,char *s2)
{
int n = 0;
int len1 = 0;
int len2 = 0;
len1 =strlen(s1)+1;
len2 =strlen(s2)+1;
for(int i =0 ;(i<len1)&&(i<len2);i++)
{
n = *(s1+i) - *(s2+i);
if(n!=0) break;
}
return n;
}
int main(int argc, const char *argv[])
{
char a[100]={0};
char b[100]={0};
printf("input a--->");
gets(a);
printf("input b--->");
gets(b);
char *s = a;
char *t = b;
printf("%d\n",mystrcmp(s,t));
mystrcat(s,t);
puts(a);
puts(b);
return 0;
}
②复习指针数组、数组指针和分文件编译内容
指针数组(数组每个元素都是指针)
指针数组:存储指针的数组,
格式: int *p; int arr[4]
数据类型 * 数组名[容量]
(需注意,p=a;这种赋值方法是错的,因为p是一个不可知变量,只存在p[0],p[1],p[2],但可以这样 p=a; 这里p表示指针数组第一个元素的值,a的首地址的值)
数组指针(指向整个数组的指针)
数组指针:指向整个数组的指针
格式:
数据类型 (*指针名)[数组容量]
也称为行指针
()优先级高,说明p是指针,指向一个整型的一维数组。这个一维数组的长度是n,也可以说p的步长为n。当p+1时,p指针会跨过n个整型数据的长度。
当数组指针指向一个二维数组时,数组指针也成为指向一维数组的指针,也就是行指针
分文件编译
将功能函数、主函数分开,分2个文件
头文件
将函数、函数声明单独出来,放在分别的.c 文件
将声明放在.h文件
.h文件是头文件
注意:
功能函数内不能有主函数
所有的.c文件 需要进行一起编译。
头文件命名规则
func.h 文件
#ifndef __FUNC_H__
#define __FUNC_H__
float div(float a,float b);
float mul(float a,float b);
float sub(float a,float b);
float add(float a,float b);
#endif
步骤
1.编写好的功能函数.c文件 (无主函数、函数声明)2.一起编译 gcc main.c fun.c
main.c
#include "func.h" //路径/头文件
fun.c
float add(float a,float b)
{
return a+b;
}
float sub(float a,float b)
{
return a-b;
}
float mul(float a,float b)
{
return a*b;
}
float div(float a,float b)
{
return a/b;
}
gcc的编译流程
gcc -E xx.c -o xx.i
预处理 : 展开头文件,替换宏定义,删除注释,生成编译文件,不检查语法错误
gcc -S xx.i -o xx.s
编译 : 检查语法错误,生成汇编文件
gcc -c xx.s -o xx.o
汇编 : 生成一个二进制文件/中间代码文件
---------------------------------------------------------------------------------------------------------
gcc xx.o -o 可执行文件
链接 : 链接到程序需要的动态库/静态库,生成可执行文件
基于上述编译过程,Makefile会把程序的编译,分为两步
第一步 : 生成二进制文件
第二步 : 二进制文件链接库生成可执行文件