1. <tt id="5hhch"><source id="5hhch"></source></tt>
    1. <xmp id="5hhch"></xmp>

  2. <xmp id="5hhch"><rt id="5hhch"></rt></xmp>

    <rp id="5hhch"></rp>
        <dfn id="5hhch"></dfn>

      1. 創維筆試題目

        時間:2024-08-06 19:15:58 面試筆試 我要投稿

        創維筆試題目(精華)

        是當時面創維數字的筆試題,題目比較簡單,只涉及到了基本的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 <filename.h> 和 #include “filename.h” 有什么區別?(5分)

        答:對于#include <filename.h> ,編譯器從標準庫路徑開始搜索 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++) != ‘\0’ )     // 2分
               null ;
            return address ;                           // 2分
        }

        (2)strcpy能把strsrc的內容復制到strdest,為什么還要char * 類型的返回值?

        答:為了實現鏈式表達式。 // 2分

        例如 int length = strlen( strcpy( strdest, “hello world”) );


        六、編寫類string的構造函數、析構函數和賦值函數(25分)

        已知類string的原型為:

            class string
            {
              public:
                string(const char *str = null); // 普通構造函數
                string(const string other);         // 拷貝構造函數
                ~ string(void);                      // 析構函數
                string operate =(const string &other);     // 賦值函數
              private:
                char     *m_data;                 // 用于保存字符串
            };
              請編寫string的上述4個函數。
        標準答案:

        // string的析構函數

               string::~string(void)                // 3分
        {

            delete [] m_data;                     
        // 由于m_data是內部數據類型,也可以寫成 delete m_data;

               }
               // string的普通構造函數            
               string::string(const char *str)       // 6分
        {

            if(strnull)                          
            {
              m_data = new char[1];     // 若能加 null 判斷則更好
               *m_data = ‘\0’;                     
            }                                          
            else
            {
               int length = strlen(str);           
               m_data = new char[length+1];   // 若能加 null 判斷則更好      
               strcpy(m_data, str);               
            }
        }

        // 拷貝構造函數

            string::string(const string other)    // 3分
            {   
            int length = strlen(other.m_data);
            m_data = new char[length+1];       // 若能加 null 判斷則更好   
            strcpy(m_data, other.m_data);         
        }

        // 賦值函數

            string string:perate =(const string other)     // 13分
            {   
               // (1) 檢查自賦值                      // 4分
               if(this other)
                   return *this;



        // (2) 釋放原有的內存資源 // 3分

               delete [] m_data;



               // (3)分配新的內存資源,并復制內容 // 3分
            int length = strlen(other.m_data);
            m_data = new char[length+1];          // 若能加 null 判斷則更好
               strcpy(m_data, other.m_data);



               // (4)返回本對象的引用             // 3分
               return *this;
        }

        【創維筆試題目】相關文章:

        2012創維筆試題目10-03

        創維筆試經驗09-30

        創維筆試題精華05-05

        創維筆試 四川大學09-11

        筆試題目09-16

        微軟筆試題目06-16

        網通筆試題目08-14

        畢馬威廣州筆試的題目09-13

        jsp經典筆試題目07-06

        醫院筆試題目09-06

        国产高潮无套免费视频_久久九九兔免费精品6_99精品热6080YY久久_国产91久久久久久无码

        1. <tt id="5hhch"><source id="5hhch"></source></tt>
          1. <xmp id="5hhch"></xmp>

        2. <xmp id="5hhch"><rt id="5hhch"></rt></xmp>

          <rp id="5hhch"></rp>
              <dfn id="5hhch"></dfn>