具體看你的職位了 不同職位面試C語言上肯定不一樣。 如果是做上層的那么QTMFC或者C++相關(guān)的問的會(huì)多一些 如果是做底層的那么與硬件相關(guān)的會(huì)問的多 不管什么職位,數(shù)據(jù)結(jié)構(gòu)基本算法什么的必須有 難易程度一樣是根據(jù)職位來的。
以下是c語言新手常見問題
1、程序畫面一閃而過
#includeint main(void){ int iSignal; /*定義變量表示信號(hào)燈的狀態(tài)*/ printf("the Red Light is 0,the Green Light is 1
"); /*輸出提示信息*/ scanf("%d",&iSignal); /*輸入iSignal變量*/ if(iSignal==1) /*使用if語句進(jìn)行判斷*/ { printf("the Light is green,cars can run
"); /*判斷結(jié)果為真時(shí)輸出*/ } if(iSignal==0) /*使用if語句進(jìn)行判斷*/ { printf("the Light is red,cars can't run
"); /*判斷結(jié)果為真時(shí)輸出*/ } return 0;}
解析:在XP以上的系統(tǒng)用win-tc,dev-cpp等IDE編譯運(yùn)行此程序時(shí),無論輸入什么數(shù)字,結(jié)果都是一閃而過,因?yàn)槌绦驁?zhí)行完語句后就直接退出了。
解決方案:這里有幾個(gè)辦法:
(1):在程序開頭加上#include,然后在程序末尾加上system("pause");
此方法僅適用于MS-DOS,windows,不適用于*nix等系統(tǒng)
(2):在需要暫停的地方加入一個(gè)或兩個(gè)get);
這種方法,實(shí)質(zhì)上并不是暫停程序,而是讓程序等待用戶輸入若干個(gè)回車。但是效果和暫停是相同的。
(3):在程序開頭加上#include,在需要暫停的地方加入一個(gè)getch();,原理和上一種差不多。在win-tc里用得比較多。
2、if,for,while的判斷后直接跟;
例如:
#includeint main(void){ int a; scanf("%d",&a); if (a == 123);////錯(cuò)誤,if(a == 123)后面不應(yīng)加上;,而應(yīng)該緊跟著 ////{ printf();}代碼 { printf("ccc"); } else { printf("ddd"); } get); return 0;}#includeint main(void){ int n,i; printf("please input a number>2:"); scanf("%d",&n); for(i=2;i { if(n%i==0) break; } if(i printf("%d not a sushu
",n); else printf("%d is a sushu
",n); return 0;}
解析&解決方案:見注釋
3、漏頭文件,main函數(shù)格式不規(guī)范
例如:
main(){ int a; scanf("%d",&a); printf("input %d", a);}
解析:這段程序沒有帶上頭文件stdio.h。即漏寫了#include 。如果僅有scanf,printf函數(shù)的話,stdio.h是可以省略并可以正確運(yùn)行的,但是這是非常不好的習(xí)慣。而main()這種寫法,C89標(biāo)準(zhǔn)勉強(qiáng)充許這種形式,C99標(biāo)準(zhǔn)是不允許的。
而void main(),至今仍未有任何標(biāo)準(zhǔn)考慮接受它。但是有些編譯器的確允許。當(dāng)然,這種寫法廣為流行,應(yīng)該和老譚的書關(guān)系非常大。
解決方案:用到的頭文件應(yīng)該用include包含進(jìn)去。main()函數(shù)應(yīng)該寫成int main(void)這種形式,在main()函數(shù)尾部加上return 0;
即
#includeint main(void){ int a; scanf("%d",&a); printf("input %d", a); return 0;}
4、scanf格式控制誤用
例如:
#includeint main(void){ float a,b,c; printf("shuru 3 ge xi shu :"); scanf("%f,%f,%f",&a,&b,&c); printf("he shi %f",a + b + c); return 0;}
解析: scanf()函數(shù)允許把普通字符放在格式字符串中。除了空格字符之外的普通字符一定要與輸入串準(zhǔn)確匹配。否則,例如上面的程序,那么scanf()將其解釋成,將鍵入一個(gè)數(shù)字,鍵入一個(gè)逗號(hào),然后再鍵入一個(gè)數(shù)字,再鍵入一個(gè)逗號(hào),最后再鍵入一個(gè)數(shù)學(xué)。也就是說必須像這樣輸入:2.3,5.1,3.8。如果不能精確匹配,則scanf()讀取將失敗。
作為編寫這個(gè)程序的人,你可以按照這個(gè)格式輸入,但是用戶則不知應(yīng)該以何種格式輸入。所以應(yīng)該改為scanf("%f%f%f",&a,&b,&c);
解決方案: scanf一行見解析。
5、scanf參數(shù)錯(cuò)誤
例如:
#includeint main(void){ char str[80]; printf("Please enter your first name"); scanf("%s", &str); printf("Hello %s", str); return 0;}
解析:scanf()中,讀取int, long, float, double, char等類型的數(shù)據(jù),是需要在第n(n>=2)個(gè)參數(shù)里加上&的,因?yàn)閟canf()函數(shù)里,第n(n>=2)個(gè)參數(shù)是變量的地址,而不是變量本身:例如定義int num;則scnaf("%d", &num);
而讀取字符串是不需要加上&,因?yàn)樽址淖兞棵旧砭痛砹说刂?。所以例子中?yīng)為scanf("%s", str);同時(shí),這條規(guī)則對(duì)于結(jié)構(gòu)體內(nèi)的變量的也適用,即
struct foo {char ch;char str[80];int num}data;
那么應(yīng)該是
scanf("%c%s%d", &data.ch, data.str, &data.num);
解決方案:見解析
6、數(shù)據(jù)類型混淆
例如:
#includeint main(void){ int a; double b=1; for(a=1;a<=6;aA++) b*=A; printf("%ld",b);}
解析:定義b為雙精度浮點(diǎn)型,而輸出使用%ld即長(zhǎng)整型,數(shù)據(jù)類型不一致,輸出為0.PS:老譚的書講到用TC調(diào)試那一節(jié)舉的例子貌似就是int a; 后面寫到printf("%f",a);產(chǎn)生錯(cuò)誤的。
解決方案:把b定義為長(zhǎng)整型long,即long b = 1;(其實(shí)這里還涉及到隱式轉(zhuǎn)換,所以,更為正確的方法是把a(bǔ)也定義為長(zhǎng)整型)
7、C語言中的“除法”
例如:
#includeint main(void){ printf("請(qǐng)輸入一個(gè)華氏溫度
"); float a,c; scanf("%f",a); c=5/9*(a-32); printf("攝氏溫度為%4.2f",c); return 0;}
解析: C語言中,兩個(gè)整型數(shù)相除,如果不能除盡,那么小數(shù)部分會(huì)直接被丟棄,即“截尾”。因此5/9的結(jié)果是0.
解決方案:應(yīng)該使用類型轉(zhuǎn)換,或者明確相除的兩數(shù)的類型
c=(float)5/9*(a-32);
c=5.0/9*(a-32);
c=5.0/9.0*(a-32);
8、混合輸入數(shù)字和字符的杯具
#includeint main(void){ char ch; int num, i; printf("Enter a character and a integer:
"); while((ch = get)) != '
') { scanf("%d", &num); for(i = 0; i < num; ++i) putch); put'
'); printf("Enter an another pair.Empty line to quit"); } return 0;}
解析:這段程序表面看起來沒有什么問題,但是,實(shí)際運(yùn)行一遍的,就會(huì)發(fā)現(xiàn),只輸入了一組數(shù)據(jù),程序就退出了。
在開始的時(shí)候,程序運(yùn)行良好,例如輸入 a 2,程序就會(huì)打印出aa。但是,程序還沒響應(yīng)第二次輸入就退出了。
問題就出在換行符,這次是緊跟在第一個(gè)輸入的2后面的那個(gè)換行符。scanf()函數(shù)將該換行符留在輸入隊(duì)列中,而get)并不跳過換行符。所以在循環(huán)的下一個(gè)周期,get)讀取了第一次輸入時(shí)的換行符,而換行符正是終止循環(huán)的條件。
解決方案:吃掉輸入流中的回車即可
在while循環(huán)最后,加上以下語句
while (get) != '
') continue;
也可以加上fflush(stdin);刷新輸入流。
9、i++,i++;的糾結(jié)
例:
#include int main(void){ int i = 5; printf("%d %d", i++, i++); return 0;}
解析:這個(gè)問題,在實(shí)際編程應(yīng)該是沒有人會(huì)這么寫的,可還是有很多初學(xué)者糾結(jié)于此。在編程這個(gè)領(lǐng)域里,很多時(shí)候,實(shí)踐是最好的老師。對(duì)于代碼有疑問,那么上機(jī)敲一遍,編譯運(yùn)行一遍是很好的方法。但是,在i++,i++這個(gè)方面,即使編譯運(yùn)行了這個(gè)程序,也不一定會(huì)有正確的結(jié)果。用VC,TC,gcc編譯運(yùn)行后的結(jié)果不一定相同。或者從某個(gè)角度來說,這里結(jié)果的正確與否其實(shí)并不重要了。
printf("%d %d", i++, i++);這一個(gè)語句,其中的i++,i++是未指定行為。即C語言的標(biāo)準(zhǔn)并沒有指定這運(yùn)算是以何種順序進(jìn)行的。如果用gcc編譯加上-Wall選項(xiàng),那么會(huì)有warning:
gcc 2_1.c -o 2_1 -g -Wall2_1.c: 在函數(shù)‘main’中:2_1.c:6:24: 警告:‘i’上的運(yùn)算結(jié)果可能是未定義的
因此,要解決這個(gè)問題,最好的方法就是不要在程序中寫這樣的代碼。
解決方案:見上。
10、60<=grade<=70
例:
if (60 <= grade <= 70) printf("及格");else if(70 <= grade <= 85) printf("良好");
解析:在數(shù)學(xué)中,60<=grade<=70這種表達(dá)是成立的,但是在C語言中,并沒有這種表達(dá)。
解決方案:應(yīng)該改寫為
if ((60 <= grade) && (grade <= 70)) printf("及格");else ...
11、switch接受什么值?
例:
#include int main(void){ double choice; scanf("%lf", &choice); switch(choice){ case 1.0 : printf("1.0"); break; case 2.0 : printf("2.0"); break; default : printf("It's not 1.0 or 2.0"); } return 0;}
解析:這種問題同樣是不會(huì)出現(xiàn)在實(shí)際的編程當(dāng)中。但是一些C語言題目可能會(huì)這么出。switch()接受的是整數(shù):整型或者字符型。所以,浮點(diǎn)型,字符串等類型是不被switch()接受的。
解決方案:無他……
12、== =的困惑
例:
void count(void);/*計(jì)數(shù)器函數(shù)*/void show_count(void);/*報(bào)告計(jì)數(shù)結(jié)果*/int main(void){ puts("Please enter some letters:(# to end)"); count(); show_count(); puts("Thank you for using this program made by HerBal_Tea!"); system("pause"); return 0;}void count(void){ while ((ch = get)) != STOP) { if (ch = SPACE) { sp_count++; continue; } if (ch = ENTER) { n_count++; continue; } other_count++; }/*end of while ((ch = get)) != '#')*/}void show_count(void){ puts("The number of
space enter other"); printf("%5d%6d%6d
", sp_count, n_count, other_count);}
解析:話說我自己也犯了這個(gè)錯(cuò)。在數(shù)學(xué)中,=表示相等,而在很多編程語言中,=表示賦值,==才表示相等。思維慣性導(dǎo)致錯(cuò)誤。而且這個(gè)錯(cuò)誤C編譯器既不會(huì)報(bào)錯(cuò)也不會(huì)警告。出錯(cuò)了檢查起來非常難。
我看了不下二十遍調(diào)試的值監(jiān)視都找不到,最后還是一行一行源代碼看,才知道是這個(gè)問題。在C語言四書五經(jīng)中的 c traps and pitfalls 和 expert c programming都提到過這個(gè)問題。
解決方案:無他,唯細(xì)心。
13、溢出問題
例:求斐波那契數(shù)列的前n項(xiàng)
#include #define N 100int main(void){ int fib[N]; int i; fib[0] = fib[1] = 1; printf("%d %d ", fib[0], fib[1]); for (i = 2; i < N; ++i) { fib[i] = fib[i - 1] + fib[i - 2]; printf("%d ", fib[i]); } return 0;}
解析:在數(shù)學(xué)的概念中,整數(shù)、小數(shù)都是無限的,但是計(jì)算機(jī)中,即使是long long int或者double類型都是有一定限度的,超過限度就會(huì)溢出。
即是,假設(shè)一個(gè)指針式體重秤最大量程為120KG,那么一個(gè)體重130KG的人站上去,那么指針會(huì)指向10KG的刻度處。溢出同理。
而C語言,編譯器是不會(huì)對(duì)溢出進(jìn)行檢查或者處理的。因此在編程中,應(yīng)該自己估算一下數(shù)的大小,以選用合適的數(shù)據(jù)類型來表示數(shù)據(jù)。
PS:由于TC編譯出的程序是16位的,所以int也是16位,很容易就會(huì)溢出。
解決方案:一方面是使用合適的數(shù)據(jù)類型,比如long ,long long 或者double。另一方面是,如果數(shù)特別大,連unsigned long long int或者連double都表示不了的時(shí)候,那么就用數(shù)組吧。不過定義數(shù)組的加減法還算好,但是定義乘除法就不是那么簡(jiǎn)單了。
所以推薦新人使用第一種方法。第二種方法,可以考慮自己編個(gè)小程序?qū)崿F(xiàn)一下。
14、四舍五入?
例:要求將輸入的數(shù)按指定精度四舍五入輸出
#include int main(void){ double a = 158.385427; printf("%.2lf", a); return 0;}
解析: C語言中,printf("%.2lf", num);是直接截?cái)嘀列?shù)點(diǎn)后兩位,并非四舍五入而是類似于趨零截尾。
解決方案:如下
//四舍五入顯示數(shù)字,精確由用戶輸入//可辨別正負(fù) #include#include#includeint main(void){ int width; double a = 158.385427; puts("Enter the width"); scanf("%d",&width); if(a>0.0) a = (int)(a*pow(10,width) + 0.5)/pow(10,width); else a = (int)(a*pow(10,width) - 0.5)/pow(10,width); printf("The result is %.*lf
",width,a); system("pause"); return 0;}
15、函數(shù)的返回值
例:
#includedouble salary();/*計(jì)算工資稅的函數(shù)*/void main(){ int choice; char want0; double result; while(1) { printf("歡迎使用個(gè)人所得稅計(jì)算器
"); printf("
"); printf("1.工資、薪金所得稅計(jì)算
"); printf("
"); printf("請(qǐng)輸入需要計(jì)算的稅收項(xiàng)目序號(hào):"); scanf("%d", &choice); if(choice==1) { salary(); printf("%lf", result); }double salary(){ double sal, result; printf("請(qǐng)輸入您的薪水:"); scanf("%lf", &sal); if(sal<=3000) result="sal;" sal="">3000&&sal<=4500) result="sal*0.05;" sal="">4500&&sal<=7500) result="sal*0.1-75;" sal="">7500&&sal<=12000) result="sal*0.2-525;" sal="">12000&&sal<=38000) result="sal*0.25-975;" sal="">38000&&sal<=58000) result="sal*0.3-2725;" sal="">58000&&sal<=83000) result="sal*0.35-5475;" sal="">83000) { result=sal*0.45-13475; } return result;}
解析:這個(gè)問題簡(jiǎn)單來說是,用戶定義函數(shù)并未返回計(jì)算所得數(shù)值。往深的來說是關(guān)于存儲(chǔ)類、鏈接,即變量的作用域、鏈接、存儲(chǔ)時(shí)期的問題。
解決方案:
/* * main.c * * Created on: 2011-6-11 * Author: ice */#includedouble salary();/*計(jì)算工資稅的函數(shù)*/int main(void){ int choice;// char want0;////這個(gè)want0變量沒有使用 double result; while(1) { printf("歡迎使用個(gè)人所得稅計(jì)算器
"); printf("
"); printf("1.工資、薪金所得稅計(jì)算
"); printf("
"); printf("請(qǐng)輸入需要計(jì)算的稅收項(xiàng)目序號(hào):"); scanf("%d", &choice); if(choice==1) { result = salary();//要有一個(gè)值接受返回值才可以 printf("%lf", result); } }}double salary(){ double sal, result; printf("請(qǐng)輸入您的薪水:"); scanf("%lf", &sal); if(sal<=3000) result="sal;" sal="">3000&&sal<=4500) result="sal*0.05;" sal="">4500&&sal<=7500) result="sal*0.1-75;" sal="">7500&&sal<=12000) result="sal*0.2-525;" sal="">12000&&sal<=38000) result="sal*0.25-975;" sal="">38000&&sal<=58000) result="sal*0.3-2725;" sal="">58000&&sal<=83000) result="sal*0.35-5475;" sal="">83000) { result=sal*0.45-13475; } return result;}
1、分類:一般錯(cuò)誤分為兩種情況,語法錯(cuò)誤和語義錯(cuò)誤,語法錯(cuò)誤通常編譯器都會(huì)報(bào)錯(cuò),而語義錯(cuò)誤,對(duì)于自由度較大的C語言,編譯器是無法檢測(cè)到的,這就加大了改錯(cuò)的難度。
2、語法錯(cuò)誤:在上圖中,第一,使用了圓括號(hào)而不是花括號(hào)包圍函數(shù)體;第二,聲明語句錯(cuò)誤,應(yīng)為“int n; int n2; int n3;”。這些編譯器通常都會(huì)報(bào)錯(cuò),也容易改正。
3、語義錯(cuò)誤:語義錯(cuò)誤就是意思上的錯(cuò)誤。正確遵循了C語言的規(guī)則,但結(jié)果不正確的時(shí)候,那就是犯了語義錯(cuò)誤。這類錯(cuò)誤編譯器不會(huì)報(bào)錯(cuò),需要自己找出。像圖中原本是希望n3代表n的三次方,但代碼把它設(shè)置成了n的4次方。
Java 最常見的 208 道面試題:第一模塊答案
Java 最常見的 208 道面試題:第二模塊答案
Java 最常見的 208 道面試題:第三模塊答案
Java 最常見的 208 道面試題:第四模塊和第五模塊答案
Java 最常見的 208 道面試題:第六模塊答案
Java 最常見的 208 道面試題:第七模塊答案
Java 最常見的 208 道面試題:第八模塊答案
Java 最常見的 208 道面試題:第九模塊和第十模塊答案
Java 最常見的 208 道面試題:第十一模塊答案
Java 最常見的 208 道面試題:第十二模塊答案
Java 最常見的 208 道面試題:第十三模塊答案
Java 最常見的 208 道面試題:第十四模塊答案
Java 最常見的 208 道面試題:第十五模塊答案
Java 最常見的 208 道面試題:第十六模塊答案
Java 最常見的 208 道面試題:第十七模塊答案
Java 最常見的 208 道面試題:第十八模塊答案
Java 最常見的 208 道面試題:第十九模塊答案
京東運(yùn)營(yíng)最常見的面試題主要就是問你一些運(yùn)營(yíng)的相關(guān)基礎(chǔ)知識(shí),也就是運(yùn)營(yíng)的一些管理方面的經(jīng)驗(yàn),再有就是問你遇到一些緊急的情況,你打算怎么處理?應(yīng)該如何解決一些突發(fā)的事情。同時(shí)還要問清楚你對(duì)運(yùn)營(yíng)如何改進(jìn)措施的一些相應(yīng)的觀點(diǎn)和看法以及有什么具體的措施。
首先,問問面向過程與面向?qū)ο蟮膮^(qū)別
一般面試C++的面試者都能回答大概,面試的技巧由淺入深,根據(jù)面試者的回答再引導(dǎo)著考察面向?qū)ο蟮南旅娴膬?nèi)容。
然后,可以考察C相關(guān)知識(shí)
C語言基礎(chǔ)還是很重要的,考考概念類的const、static、指針、棧、鏈表、排序算法等很體現(xiàn)基本功的問題。
繼續(xù),考察C++相關(guān)知識(shí)
構(gòu)造與析構(gòu)函數(shù),虛函數(shù),函數(shù)重載,類的繼承多態(tài),內(nèi)存模型等。
最后,項(xiàng)目相關(guān)的問題
若面試者做過大型項(xiàng)目或者招聘需求相關(guān)的項(xiàng)目,可以做適當(dāng)加分。然后根據(jù)項(xiàng)目側(cè)重點(diǎn),問問項(xiàng)目會(huì)用到的知識(shí),比如進(jìn)程間通訊,通訊協(xié)議,通訊報(bào)文與文件處理之類的。
編程能力很重要,編程習(xí)慣更不容忽視
一場(chǎng)面試,時(shí)間有限,肯定不能把所有知識(shí)點(diǎn)都考到,要詳細(xì)的考察面試者的各項(xiàng)能力可以增加一場(chǎng)筆試。筆試的編程題必不可少,除了考察編程能力之外,還可以看出一個(gè)人的代碼習(xí)慣與代碼風(fēng)格。代碼習(xí)慣不好的面試者,需要慎重考慮。
另外,招聘還是要看多方面的看這個(gè)人是否合適。技術(shù)能力與項(xiàng)目經(jīng)驗(yàn)是一方面,性格、價(jià)值觀與企業(yè)文化的融合度,個(gè)人問題等也是決定因素。
1、 visual c++6.0 (win8系統(tǒng)下不好用,C/C++)-Microsoft Visual C++ ;
2、 visual studio (2005、2008、2010、2012、2013)- Microsoft Visual Studio ;
3、 win-tc非常方便:不騙你,2000/XP/7都可以用 ;
4、 Code::Blocks(win7、8都可以用);
5、 Turb C(只能編譯C語言) ;
6、 gcc (GNU編譯器套件) ;
7、 DEV C++;
8、 C-Free;
9、 Borland C++、WaTCom C++、Borland C++ Builder、GNU DJGPP C++、Lccwin32 C Compiler3.1、High C、My Tc等,由于C語言比較成熟,所以編程環(huán)境很多;
10、還常用souceinsight ,在工作中還用Labwindows編程,直接調(diào)試運(yùn)行,不過那是有工程背景,有工作經(jīng)驗(yàn)的技術(shù)人員用的。
常見錯(cuò)誤有if語句后面直接加分號(hào),語法沒有錯(cuò),但是if語句的執(zhí)行語句為空語句,邏輯上沒有達(dá)到分支結(jié)構(gòu)的要求,程序的運(yùn)行結(jié)果和設(shè)計(jì)預(yù)期的有差異,還有就是if語句的執(zhí)行語句是多條語句,要用大括號(hào)包含起來,else要與if配套使用,if和else之間不能有其他語句,也就是如果你需要用else語句,必須在if語句的執(zhí)行后就用else語句,中間不能執(zhí)行其他語句,最后就是if語句中的條件判斷非零為真,在判斷比較關(guān)系運(yùn)算符==容易寫成賦值運(yùn)算符=,避免的方法就是常量寫左邊,變量寫右邊,比如:if(0==a),判斷當(dāng)a等于0時(shí)條件成立,如果不小心寫成if(0=a),編譯器會(huì)報(bào)錯(cuò),而if(a=0),編譯器不會(huì)報(bào)錯(cuò),條件永遠(yuǎn)為假,if語句永遠(yuǎn)不執(zhí)行
1.Dubbo的工作流程是什么?
答:Dubbo的工作流程包括:provider向注冊(cè)中心去注冊(cè)自己為一個(gè)服務(wù),consumer去注冊(cè)中心訂閱服務(wù),注冊(cè)中心會(huì)通知consumer注冊(cè)好的服務(wù),consumer會(huì)將provider的地址等信息拉取到本地緩存,consumer去調(diào)用provider,consumer和provider都異步的通知監(jiān)控中心。
2.Dubbo的通信原理是什么?
答:Dubbo底層使用hessian2進(jìn)行二進(jìn)制序列化進(jìn)行遠(yuǎn)程調(diào)用,Dubbo底層使用Netty框架進(jìn)行異步通信。
3.Dubbo負(fù)載均衡策略有哪些?
答:Dubbo負(fù)載均衡策略包括:random loadbalance、roundrobin loadbalance、leastactive loadbalance、consistanthash loadbalance等。
4.ZooKeeper是什么?有什么作用?
答:ZooKeeper是一個(gè)分布式協(xié)調(diào)服務(wù),可以用于分布式應(yīng)用程序的協(xié)調(diào)和管理。它提供了一個(gè)分布式的、開放的、可靠的數(shù)據(jù)存儲(chǔ),用于存儲(chǔ)和管理分布式應(yīng)用程序的配置信息、命名服務(wù)、狀態(tài)信息等。
5.ZooKeeper的特點(diǎn)是什么?
答:ZooKeeper的特點(diǎn)包括:高可用性、高性能、數(shù)據(jù)一致性、順序訪問、可靠性、容錯(cuò)性等。
6.ZooKeeper的工作原理是什么?
答:ZooKeeper的工作原理是基于ZAB協(xié)議,它將數(shù)據(jù)存儲(chǔ)在內(nèi)存中,并將數(shù)據(jù)同步到所有的ZooKeeper服務(wù)器上,保證數(shù)據(jù)的一致性。ZooKeeper使用了一種基于觀察者模式的機(jī)制,當(dāng)數(shù)據(jù)發(fā)生變化時(shí),會(huì)通知所有的觀察者。
7.ZooKeeper的節(jié)點(diǎn)類型有哪些?
答:ZooKeeper的節(jié)點(diǎn)類型包括:持久節(jié)點(diǎn)、臨時(shí)節(jié)點(diǎn)、持久順序節(jié)點(diǎn)、臨時(shí)順序節(jié)點(diǎn)。
8.ZooKeeper如何保證數(shù)據(jù)的一致性?
答:ZooKeeper使用了ZAB協(xié)議來保證數(shù)據(jù)的一致性,它將數(shù)據(jù)存儲(chǔ)在內(nèi)存中,并將數(shù)據(jù)同步到所有的ZooKeeper服務(wù)器上,保證數(shù)據(jù)的一致性。
以下是 Redis 常見的八道面試題:
Redis 支持的數(shù)據(jù)結(jié)構(gòu)有哪些?
Redis 是如何實(shí)現(xiàn)持久化的?
Redis 如何實(shí)現(xiàn)分布式鎖?
Redis 如何處理并發(fā)請(qǐng)求?
Redis 的過期鍵的刪除策略是什么?
Redis 的主從同步原理是什么?
Redis 如何實(shí)現(xiàn)高可用?
Redis 的內(nèi)存淘汰策略有哪些?
這些問題涵蓋了 Redis 的基本概念、原理、應(yīng)用和優(yōu)化等方面,是 Redis 面試中經(jīng)常出現(xiàn)的問題。