[收集] 經典C/C++面試題(四)

來源:互聯網
上載者:User

1、局部變數能否和全域變數重名?
     能,局部會屏蔽全域。要用全域變數,需要使用"::"
局部變數可以與全域變數同名,在函數內引用這個變數時,會用到同名的局部變數,而不會用到全域變數。對於有些編譯器而言,在同一個函數內可以定義多個同名的局部變數,比如在兩個迴圈體內都定義一個同名的局部變數,而那個局部變數的範圍就在那個迴圈體內。

2、如何引用一個已經定義過的全域變數?
     extern
     可以用引用標頭檔的方式,也可以用extern關鍵字,如果用引用標頭檔方式來引用某個在標頭檔中聲明的全域變理,假定你將那個變寫錯了,那麼在編譯期間會報錯,如果你用extern方式引用時,假定你犯了同樣的錯誤,那麼在編譯期間不會報錯,而在串連期間報錯。

3、全域變數可不可以定義在可被多個.C檔案包含的標頭檔中?為什嗎?
    可以,在不同的C檔案中以static形式來聲明同名全域變數。
    可以在不同的C檔案中聲明同名的全域變數,前提是其中只能有一個C檔案中對此變數賦初值,此時串連不會出錯。

4、語句for( ;1 ;)有什麼問題?它是什麼意思?
    無限迴圈,和while(1)相同。

5、do……while和while……do有什麼區別?
    前一個迴圈一遍再判斷,後一個判斷以後再迴圈。

6、請寫出下列代碼的輸出內容
#include<stdio.h>
main()
{
    int a,b,c,d;
    a=10;
    b=a++;
    c=++a;
    d=10*a++;
    printf("b,c,d:%d,%d,%d",b,c,d);
    return 0;
}
答:10,12,120

7、請找出下面代碼中的所以錯誤
說明:以下代碼是把一個字串倒序,如“abcd”倒序後變為“dcba”

#include "string.h"
main()
{
    char*src="hello,world";
    char* dest=NULL;
    int len=strlen(src);
    dest=(char*)malloc(len);
    char* d=dest;
    char* s=src[len];
    while(len--!=0) 
        d++=s--;
    printf("%s",dest);
    return 0;
}
答:
方法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:
#include <stdio.h>
#include <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;
}

8、-1,2,7,28,,126請問28和126中間那個數是什嗎?為什嗎?
    答案應該是4^3-1=63
    規律是n^3-1(當n為偶數0,2,4)
            n^3+1(當n為奇數1,3,5)
    答案:63

9、用兩個棧實現一個隊列的功能?要求給出演算法和思路!
    設2個棧為A,B, 一開始均為空白.

    入隊:
    將新元素push入棧A;

    出隊:
    (1)判斷棧B是否為空白;
    (2)如果不為空白,則將棧A中所有元素依次pop出並push到棧B;
    (3)將棧B的棧頂元素pop出;這樣實現的隊列入隊和出隊的平攤複雜度都還是O(1), 比上面的幾種方法要好。

10、在c語言庫函數中將一個字元轉換成整型的函數是atool()嗎,這個函數的原型是什嗎?
    函數名: atol 
    功 能: 把字串轉換成長整型數 
    用 法: long atol(const char *nptr); 
    程式例: 
    #include <stdlib.h> 
    #include <stdio.h> 
    int main(void) 
    { 
        long l; 
        char *str = "98765432";

        l = atol(lstr); 
        printf("string = %s integer = %ld\n", str, l); 
        return(0); 
    }

11、對於一個頻繁使用的短小函數,在C語言中應用什麼實現,在C++中應用什麼實現?
    c用宏定義,c++用inline

12、直接連結兩個信令點的一組鏈路稱作什麼?
    PPP點到點串連

13、接入網用的是什麼介面?

14、voip都用了那些協議?

15、軟體測試都有那些種類?
    黑盒:針對系統功能的測試    白合:測試函數功能,各函數介面

16、確定模組的功能和模組的介面是在軟體設計的那個隊段完成的?
    概要設計階段

17、enum string
    {
        x1,
        x2,
        x3=10,
        x4,
        x5,
    }x;
   問x= 0x801005,0x8010f4;

18、unsigned char *p1;
      unsigned long *p2;
      p1=(unsigned char *)0x801000;
      p2=(unsigned long *)0x810000;
      請問p1+5=  0x801005;
            p2+5=  0x801014;

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.