标签:char rom 编译器 col === 字符数组 长度 rcp class
//一级指针的典型用法
//数组 int a[10]
//字符串
//1 C语言的字符串 以零结尾的字符串
//2 在C语言中没有字符串类型 通过字符数组 来模拟字符串
//3 字符串的内存分配 堆上 栈上 全局区 (很重要)
字符串的初始化
void main() { //1 指定长度 char buf2[100] = {‘a‘, ‘b‘, ‘c‘, ‘d‘}; //1-1 char buf3[2] = {‘a‘, ‘b‘, ‘c‘, ‘d‘}; //如果初始化的个数大于内存的个数 编译错误 //1-2 //后面的buf2[4]-buf2[99] 0 //2 不指定长度 C编译器会自动帮程序员 求元素的个数 char buf1[] = {‘a‘, ‘b‘, ‘c‘, ‘d‘}; //buf1是一个数组 不是一个以0结尾的字符串 printf("buf2: %s \n", buf2); printf("buf2[88]:%d \n", buf2[88]); printf("hello....\n"); system("pause"); return ; }
//下面要是面试题可别错 //用字符串 来 初始化字符数组 //strlen() 长度 不包括0 //sizeof() 内存块的大小 void main52() { int size = 0; char buf3[] = "abcd"; // buf3 作为字符数组 应该是5个字节 //作为字符串 应该4个字节 int len = strlen(buf3); printf("buf3字符的长度:%d \n", len); //4 //buf3 作为数组 数组是一种数据类型 本质(固定小大内存块的别名) size = sizeof(buf3); // printf("buf3数组所占内存空间大小:%d \n", size); //5 printf("hello....\n"); { char buf4[128] = "abcd"; // buf printf("buf4[100]:%d \n", buf4[100]); } system("pause"); return ; }
//通过数组下标 和 指针
void main58() { int i = 0; char *p = NULL; char buf5[128] = "abcdefg"; // buf for (i=0; i<strlen(buf5); i++) { printf("%c ", buf5[i]); } p = buf5; //buf 代表数组首元素的地址 for (i=0; i<strlen(buf5); i++) { p = p +i; //*(p+i) printf("%c ", *p ) ; } //buf for (i=0; i<strlen(buf5); i++) { printf("%c ", *(buf5+i) ) ; } //[] *的推导过程 // buf5[i] ===> buf5[0+i]; ==> *(buf5+i); { //buf5 = buf5 + 1; //buf5 = 0x11; } printf("hello....\n"); system("pause"); } // []的本质 :和*p 是一样 ,只不过是符合程序员的阅读习惯 // buf5 是一个指针, 只读的常量 buf5是一个常量指针 析构内存的时候,保证buf所指向的内存空间安全释放 //为什么这么做? //p普通指针和内存首地址区别
//一级指针的内存模型 void main61() { char buf[20]= "aaaa"; //定义并且初始化 char buf2[] = "bbbb"; char *p1 = "111111"; char *p2 = malloc(100); strcpy(p2, "3333"); system("pause"); return ; }
//字符串技术推演 void copy_str(char *from, char *to) { for (; *from != ‘\0‘; from++, to++) { *to = *from; } *to = ‘\0‘; return ; } void main() { char *from = "abcd"; char buf[100]; copy_str(from, buf); printf("buff:%s\n", buf); system("pause"); }
标签:char rom 编译器 col === 字符数组 长度 rcp class
原文地址:https://www.cnblogs.com/yaozhenhua/p/9321678.html