试题1:

 void test1()
{
 char string[];
 char* str1 ="";
 strcpy( string, str1 );
}

试题2:

 void test2()
{
 charstring[],str1[];
 int i;
 for(i=; i<; i++)
 {
  str1 ='a';
 }
 strcpy( string, str1 );
}

解答:
  试题1字符串str1需要11个字节才能存放下(包括末尾的’\0’),而string只有10个字节的空间,strcpy会导致数组越界;

  对试题2,如果面试者指出字符数组str1不能在数组内结束可以给3分;如果面试者指出strcpy(string,str1)调用使得从str1内存起复制到string内存起所复制的字节数具有不确定性可以给7分,在此基础上指出库函数strcpy工作方式的给10分;

正确的写法为:

 void test1()
{
 char str[];
 char* str1 ="";
 strcpy( str, str1 );
}
 char str[], str1[];
int i;
for (i = ; i<; i++)
{
str1[i] = 'a';
}
str1[i] = '\0';
strcpy_s(str, str1);

试题3:

void GetMemory( char*p )
{
 p = (char*) malloc( );
}
void Test( void )
{
 char*str = NULL;
 GetMemory( str );
 strcpy( str, "hello world" );
 printf( str );
}

试题3传入中GetMemory(char *p )函数的形参为字符串指针,在函数内部修改形参并不能真正的改变传入形参的值,执行完

char *str = NULL;
GetMemory( str ); 
后的str仍然为NULL;

试题4:

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

试题4中
char p[] = "hello world"; 
return p; 
  的p[]数组为函数内的局部自动变量,在函数返回后,内存已经被释放。

试题5:

 void GetMemory( char**p, int num )
{
 *p = (char*) malloc( num );
}
void Test( void )
{
 char*str = NULL;
 GetMemory( &str, );
 strcpy( str, "hello" );
 printf( str );
}

在GetMemory中执行申请内存及赋值语句

*p = (char *) malloc( num );
后未判断内存是否申请成功,应加上:

if ( *p == NULL )
{
 ...//进行申请内存失败处理
}

未对malloc的内存进行释放。

试题6:

 void Test( void )
{
 char*str = (char*) malloc( );
 strcpy( str, "hello" );
 free( str );
 ... //省略的其它语句
}

在执行char *str = (char *) malloc(100);后未进行内存是否申请成功的判断;另外,在free(str)后未置str为空,导致可能变成一个“野”指针,应加上:

str = NULL;

试题7:

 swap( int* p1,int* p2 )
{
 int*p;
 *p =*p1;
 *p1 =*p2;
 *p2 =*p;
}

在swap函数中,p是一个“野”指针,有可能指向系统区,导致程序运行的崩溃。在VC++中DEBUG运行时提示错误“AccessViolation”。该程序应该改为:

 swap( int* p1,int* p2 )
{
 int p;
 p =*p1;
 *p1 =*p2;
 *p2 = p;
}

 

其他

1.char *str(){char str[] = "hello world"; return str;}

这个函数返回的是局部变量的地址,调用这个函数后,这个局部变量str就释放了。

2.

void test()
{
  char str[10],str1[10];
  for(int i=0; i<10; i++)
  {
    str1[i] = 'a';
  }
  //str1[9]='\0'; //正确做法
  strcpy(str,str1);
  cout<<str<<endl;
}

str1没有结束符,应在strcpy之前加上str1[9]='\0';

3.

class A{const int size = 0;};这个类声明正确吗?为什么?

错误,常量必须在构造函数的初始化列表中初始化,或将其设置为static

class A{A(){const int size = 0;}};或

class A{static const int size = 0;}

4.

class base
{
private:
  int i;
public:
  base(int x){i = x;}
};

class derived:public base{
private:

  int i;
public:
  derived(int x,int y){i = x;}
  //derived(int x,int y):base(x){i = x;} //正确做法
};

int main(int argc, char* argv[])
{
  base a(5);
  return 0;
}

要在子类中设定初始化成员变量。

5.

char *my_cpy(char*src,int len)
{
  char dest[1024];
  memcpy(dest,src,len);
  return dest;
}

返回局部变量地址。

6.

请找出下面代码中的所以错误
说明:以下代码是把一个字符串倒序,如“abcd”倒序后变为“dcba”

1、#i nclude"string.h"
2、main()
3、{
4、 char*src="hello,world";
5、 char* dest=NULL;
6、 int len=strlen(src);
7、 dest=(char*)malloc(len);
8、 char* d=dest;
9、 char* s=src[len];
10、 while(len--!=0)
11、 d++=s--;
12、 printf("%s",dest);
13、 return 0;
14、}
答:
方法1:
int main(){
char* src = "hello,world";
int len = strlen(src);
char* dest = (char*)malloc(len+1);//要为\0分配一个空间
char* d = dest;
char* s = &src[len-1];//指向最后一个字符
while( len-- != 0 )
*d++=*s--;
*d = 0;//尾部要加\0
printf("%s\n",dest);
free(dest);// 使用完,应当释放空间,以免造成内存汇泄露
return 0;
}
方法2:
#i nclude <stdio.h>
#i nclude <string.h>
main()
{
char str[]="hello,world";
int len=strlen(str);
char t;
for(int i=0; i<len/2; i++)
{
t=str[i];
str[i]=str[len-i-1]; str[len-i-1]=t;
}
printf("%s",str);
return 0;
}

