So sánh hiệu suất của chương trình này câu trả lời của bạn một phần (a). 1,4 (a) Thực hiện các chương trình tìm kiếm tập tin đồng thời bằng cách sử dụng các mẫu khác nhau và các tập tin trên một hệ thống UNIX. So sánh các đầu ra của lệnh grep. | 94 Remote Procedure Call private static int p int x return x 4 public static void main String args The above code can be written equivalently as follows public class SRPairl private static op void p int private static op void r int private static process q int a b send p a receive r b private static void p int x send r x 4 public static void main String args The operation p has been replaced by a new version of p and a new results operation r. Note that p is now declared as having no return type . void the return value is now passed back as the parameter of r. The call to the method has been replaced by a send receive pair. The send passes the parameter to p the receive gets the result back from p. The above code works as long as only one process is invoking p. However if more than one process invokes p each needs its own local results operation. For this we can use local operations and capabilities as we did in class Model4 in Section . For example suppose q is now a family of processes each of which invokes p public class RPC2 private static op int p int private static process q int i 1 i 20 i int a b b p a private static int p int x return x 4 Equivalence to Send Receive Pairs 95 public static void main String args This code can be written equivalently as follows public class SRPair2 private static op void p int cap void int private static process q int i 1 i 20 i int a b op void r int send p a r receive r b private static void p int X cap void int r send r x 4 public static void main String args Here the operation p has been replaced by a new version the new second argument is a capability for an operation that is used to return the result. Each invoking process now declares a local operation r. Again the call to the method has been replaced by a send receive pair. A sending process passes the capability for its r to p p sends results back to that operation. The structure of the above code is very similar to what we saw earlier in the client-server .