总结C/C++面试中可能会碰到的字符串指针题

2020-01-06 16:26:28丽君

  以下是引用片段:


void strcpy(char *strDest, const char *strSrc) 
{ 
  //对源地址和目的地址加非0断言,加3分 
   assert( (strDest != NULL) &&(strSrc != NULL) ); 
   while( (*strDest++ = * strSrc++) != ‘' ); 
}

  10分

  以下是引用片段:


// 为了实现链式操作,将目的地址返回,加3分! 
char * strcpy( char *strDest, const char *strSrc ) 
{ 
   assert( (strDest != NULL) &&(strSrc != NULL) ); 
   char *address = strDest; 
   while( (*strDest++ = * strSrc++) != ‘' ); 
   return address; 
} 

  从2分到10分的几个答案我们可以清楚的看到,小小的strcpy竟然暗藏着这么多玄机,真不是盖的!需要多么扎实的基本功才能写一个完美的 strcpy啊!

  (4)对strlen的掌握,它没有包括字符串末尾的''。

  读者看了不同分值的 strcpy版本,应该也可以写出一个10分的strlen函数了,完美的版本为:

  以下是引用片段:


int strlen( const char *str ) //输入参数const 
{ 
  assert( strt != NULL ); //断言字符串地址非0 
   int len; 
   while( (*str++) != '' ) 
   { 
   len++; 
   } 
   return len; 
} 

  试题4:

  以下是引用片段:


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

  试题5:

  以下是引用片段:


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

  试题6:

  以下是引用片段:


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

  试题7:

  以下是引用片段:


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

  解答:

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


char *str = NULL;GetMemory( str ); 

后的str仍然为NULL;

  试题5中


char p[] = "hello world"; 
return p;