字符串一级指针
C语言里没有实质的字符串类型,通过字符数组来模拟。
C语言的字符串是以0结尾的字符串。
C语言字符串的内存分配 可以分配在堆上、栈上、全局区上。
1、字符串一级指针内存模型
buf数组与指针的区别:
注意:
char buf[20] = “aaaa”; 字符串数组的初始化步骤是,先在常量区创建字符常量“aaaa”,再从字符常量区拷贝字符到堆区(临时区)。
2、字符串copy函数的经典实现及判空和引入辅助指针变量
//int copy(char *from, char *to) {
// if (from == NULL || to == NULL) {
// return -1;
// }
// while( (*to = *from) != '\0' ){
// from ++;
// to ++;
// }
//}
int copy(char *from, char *to) {
// 为了程序的健壮性,这里要判空
if (from == NULL || to == NULL) {
return -1;
}
// 不要轻易改变形参的值,最好引入一个辅助的指针变量,把形参给接过来...
char *tem_from = from;
char * temp_to = to;
while( *temp_to ++ = *tem_from ++ ); // 空语句
printf("%s", from);// 因为形参from指针没有发生变化,这里可以正常打印。
}
int main() {
char *from = "abce";
char *to[100];
copy(from, to);
printf("to=%s \n", to);
system("pause");
return 0;
}
二级指针
1、二级指针内存模型
二级指针的三种内存模型,对应C语言字符串的内存分配 可以分配在堆上、栈上、全局区上。
第一种内存模型:指针数组,对应字符串分配在全局区(代码区)。
第二种内存模型:二维数组,对应字符串分配在栈上。
第三种内存模型:手工打造二级指针,对应字符串分配在堆上。
2、二级指针做函数参数
第一种内存模型:数组做函数参数退化为指针,指针数组做函数参数退化为二级指针。
第二种内存模型:二维数组做函数参数退化为一个指向一维数组的指针。
第三种内存模型:被调函数分配内存,将结果甩出来给主调函数。