一道华为笔试题 ,内存相关

本文探讨了C++中指针操作与内存管理的具体案例,包括指针差值计算、动态内存分配与释放的问题及类大小计算。通过具体代码示例展示了不同情况下可能遇到的陷阱,如使用未正确分配内存的指针导致程序崩溃,或返回栈内存地址导致的乱码等问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

下面一段程序,请说明输出结果:

int _tmain(int argc, _TCHAR* argv[])
{
  
int *p1,*p2,value;
  p1
=(int*)0x500;
  p2
=(int*)0x518;
  value
=p2-p1;
  printf(
"%d\n", value);
 
return 0;
}


 结果为6.


(0x518-0x500)/sizeof(int) =6

0x0018/4=6

 

void GetMemory(char *p)
{
p=(char*)malloc(100);
}

void Test(void)
{
char *str = NULL;
GetMemory(str);
strcpy(str,"helloworld");
printf(str);
}
请问运行Test函数会有什么样的结果?
答:程序崩溃。因为GetMemory并不能传递动态内存,Test函数中的str一直都是NULL。strcpy(str,"helloworld");将使程序崩溃。

char *GetMemory(void)
{
char p[]="helloworld";
return p;
}
void Test(void)
{
char *str = NULL;
str = GetMemory();
printf(str);

请问运行Test函数会有什么样的结果?
答:可能是乱码。因为GetMemory返回的是指向“栈内存”的指针,该指针的地址不是NULL,但其原先的内容已经被清除,新内容不可知。 

 

 

#include   <iostream.h>  
   
  class   A  
  {  
  unsigned   char   i;  
  virtual   f()   {};  
  };  
   
  class   B   :   public   A  
  {  
  };  
   
  class   C   :   virtual   public   A  
  {  
  };  
   
  class   D   :   public   B,   public   C  
  {  
  };  
   
  void   main()  
  {  
  cout   <<   "A:   "   <<   sizeof(A)   <<   endl;  
  cout   <<   "B:   "   <<   sizeof(B)   <<   endl;  
  cout   <<   "C:   "   <<   sizeof(C)   <<   endl;  
  cout   <<   "D:   "   <<   sizeof(D)   <<   endl;  
  }  
  结果为  
  A:   8  
  B:   8  
  C:   12  
  D:   20  
   
  A:1   char+3bit(补位)=4bit+1   ptr=8bit  
  B:sizeof(B)=0+sizeof(A)=8bit  
  C:sizeof(A)+1   ptr=12bit  
  D:sizeof(B)+sizeof(C)=20bit    

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值