亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
12下一頁
最近訪問板塊 發(fā)新帖
查看: 5464 | 回復(fù): 10
打印 上一主題 下一主題

如何讓子進程向父進程傳輸數(shù)據(jù) [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2006-11-21 17:32 |只看該作者 |倒序瀏覽
主進程派生200個左右的子進程,子進程處理完畢前,將數(shù)據(jù)傳給主進程,請問使用什么方法?能否給個例子?(是不是使用進程通信)

論壇徽章:
1
榮譽會員
日期:2011-11-23 16:44:17
2 [報告]
發(fā)表于 2006-11-21 17:41 |只看該作者
看network programming with perl
找一下..里面有個parent與child用PIPE傳送資料的例子
改一下就是你要的了...

論壇徽章:
0
3 [報告]
發(fā)表于 2006-11-21 18:39 |只看該作者
這種情況也就pipe最好了。parent用IO::Select把childs的寫pipe監(jiān)控起來,有數(shù)據(jù)就取出。

論壇徽章:
0
4 [報告]
發(fā)表于 2006-11-22 10:10 |只看該作者
我試了一下PIPE,主進程中我使用ARRAY存儲這些數(shù)據(jù),但我打印時,系統(tǒng)提示ARRAY中只有一個元素.系統(tǒng)把所有的數(shù)據(jù)融入一個元素中了!這是為什么啊?
還有,不知道那么多子進程共同使用一個PIPE,會不會產(chǎn)生PIPE堵塞啊?

[ 本帖最后由 chinaseen 于 2006-11-22 10:19 編輯 ]

論壇徽章:
0
5 [報告]
發(fā)表于 2006-11-22 10:17 |只看該作者
不知道使用PIPE與使用共享內(nèi)存相比,哪個的率更高?

論壇徽章:
0
6 [報告]
發(fā)表于 2006-11-22 10:27 |只看該作者
原帖由 chinaseen 于 2006-11-22 10:10 發(fā)表
我試了一下PIPE,主進程中我使用ARRAY存儲這些數(shù)據(jù),但我打印時,系統(tǒng)提示ARRAY中只有一個元素.系統(tǒng)把所有的數(shù)據(jù)融入一個元素中了!這是為什么啊?
還有,不知道那么多子進程共同使用一個PIPE,會不會產(chǎn)生PIPE堵塞啊?


不會堵塞,子進程關(guān)閉讀管道,只寫;父進程關(guān)閉寫管道,只讀。
我說了要用IO::Select把pipe監(jiān)控起來。
另外,用hash來保存數(shù)據(jù)不是更好點么?用PID=>CONTENT這種形式。

論壇徽章:
0
7 [報告]
發(fā)表于 2006-11-22 10:37 |只看該作者
謝謝仙子姐姐,我在子進程中關(guān)閉了READER,在主進程中也關(guān)閉了WRITER.
我使用ARRAY存儲,是由于將所有的子進程傳輸后,主進程要使用得到的數(shù)據(jù)進行匹配操作(grep),不管它是來自哪個子進程!所有我就沒有使用IO::select和HASH。這樣應(yīng)該也可以吧!

[ 本帖最后由 chinaseen 于 2006-11-22 10:57 編輯 ]

論壇徽章:
0
8 [報告]
發(fā)表于 2006-11-22 13:20 |只看該作者
剛才跑了一下,最后管道被寫滿了。我是使用foreach和Parallel::ForkManager每次并發(fā)50個子進程運行的。foreach后面寫的是while(<READER>)來讀取管道的內(nèi)容。怎么能防止管道寫滿了?應(yīng)該在什么時候讀呢?

論壇徽章:
0
9 [報告]
發(fā)表于 2006-11-22 17:28 |只看該作者
原帖由 chinaseen 于 2006-11-22 13:20 發(fā)表
剛才跑了一下,最后管道被寫滿了。我是使用foreach和Parallel::ForkManager每次并發(fā)50個子進程運行的。foreach后面寫的是while(<READER>)來讀取管道的內(nèi)容。怎么能防止管道寫滿了?應(yīng)該在什么時候讀呢?



  1. IO::Select
復(fù)制代碼

論壇徽章:
1
榮譽會員
日期:2011-11-23 16:44:17
10 [報告]
發(fā)表于 2006-11-22 17:31 |只看該作者
我的作法...從network programming with perl改的..


  1. # create a pipe for IPC
  2. pipe(CHILD_READ,CHILD_WRITE) or die "Can't make pipe!\n";

  3. #-- Parent Process maintain read the input of child
  4. my $IN = IO::Select->new(\*CHILD_READ);
  5. $SIG{CHLD} = \&reap_child;

  6. while(!$DONE){
  7.   if($IN->can_read){    # get a message from one of the children
  8.     my $message;
  9.     next unless sysread(CHILD_READ,$message,4096);
  10.     my @messages = split /\n/,$message;
  11.     foreach (@messages){
  12.        next unless my ($pid,$status) = /^(\d+) (.+)$/;
  13.        if($status ne 'done'){
  14.          $STATUS{$pid} = $status;
  15.        }else{
  16.          delete $STATUS{$pid};
  17.        }
  18.     }
  19.   }
  20.   print join(" ",map {"$_ => $STATUS{$_}"} keys %STATUS )."\n";
  21.   #----- do nothing,if no child alive, -----
  22.   unless(%CHILDREN){
  23.      $normal = 1;
  24.      last;
  25.   }
  26. }
  27. ##-------假如非正常結(jié)束,必須刪除所有子程序
  28. if($normal ==0){ kill_children(); exit 1;}

復(fù)制代碼
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP