• <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>

            專(zhuān)職C++

            不能停止的腳步

              C++博客 :: 首頁(yè) :: 聯(lián)系 :: 聚合  :: 管理
              163 Posts :: 7 Stories :: 135 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(28)

            我參與的團(tuán)隊(duì)

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            翻開(kāi)高級(jí)unix編程,仔細(xì)看了一下管道,并將書(shū)中的例子修改并實(shí)現(xiàn)。
            雖然很簡(jiǎn)單,確揭示了多進(jìn)程編程的基礎(chǔ)。
            用管道非常真是非常的簡(jiǎn)單。以前只是看了,沒(méi)有實(shí)踐!

            #include <common.h>

            #define MAXLINE 256
            int main(int argc, char * argv[])
            {
                
            int fd[2]; //管道fd
                pid_t pid; //子進(jìn)程的PID
                char line[MAXLINE];

                
            if( (pipe(fd) ) < 0 ) //創(chuàng)建PID,其中fd[0]為讀管道,fd[1]為寫(xiě)管道
                {
                    cout
            <<"pipe error"<<endl;
                    exit(
            0);
                }


                
            if( (pid = fork() )<0//創(chuàng)建子進(jìn)程
                {
                    cout
            <<"fork error"<<endl; //一般是進(jìn)程過(guò)多的時(shí)候才會(huì)出錯(cuò)
                    exit(0);
                }

                
            //執(zhí)行fork后,當(dāng)前進(jìn)程會(huì)得到子進(jìn)程的pid,而子進(jìn)程得到的是0,可以通過(guò)getppid()取得父進(jìn)程
                if( pid > 0 )
                
            {
                    
            //父進(jìn)程向管道寫(xiě)數(shù)據(jù)
                    char buffer[MAXLINE];
                    close(fd[
            0]);
                    cout
            <<"input:";
                    cin.getline(buffer,MAXLINE);
                    write(fd[
            1],buffer,strlen(buffer));
                }

                
            else
                
            {
                    
            //子進(jìn)程接收數(shù)據(jù)
                    close(fd[1]);
                    
            int n = read(fd[0],line,MAXLINE);
                    line[n] 
            = 0;
                    cout
            <<"read message:"<<line<<endl;
                }


                
            return 0;
            }


            posted on 2010-12-28 22:51 冬瓜 閱讀(3540) 評(píng)論(3)  編輯 收藏 引用 所屬分類(lèi): 轉(zhuǎn)貼

            Feedback

            # re: 進(jìn)程間通信:管道 2010-12-30 12:21 dwang
            這么也看不出會(huì)用了吧  回復(fù)  更多評(píng)論
              

            # re: 進(jìn)程間通信:管道 2011-03-01 17:24 flagman
            在fork子進(jìn)程之后,子進(jìn)程似乎不會(huì)執(zhí)行下面的這個(gè)分支段;

            else
            {
            //子進(jìn)程接收數(shù)據(jù)
            close(fd[1]);
            int n = read(fd[0],line,MAXLINE);
            line[n] = 0;
            cout<<"read message:"<<line<<endl;
            }

            雖然fork()只是執(zhí)行了建立一個(gè)新的task_struct的操作,上面這代碼在同步上是不是有些問(wèn)題?  回復(fù)  更多評(píng)論
              

            # re: 進(jìn)程間通信:管道 2012-08-04 07:22 lexus
            請(qǐng)問(wèn)這里管道 的作用是什么?  回復(fù)  更多評(píng)論
              

            久久无码AV中文出轨人妻| 热久久视久久精品18| 国产日韩久久免费影院| 国产精品成人99久久久久91gav | 久久夜色精品国产亚洲| 久久久久亚洲AV无码专区网站| 亚洲乱码精品久久久久..| 99久久精品国产一区二区蜜芽| 久久亚洲熟女cc98cm| 伊人久久免费视频| 亚洲中文字幕久久精品无码喷水| 久久免费高清视频| 日日躁夜夜躁狠狠久久AV| 亚洲国产日韩欧美综合久久| 国内精品久久久久影院免费| 亚洲狠狠婷婷综合久久蜜芽| 色综合久久久久综合99| 国产一区二区三区久久| 日韩人妻无码精品久久免费一 | 日本久久久久久久久久| AV色综合久久天堂AV色综合在| 色婷婷狠狠久久综合五月| 2020最新久久久视精品爱 | 青青草国产97免久久费观看| 久久精品免费观看| 久久A级毛片免费观看| 国产偷久久久精品专区| 亚洲国产精品综合久久一线| 久久久久亚洲?V成人无码| 久久最新精品国产| 国产精品久久毛片完整版| 久久精品无码专区免费青青 | 狠狠精品干练久久久无码中文字幕| 精品国际久久久久999波多野| 欧洲人妻丰满av无码久久不卡| 99精品久久精品一区二区| 亚洲国产精品无码久久九九| 亚洲Av无码国产情品久久| 久久亚洲精品无码观看不卡| 久久性生大片免费观看性| 亚洲午夜无码久久久久小说|