0
点赞
收藏
分享

微信扫一扫

指针和数组笔试题(2)

#define _CRT_SECURE_NO_WARNINGS 1 
#include<stdio.h>
#include<string.h>

//笔试题(1):
//int main()
//{
// int a[5] = { 1,2,3,4,5 };
// int* ptr = (int*)(&a + 1);
// printf("%d,%d\n", *(a + 1), *(ptr - 1)); //2,5
// return 0;
//}

//笔试题(2):
//struct Test
//{
// int Num;
// char* pcName;
// short sDate;
// char cha[2];
// short sBa[4];
//}* p;
//
////假设p的值为0x100000,如下表达式的值分别为?
////已知,结构体Test类型的变量大小是20个字节;
//int main()
//{
// p = (struct Test*)0x100000;
// printf("%p\n", p + 0x1); //0x00100014
// //p是结构体类型,所以p+1,加上一个结构体类型,0x00100000+20=0x00100014
//
// printf("%p\n", (unsigned long)p + 0x1); //0x00100001 :
// //把p转换为十进制再加上一个(unsigne long)0x1=1048576+1=1048577 ,再转换为地址,打印出来
//
// printf("%p\n", (unsigned int*)p + 0x1); //0x00100004 :
// //把p转换为十进制再加上一个(unsig int*)0x1(跳过一个无符号整型)=1048576+4=1048580,
// return 0;
//}

//笔试题(3):
//int main()
//{
// int a[4] = { 1,2,3,4 }; //小端存储:01 00 00 00 02 00 00 00 03 00 00 00 04 00 00 00
// int* ptr1 = (int*)(&a + 1);
// int* ptr2 = (int*)((int)a + 1); //(int)a:转换为整型,再+1,就是往后移动1个字节,此时ptr2指向的是:00 00 00 02,(小端存储)
// printf("%x,%x", ptr1[-1], *ptr2); //4, 2000000
// return 0;
//}

//笔试题(4):
//int main()
//{
// int a[3][2] = { (0,1),(2,3),(4,5) };
// int* p;
// p = a[0];
// printf("%d", p[0]); //1
// return 0;
//}

//笔试题(5):
//int main()
//{
// int a[5][5];
// int(*p)[4];
// p = a;
// printf("%p,%d\n", &p[4][2] - &a[4][2],&p[4][2] - &a[4][2]); //FFFFFFFC,-4
// //p[4][2]=*(*(p+4)+2),,因为p是指针,所以p+4移动4个指针大小
// return 0;
//}

//笔试题(6):
//int main()
//{
// int aa[2][5] = { 1,2,3,4,5,6,7,8,9,10 };
// int* ptr1 = (int*)(&aa + 1);
// int* ptr2 = (int*)(*(aa + 1));
// printf("%d,%d", *(ptr1 - 1), *(ptr2 - 1)); //10,5
// return 0;
//}

//笔试题(7):
//int main()
//{
// char* a[] = { "work","at","alibaba" };
// char** pa = a;
// pa++;
// printf("%s\n", *pa); //at
// return 0;
//}

//笔试题(8):
int main()
{
char* c[] = { "enter","new","point","first" };
char** cp[] = { c + 3,c + 2,c + 1,c };
char*** cpp = cp;

printf("%s\n", **++cpp); //point: 先计算++
printf("%s\n", *-- * ++cpp + 3);//er
printf("%s\n", *cpp[-2] + 3); //st:* *(cpp-2) +3
printf("%s\n", cpp[-1][-1] + 1);//ew:*(*(cpp-1)-1)+1
return 0;
}

指针和数组笔试题(2)_笔试题


举报

相关推荐

0 条评论