1、嵌入式习题练习到79题,关于malloc函数使用的问题。
2、在详细查资料后,对部分问题进行总结。如下:
①对于数组a[n],a与&a的区别,a是数组a[n]的首地址,即a[0]的地址。而&a表示行指针,它的移动单位不是数组元素,而是数组。
②for循环基本条件的确认,for( ; 判断条件。只要这里为真,则循环可以继续,与前后表达式无关。重要的是,只要>零,就为逻辑真 ; );
③malloc函数的使用方法。
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
void getmemory(char **p)
{
*p=(char *) malloc(100);
strcpy(*p,"hello world");
}
int main( )
{
char *str=NULL;
getmemory(&str);
printf("%s\n",str);
free(str);
return 0;
}
或者:#include <stdio.h>
#include <string.h>
#include <stdlib.h>
char* getmemory(char *p)
{
p=(char *) malloc(100);
strcpy(p,"hello world");
return p;
}
int main( )
{
char *str=NULL;
str=getmemory(str);
printf("%s\n",str);
free(str);
return 0;
}
④对于快速排序的理解。
找到一份很好的代码。