創維數字筆試題精華

學識都 人氣:5.89K

  是當時面創維數字的筆試題,題目比較簡單,只涉及到了基本的c語法,沒有考到數據結構以及算法,試題在前面說明這套題並不能反映應聘者實際的軟件開發及編程能力。

創維數字筆試題精華

  一、請填寫bool , float, 指針變量 與“零值”比較的 if 語句。(10分)

  請寫出 bool flag 與“零值”比較的 if 語句。

  if ( flag )

  if ( !flag )

  請寫出 float x 與“零值”比較的 if 語句。

  const float epsinon = 0.00001;

  if ((x >= - epsinon) & (x <= epsinon)

  不可將浮點變量用“”或“!=”與數字比較,應該設法轉化成“>=”或“<=”此類形式。

  請寫出 char *p 與“零值”比較的 if 語句。

  if (p null)

  if (p != null)

  二、以下爲windows nt下的32位c++程序,請計算sizeof的值(10分)

  char str[] = “hello” ;

  char *p = str ;

  int n = 10;

  請計算

  sizeof (str ) = 6 (2分)

  sizeof ( p ) = 4 (2分)

  sizeof ( n ) = 4

  void func ( char str[100])

  {

  請計算

  sizeof( str ) = 4 (2分)

  }

  void *p = malloc( 100 );

  請計算

  sizeof ( p ) = 4 (2分)

  三、簡答題(25分)

  1、頭文件中的 ifndef/define/endif 幹什麼用?(5分)

  答:防止該頭文件被重複引用。

  2、#include 和 #include “filename.h” 有什麼區別?(5分)

  答:對於#include ,編譯器從標準庫路徑開始搜索 filename.h

  對於#include “filename.h” ,編譯器從用戶的工作路徑開始搜索 filename.h

  3、const 有什麼用途?(請至少說明兩種)(5分)

  答:(1)可以定義 const 常量

  (2)const可以修飾函數的參數、返回值,甚至函數的定義體。被const修飾的東西都受到強制保護,可以預防意外的變動,能提高程序的健壯性。

  4、在c++ 程序中調用被 c編譯器編譯後的函數,爲什麼要加 extern “c”? (5分)

  答:c++語言支持函數重載,c語言不支持函數重載。函數被c++編譯後在庫中的名字與c語言的不同。假設某個函數的原型爲: void foo(int x, int y);

  該函數被c編譯器編譯後在庫中的名字爲_foo,而c++編譯器則會產生像_foo_int_int之類的名字。

  c++提供了c連接交換指定符號extern“c”來解決名字匹配問題。

  四、有關內存的思考題(每小題5分,共20分)

  一.

  void getmemory(char *p)

  {

  p = (char *)malloc(100);

  }

  void test(void)

  {

  char *str = null;

  getmemory(str);

  strcpy(str, "hello world");

  printf(str);

  }

  請問運行test函數會有什麼樣的結果?

  答:試題傳入getmemory( char *p )函數的形參爲字符串指針,在函數內部修改形參並不能真正的改變傳入形參的值,執行完 char *str = null; getmemory( str ); 後的str仍然爲null;

  二.

  char *getmemory(void)

  {

  char p[] = "hello world";

  return p;

  }

  void test(void)

  {

  char *str = null;

  str = getmemory();

  printf(str);

  }

  請問運行test函數會有什麼樣的結果?

  答:可能是亂碼。 char p[] = "hello world";

  return p;

  的p[]數組爲函數內的局部自動變量,在函數返回後,內存已經被釋放。這是許多程序員常犯的錯誤,其根源在於不理解變量的生存期。

  三.

  void getmemory2(char **p, int num)

  {

  p = (char *)malloc(num);

  }

  void test(void)

  {

  char *str = null;

  getmemory(str, 100);

  strcpy(str, "hello");

  printf(str);

  }

  請問運行test函數會有什麼樣的.結果?

  答:

  (1)能夠輸出hello (2 )test函數中也未對malloc的內存進行釋放。(3)getmemory避免了試題1的問題,傳入getmemory的參數爲字符串指針的指針,但是在getmemory中執行申請內存及賦值語句

  p = (char *) malloc( num );

  後未判斷內存是否申請成功,應加上: if ( *p null ) {

  ...//進行申請內存失敗處理

  }

  四.

  void test(void)

  {

  char *str = (char *) malloc(100);

  strcpy(str, “hello”);

  free(str);

  if(str != null)

  {

  strcpy(str, “world”);

  printf(str);

  }

  }

  請問運行test函數會有什麼樣的結果?

  答:執行 char *str = (char *) malloc(100); 後未進行內存是否申請成功的判斷;另外,在free(str)後未置str爲空,導致可能變成一個“野”指針,應加上: str = null;

  五、編寫strcpy函數(10分)

  已知strcpy函數的原型是

  char *strcpy(char *strdest, const char *strsrc);

  其中strdest是目的字符串,strsrc是源字符串。

  (1)不調用c++/c的字符串庫函數,請編寫函數 strcpy

  char *strcpy(char *strdest, const char *strsrc);

  {

  assert((strdest!=null) & (strsrc !=null)); // 2分

  char *address = strdest; // 2分

  while( (*strdest++ = * strsrc++) != ‘