改错+GetMemory问题的更多相关文章

  1. 【C++基础】内存操作 getMemory改错

    内存操作的考察点:①指针 ②变量生存期及作用范围 ③动态内存申请和释放 笔试题************************************************************* ...

  2. C++面试之GetMemory问题

    http://blog.csdn.net/zhuxiaoyang2000/article/details/8084629 #include <iostream> #include < ...

  3. JAVA程序改错 (易错题)

    JAVA程序改错 1. abstract class Name { private String name; public abstract boolean isStupidName(String n ...

  4. 关于内存 GetMemory( ) 笔试分析

    1. #include<stdio.h>#include<string.h>void GetMemory(char *p){ p=(char *)malloc(100); }i ...

  5. YTU 2610: A改错题--体检情况分析

    2610: A改错题--体检情况分析 时间限制: 1 Sec  内存限制: 128 MB 提交: 233  解决: 161 题目描述 注:本题只需要提交标记为修改部分之间的代码,请按照C++方式提交. ...

  6. YTU 2609: A改错题--学生信息的输入和输出

    2609: A改错题--学生信息的输入和输出 时间限制: 1 Sec  内存限制: 128 MB 提交: 238  解决: 157 题目描述 注:本题只需要提交标记为修改部分之间的代码,请按照C++方 ...

  7. GetMemory 函数解析

    GetMemory函数 代码1: void GetMemory(char *p){ p = (char*)malloc(100);}int main(int argc, char *argv[]){ ...

  8. GetMemory()函数

    NO1 void GetMemory(char *p) { p=(char *)malloc(100); } void Test() { char * str=NULL; GetMemory(str) ...

  9. GetMemory那一题的理解

    #include "stdafx.h" #include <iostream> void GetMemory(char *p,int num) { p = (char* ...

随机推荐

  1. iOS 面试题 2

    1.         描述应用程序的启动顺序. 1.程序入口main函数创建UIApplication实例和UIApplication代理实例 2.在UIApplication代理实例中重写启动方法, ...

  2. iOS 面试题 1

    1.    简述OC中内存管理机制.与retain配对使用的方法是dealloc还是release,为什么?需要与alloc配对使用的方法是dealloc还是release,为什么?readwrite ...

  3. CTL_CODE 宏 详解

    CTL_CODE宏 CTL_CODE:用于创建一个唯一的32位系统I/O控制代码,这个控制代码包括4部分组成: DeviceType(设备类型,高16位(16-31位)), Function(功能2- ...

  4. oracle之Flash Recovery Area全面介绍 (转载)

    1. 设置闪回恢复区闪回恢复区主要通过3个初始化参数来设置和管理 db_recovery_file_dest:指定闪回恢复区的位置db_recovery_file_dest_size:指定闪回恢复区的 ...

  5. CSS3动画之透视

    若在x,y轴rotate90度,其实是线,不显示,按近大远小的透视关系可用 perspective:数值 开启透视: 默认以中间线为旋转基线,可以用transform-origin来设置旋转基线 在z ...

  6. 我和Python的第一次亲密接触 - 零基础入门学习Python001

    我和Python的第一次亲密接触 让编程改变世界 Change the world by program 小甲鱼经常说,学习一门编程语言就是要深入其中,要把编程语言想象为你的女朋友你的情人,这样你学习 ...

  7. MVC中配置OutputCache的VaryByParam参数无效的问题

    在项目使用OutputCacheAttribute是遇到了问题,当我想在配置文件web.config中配置OutputCache的VaryByParam时竟然不起作用,下面是相关代码: 文件FaceC ...

  8. 从Hello, world开始认识IL <第一篇>

    IL代码分析方法 Hello, world历史 .NET学习方法论 1.引言 1988年Brian W.Kernighan和Dennis M.Ritchie合著了软件史上的经典巨著<The C ...

  9. App开发革命进阶路

    APP开发的成败,或许不是程序编辑的多么完美,界面设计的多么精致,其实这就是一场用户体验的革命. APP的使用场景是移动设备,人机交互以单指手“触点”为主,大段文字输入是交互的禁区.因此,APP带来了 ...

  10. CentOS、Ubuntu、Debian三个linux比较异同

    Linux有非常多的发行版本,从性质上划分,大体分为由商业公司维护的商业版本与由开源社区维护的免费发行版本. 商业版本以Redhat为代表,开源社区版本则以debian为代表.这些版本各有不同的特点, ...