青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

jake1036

2011-5-7百度實(shí)習(xí)生筆試

                  百度實(shí)習(xí)生筆試總結(jié)

試題:
 一。簡答
   1.extern“c”{是什么含義,有什么作用
   2.寫出至少兩種經(jīng)典設(shè)計(jì)模式,最好寫偽代碼
   3.TCP中time_wait什么含義,在什么情境下發(fā)生,以及它的好處和壞處
二。編程
   1.一個(gè)服務(wù)器每天定時(shí)執(zhí)行一定任務(wù)(N<1000),各任務(wù)間有一定依賴,如執(zhí)行任務(wù)A需要先執(zhí)行任務(wù)B,但無死循環(huán)。
      請?jiān)O(shè)計(jì)適當(dāng)?shù)娜蝿?wù)執(zhí)行順序。寫出算法過程,分析時(shí)間空間復(fù)雜度。
   2.統(tǒng)計(jì)一個(gè)英文文本中的句子數(shù),文本中含有大小寫字母、空格、點(diǎn)號(hào)(.)、逗號(hào)(,),一個(gè)句子的結(jié)尾必須至少是一個(gè)字母加點(diǎn)好。給出詳細(xì)代碼。
三。設(shè)計(jì)題
    服務(wù)器記錄url、訪問ip、訪問時(shí)間,服務(wù)器有100億條記錄,設(shè)計(jì)一個(gè)系統(tǒng):
   1.當(dāng)知道訪問時(shí)間(精確到分鐘)和ip,可以統(tǒng)計(jì)url的總訪問量
   2.當(dāng)知道訪問時(shí)間(精確到分鐘)和url,可以統(tǒng)計(jì)ip的總訪問量

 解答:
   1 關(guān)于extern"C"
      (1) 首先關(guān)于條件編譯
            #ifdef _cplusplus  #endif _cplusplus及發(fā)散 
            這個(gè)屬于條件編譯。比如在a.h中引用了c.h,在a.c中顯式的引入了a.h和c.h頭文件,若不添加條件編譯,就會(huì)發(fā)生錯(cuò)誤。因?yàn)榭赡苤貜?fù)引入了
            一些結(jié)構(gòu)和函數(shù)的定義。
     (2) extern關(guān)鍵字
           在一個(gè)項(xiàng)目中,必須保證函數(shù)、變量、枚舉在所有文件中保持一致,除非你定義的變量是局部的。
           ;

 

int{}

//file1.c
  int x = 1 ;
  
int foo(){doSomething here}

//file2.c
  extern int x ;
   
int foo() ;
  
int goo(return foo());


     在file1.c中定義了變量c,然后在file2.c中的變量x ,以及函數(shù)foo() 都是引用的文件file1.c中。

    extern 是c/c++語言中標(biāo)示函數(shù)和全局變量的作用范圍,該關(guān)鍵字告訴編譯器該變量或者函數(shù)可以在本模塊之外的其他模塊之中使用。
    通常在本模塊的頭文件中對本模塊提供給其余模塊的函數(shù)和變量添加extern 關(guān)鍵字。
   該關(guān)鍵字對應(yīng)的事static,表示static的變量或者函數(shù)只能在本模塊中使用。
    
  (3)"c" 關(guān)鍵字
       一個(gè)c++編寫的代碼中,可能會(huì)包哈其余語言編寫的代碼, 不同語言之間編寫的代碼互相調(diào)用是困難的,可能會(huì)在注冊變量以及變量在棧上
      的分布不同。
     為了使各個(gè)語言之間保持相同的編譯和鏈接規(guī)約,可以使用extern "C" 進(jìn)行修飾。比如 c/c++的標(biāo)準(zhǔn)函數(shù) strcpy() 
     extern "C" void strcpy(char * dest , const char * src) ;
     注意該聲明與下面的聲明不同的地方  extern  void strcpy(char * dest , const char * src) ;
     "C" 并不指的是 C語言,而指的是一種鏈接規(guī)約  ,比如Fortran、assembler 等都使用的和C一樣的編譯和鏈接規(guī)約。
     
  (4) 綜上:
       extern "c" 表示的是 在C++ 源文件中使用 該定義,使c++代碼按照c的編譯和鏈接規(guī)約,這樣在c源文件中,就可以使用C++中定義的變量
       和函數(shù)。使用在c/c++混合編程的情況下,

  (5) c 與c++互相調(diào)用
       
       c++是面向?qū)ο蟮恼Z言,為了支持函數(shù)重載等特性,c++編譯器將函數(shù)編譯如下
      

