数组和指针常见笔试题(深度剖析)
strlen和sizeof的区别
strlen是统计\0之前的字符个数,传递的是地址
sizeof是计算类型的字节数,其实在编译期间会通过类型来确定大小
下边我来讲一下常见的面试题,过程很详细放心观看
#include<stdio.h> #include <string.h> int main() { char arr[] = { 'a','b','c','d','e','f' }; printf("%d\n", strlen(arr));//随机值,因为strlen是遇到斜杠\0结束,统计\0之前的字符个数 printf("%d\n", strlen(arr + 0));//起始地址不变,还是随机值 //printf("%d\n", strlen(*arr));//第一个元素,错误,只能给地址 //printf("%d\n", strlen(arr[1]));//元素错误同理 printf("%d\n", strlen(&arr));//随机值 printf("%d\n", strlen(&arr + 1));//随机值 printf("%d\n", strlen(&arr[0] + 1));//随机值 printf("%d\n", sizeof(arr));//sizeof统计的是字节大小(包括\0),记住数组名放在sizeof内部表示数组全部元素大小,所以是6 printf("%d\n", sizeof(arr + 0));//arr+0和数组名arr不是一个意思,所以表示的是地址,4/8 printf("%d\n", sizeof(*arr));//数组首元素地址解引用之后是数组首元素,1字节 printf("%d\n", sizeof(arr[1]));//元素b,1字节 printf("%d\n", sizeof(&arr));//整个数组的地址也是地址,4/8 printf("%d\n", sizeof(&arr + 1));//跳过一个数组大小,还是地址4/8 printf("%d\n", sizeof(&arr[0] + 1));//第二个元素的地址,注意[]优先级比&高 return 0; }
#include<string.h> int main() { char arr[] = "abcdef";//这种就是数组结尾多了一个\0,本质还是数组 printf("%d\n", strlen(arr));//6,统计\0之前的字符个数 printf("%d\n", strlen(arr + 0));//还是6,起始地址是数组首元素地址 //printf("%d\n", strlen(*arr));//err 不能放元素 //printf("%d\n", strlen(arr[1]));//err t同理 printf("%d\n", strlen(&arr));//还是6,因为数组的地址和数组首元素的地址相同,直接统计\0之前的字符个数 printf("%d\n", strlen(&arr + 1));//随机值,跳过一个数组的地址,相当于后边是随机值 printf("%d\n", strlen(&arr[0] + 1));//第二个元素的地址,5 printf("%d\n", sizeof(arr));//7,统计字符个数+\0 printf("%d\n", sizeof(arr + 0));//数组首元素地址,地址大小是4/8(32位或者64位机器的区别) printf("%d\n", sizeof(*arr));//数组首元素的地址被解引用,是数组首元素,1 printf("%d\n", sizeof(arr[1]));//数组第二个元素,1 printf("%d\n", sizeof(&arr));//数组的地址,大小是4/8 printf("%d\n", sizeof(&arr + 1));//还是地址 printf("%d\n", sizeof(&arr[0] + 1));//数组第二个元素的地址 return 0; }
本节的内容基础之前写过,我把链接放在综这里有需要的可以看看,比如数组名那里就可以回顾一下指针的进阶_在指针中int*w,*p=*w是-CSDN博客文章浏览阅读1.7k次,点赞33次,收藏39次。如果你把函数的指针(地址)作为参数传递给另一个函数,当这个指针被用来调用其所指向的函数时,我们就说这是回调函数。1. sizeof(数组名),这里的数组名不是数组首元素的地址,数组名表示整个数组,sizeof(数组名)计算的是整个数组的大小,单位是字节。数组名是数组首元素的地址,arr[1]拿到的是arr1数组名,再使用下标就能访问数组的元素,很简单。2. &数组名,这里的数组名表示整个数组, &数组名取出的是整个数组的地址。是指针,指针指向的是一个函数,指向的函数无参数,返回值类型为void。_在指针中int*w,*p=*w是https://blog.csdn.net/eixjdj/article/details/145118231
#include<stdio.h> #include<string.h> int main() { const char* p = "abcdef";//字符串结尾有\0 printf("%d\n", strlen(p));//6,统计\0之前的 printf("%d\n", strlen(p + 1));//5,从第二个地址开始 // printf("%d\n", strlen(*p));//err,不能放非地址 //printf("%d\n", strlen(p[0]));//err 和上边同理 printf("%d\n", strlen(&p));//相当于是字符串首地址的地址,p指向一个地址,不确定什么时候遇到\0,是随机值 printf("%d\n", strlen(&p + 1));//跳过整个数组的地址,随机值 printf("%d\n", strlen(&p[0] + 1));//第二个元素的地址,5 printf("%d\n", sizeof(p));//地址大小是4/8 printf("%d\n", sizeof(p + 1));//第二个位置的指针,4/8 printf("%d\n", sizeof(*p));//第1个元素,刚才讲过是1 printf("%d\n", sizeof(p[0]));//第一个元素,1 printf("%d\n", sizeof(&p));//地址大小是4或8 printf("%d\n", sizeof(&p + 1));//地址大小是4或8 printf("%d\n", sizeof(&p[0] + 1));//地址大小是4或8 return 0; }
#include<stdio.h> #include<string.h> int main() { int a[3][4] = { 0 }; printf("%d\n", sizeof(a));//sizeof数组名是整个数组大小,所以是3*4*4=48 printf("%d\n", sizeof(a[0][0]));//这个是经典的二维数组的第一个元素,大小是一个整形4 printf("%d\n", sizeof(a[0]));//是第一行数组的数组名,数组名放在sizeof是整个数组大小,所以是第一行的大小是4*4=16 printf("%d\n", sizeof(a[0] + 1));//第一行数组的首元素的地址+1跳过一个整形,是第一行第二个元素的地址,4/8 printf("%d\n", sizeof(*(a[0] + 1)));//解引用第一行第二个元素的地址,拿到这个元素,4 printf("%d\n", sizeof(a + 1));//二维数组的数组名也是数组首元素的地址,二维数组的多行一维数组可以看成多个元素 //那么可以理解为第一个元素的地址也就是第一行的地址,第一行的地址+1跳过这一行到第二行,成为第二行的地址,数组的地址是4/8 printf("%d\n", sizeof(*(a + 1)));//第二行的地址被解引用,是第二行的所有元素也就是16 printf("%d\n", sizeof(&a[0] + 1));//a[0]是第一行数组名,取地址是第一行数组的地址,+1是跳过第一行元素,成为第二行元素的地址,4/8 printf("%d\n", sizeof(*(&a[0] + 1)));//对第二行数组地址解引用,拿到第二行的数组元素是16 printf("%d\n", sizeof(*a));//a是数组首元素的地址,第一行的地址,解引用拿到这一行是16 printf("%d\n", sizeof(a[3]));//这里不会越界访问,因为sizeof是在编译时查看括号内的类型而确定大小,并不会运算,所以还是16 return 0; }
以上就是对常见笔试题的剖析,感谢一直以来支持我的人!!