void print(int , int) ;
void print(int , float) ;

//編譯如下
_print_int_int 
_print_int_float

  c語言的編譯器不會(huì)像c++編譯器那樣,而是直接編譯為_print
 
  具體代碼如下: c++調(diào)用c
  

#ifndef _C_HEADER_H   //c語言的頭文件
#define _C_HEADER_H 
 
void print(int x) ;
#endif

#include 
<stdio.h>    //c實(shí)現(xiàn)文件
#include "cheader.h"
 
void print(int x)
 
{
      printf(
"%d\n" , x) ;
 }



#include 
"cheader.h"  //c++調(diào)用文件
#include "iostream"
 
int main()
 
{
   print(
3);
   system(
"pause") ;
   
return 0 ;    
 }





   c 調(diào)用c++代碼
  
   

#ifndef _C_PLUS_H      //c++頭文件
#define _C_PLUS_H
extern "C"  void print(int x) ;
#endif

#include 
<iostream>    //c++ 實(shí)現(xiàn)文件
#include "cplus.h"
  
void print(int x) 
  
{
    printf(
"%d\n" , x) ;   
    system(
"pause") ;  
  }


#include 
"cplus.h" //c調(diào)用文件
 int main()
 
{
   print(
3) ;    
 }



 2 設(shè)計(jì)模式解答
   (1) 工廠設(shè)計(jì)模式
          (a) 簡單工廠模式
            Simple Factory模式(又稱Static Factory模式),一個(gè)Simple Factory生產(chǎn)成品,而對客戶端隱藏產(chǎn)品產(chǎn)生的細(xì)節(jié)。實(shí)作時(shí)定義一個(gè)產(chǎn)品介面(interface),并透過特定靜態(tài)方法來建立成品。假設(shè)有一個(gè)音樂盒工廠,購買音樂盒的客人不用知道音樂盒是如何制作的,他只要知道如何播放音樂盒就可以了。
 

IMusicBox.java 
public interface IMusicBox {    public void play();}


PianoBox.java 
public class PianoBox implements IMusicBox {    public void play() {        System.out.println("撥放鋼琴音樂:)");    }}


ViolinBox.java 
public class ViolinBox implements IMusicBox {    public void play() {        System.out.println("撥放小提琴音樂^_^");    }}


MusicBoxFactory.java 
public class MusicBoxFactory {    public static IMusicBox createMusicBox(String name)                                throws InstantiationException,                                       IllegalAccessException,                                       ClassNotFoundException {        // 這邊使用的是Java的Reflection機(jī)制來產(chǎn)生實(shí)例        // 不過客戶端不用管啦        // 以后就算改變了這邊的程式,客戶端程式是不用更改的        return (IMusicBox) Class.forName(name).newInstance();    }}


MusicBoxDemo.java 
public class MusicBoxDemo {    public static void main(String[] args) throws Exception {        playMusicBox(MusicBoxFactory.createMusicBox("PianoBox"));        playMusicBox(MusicBoxFactory.createMusicBox("ViolinBox"));    }        public static void playMusicBox(IMusicBox musicBox) {        musicBox.play();    }}

 
  (2) 單例設(shè)計(jì)模式
      

public Runtime
{
  
private static Runtime currrentRuntime = new
  Runtime();
  
  
public static Runtime getRuntime()
  
{
    
return currentTime ;
  }
   

   
private RunTime() ; //注意構(gòu)造函數(shù)定義為私有

}

        注意成員變量定義為私有,而且構(gòu)造函數(shù)定義為私有。

 3 TCP 中的 time_wait 狀態(tài)
    
    (1) 擴(kuò)展 TCP建立連接的3次握手操作
       c ---------------  s
         SYN-------->
        <---------ACK-SYN----
         ----------ACK--->               
   (2) tcp關(guān)閉連接過程
       
       主動(dòng)關(guān)閉方                                              被動(dòng)關(guān)閉方
      
                           -------------FIN M ----------->
              TIN_WAIT1                                                
                         <---------------ACK-----------  
                                                                                 
             FIN_WAIT2                                                close_wait
                   
                         
                       <---------FIN    N-----------
                                                                                  LAST_ACK

                        -----------ACK ----------->
          TIME_WAIT                                               CLOSED
                                                                                    


         
           CLOSED          
  
          


      time_wait的作用:
        (1)  最后一個(gè)發(fā)送的ACK 很可能丟失,則服務(wù)器會(huì)重發(fā)一個(gè)FIN , 客戶端可以在time_wait階段再次接受。

       (2) 網(wǎng)絡(luò)上可能還有一些沒有到達(dá)的數(shù)據(jù)包,或者老的重復(fù)數(shù)據(jù)包,在該階段可以接受。



   4 接下來的那個(gè)任務(wù)題,實(shí)質(zhì)上就是為 一個(gè)拓?fù)渑判騿栴}。
   


 5 設(shè)計(jì)題解析
  

  









 

posted on 2011-05-08 21:35 kahn 閱讀(2110) 評(píng)論(1)  編輯 收藏 引用 所屬分類: 算法相關(guān)

Feedback

# re: 2011-5-7百度實(shí)習(xí)生筆試[未登錄] 2011-06-13 10:52 MU

有沒有去2011百度實(shí)習(xí)的同學(xué)啊 加群89864538  回復(fù)  更多評(píng)論   


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            午夜精品久久久久久久蜜桃app | 国产精品久久久久久久7电影| 国产精品青草综合久久久久99| 亚洲成人资源| 香蕉免费一区二区三区在线观看 | 亚洲一级黄色av| 欧美激情导航| 美乳少妇欧美精品| 亚洲第一黄色| 你懂的网址国产 欧美| 久久精品99久久香蕉国产色戒| 国产精品视频自拍| 羞羞视频在线观看欧美| 亚洲一区二区三区视频| 欧美午夜宅男影院| 亚洲欧美视频| 性欧美在线看片a免费观看| 久久久综合精品| 欧美肥婆在线| 亚洲人精品午夜在线观看| 欧美激情亚洲精品| 欧美jizz19性欧美| 亚洲人成高清| 亚洲精品永久免费精品| 欧美日韩大片一区二区三区| 一本一本久久| 亚洲性人人天天夜夜摸| 国产精品一区在线播放| 久久在线91| 欧美h视频在线| 在线观看亚洲视频| 欧美亚洲免费电影| 欧美一级欧美一级在线播放| 国内精品久久久久国产盗摄免费观看完整版| 欧美亚洲系列| 久久免费视频网| 99国产欧美久久久精品| 亚洲一区尤物| 国产在线播精品第三| 欧美激情精品久久久久久变态| 欧美日韩国产小视频在线观看| 性感少妇一区| 蜜臀av国产精品久久久久| 亚洲视频电影在线| 午夜精品免费在线| 99综合视频| 久久精品人人做人人综合| 久久成人羞羞网站| 日韩一级成人av| 欧美专区福利在线| 亚洲深夜福利在线| 久久噜噜噜精品国产亚洲综合| 亚洲伦理中文字幕| 欧美一区亚洲二区| 亚洲私人影院在线观看| 久久久精品视频成人| 一区二区日韩| 久久成人亚洲| 亚洲欧美日韩高清| 欧美黑人在线观看| 欧美中文字幕在线播放| 欧美精品二区三区四区免费看视频| 久久激情视频久久| 欧美日本在线| 欧美bbbxxxxx| 国产亚洲精品久久久久动| 日韩视频在线一区| 亚洲区第一页| 久久午夜激情| 久久人人超碰| 国产日本精品| 亚洲丝袜av一区| 一区二区毛片| 老司机成人网| 久久免费视频在线观看| 国产精品香蕉在线观看| 亚洲毛片视频| 亚洲精品日韩在线观看| 久久九九精品| 久久精品在线| 国产免费一区二区三区香蕉精| 艳妇臀荡乳欲伦亚洲一区| 亚洲理论电影网| 欧美/亚洲一区| 欧美国产精品va在线观看| 好吊色欧美一区二区三区视频| 亚洲欧美日韩另类| 欧美在线免费观看| 国产毛片一区二区| 午夜国产欧美理论在线播放| 亚洲欧美视频在线观看视频| 国产日韩欧美制服另类| 香蕉久久夜色精品国产| 国产精品日本欧美一区二区三区| 99精品欧美一区二区三区综合在线| 久久成人在线| 午夜国产精品影院在线观看| 羞羞答答国产精品www一本| 欧美手机在线| 99精品欧美一区二区三区综合在线| 免费一级欧美片在线播放| 乱人伦精品视频在线观看| 国产亚洲欧洲| 久久精品一区蜜桃臀影院| 美女久久网站| 亚洲精品在线二区| 欧美日韩不卡在线| 在线视频成人| 亚洲九九精品| 国产精品久久久久久影院8一贰佰| 亚洲美女在线一区| 亚洲欧美大片| 国产尤物精品| 欧美区一区二区三区| 一区二区三区高清不卡| 久久aⅴ乱码一区二区三区| 激情欧美日韩| 欧美国产日韩a欧美在线观看| 日韩视频中文| 久久久www成人免费毛片麻豆 | 久久久久国产精品午夜一区| 激情成人在线视频| 欧美激情视频一区二区三区免费| 99国产精品久久| 欧美在线视频网站| 91久久嫩草影院一区二区| 欧美三级资源在线| 久久成年人视频| 99国产精品久久久久久久成人热| 久久精品国产精品亚洲综合| 亚洲人成在线播放| 国产日韩一区二区三区| 欧美成人黄色小视频| 中文在线资源观看网站视频免费不卡 | 欧美日韩一区在线| 久久黄色网页| 一区二区三区精品久久久| 久热成人在线视频| 亚洲一区在线看| 亚洲激情午夜| 激情亚洲网站| 国内自拍一区| 欧美在线网站| 久久se精品一区二区| 中文在线资源观看视频网站免费不卡| 欧美在线在线| 国产精品99久久久久久有的能看 | 欧美一区二区三区免费视频| 亚洲国产欧美在线| 久久视频在线视频| 亚洲一级片在线观看| 亚洲人妖在线| 在线成人h网| 国产一区二区三区四区三区四| 国产精品jizz在线观看美国| 免费在线日韩av| 久久久一本精品99久久精品66| 亚洲女同在线| 一本一本久久a久久精品综合麻豆| 亚洲福利国产| 国产一区二区三区日韩| 久久久久欧美| 亚洲视频网站在线观看| 在线日本成人| 国产日产欧美精品| 国产精品xxxav免费视频| 免费av成人在线| 欧美在线日韩| 欧美亚洲三区| 亚洲欧美日本精品| 一本久久a久久免费精品不卡| 亚洲福利视频一区二区| 欧美77777| 嫩草影视亚洲| 免费短视频成人日韩| 久久艳片www.17c.com| 久久精品一区二区国产| 欧美中文字幕不卡| 久久精品国语| 欧美日韩一区二区三区在线看| 久久久久久高潮国产精品视| 欧美一区二区精品久久911| 一区二区激情| 一本色道久久综合狠狠躁篇怎么玩 | 久久综合九色综合久99| 久久久久国产免费免费| 欧美一区二区视频在线观看2020| 校园激情久久| 久久精品日韩欧美| 久久先锋资源| 欧美激情成人在线视频| 欧美日韩一区二区高清| 国产精品另类一区| 国产日韩精品综合网站| 国产在线欧美日韩| 亚洲区国产区| 午夜精品一区二区三区在线视 | 欧美一级艳片视频免费观看| 欧美主播一区二区三区| 免费成人av资源网|