⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 nonblockingtest2.java

📁 MPI for java for Distributed Programming
💻 JAVA
字号:
package nbcomms;

import mpjdev.*;
import mpjbuf.*;
import java.util.Arrays;

public class NonBlockingTest2 {

  public static void main(String args[]) throws Exception {

    MPJDev.init(args);
    int id = MPJDev.WORLD.id();
    int DATA_SIZE = 100;    
    mpjdev.Request [] sreqs = new mpjdev.Request[8];
    mpjdev.Request [] rreqs = new mpjdev.Request[8];    
    int intArray[] = new int[DATA_SIZE];

    for (int i = 0; i < DATA_SIZE; i++) {
      intArray[i] = i + 1;
    }
    
    for (int h = 1; h < 5; h++) {
	    
      if (id == 0) {	      
        Buffer intBuffer = new Buffer( (DATA_SIZE * 4) + 8);
        intBuffer.putSectionHeader(Buffer.INT);
        intBuffer.write(intArray, 0, DATA_SIZE);
        intBuffer.commit();      
        sreqs[0] = MPJDev.WORLD.isend(intBuffer, 1, (1 + (h * 10)));
	for(int r=0 ; r<1 ; r++) {
	    sreqs[r].iwait();		
	}
	
      }
      else if (id == 1) {

        int intReadArray[] = new int[DATA_SIZE];
        for (int i = 0; i < intReadArray.length; i++) {
          intReadArray[i] = 3;
        }
        Buffer intBuffer = new Buffer( (DATA_SIZE * 4) + 8);       
        rreqs[0] = MPJDev.WORLD.irecv(intBuffer, 0, (1 + (h * 10)));        

	for(int r=0 ; r<1 ; r++) {
	    rreqs[r].iwait();		
	}

        intBuffer.commit();	
	intBuffer.getSectionHeader(Buffer.INT);
	intBuffer.read(intReadArray, 0, DATA_SIZE);

        if (Arrays.equals(intArray, intReadArray) ) {
          System.out.println(" <<<<PASSED>>>> ");
        } else {
          System.out.println(" <<<<FAILED>>>> ");        
          System.exit(0);
        }
	
      }

    } //end tests for loop ...

    Thread.currentThread().sleep(500);
    MPJDev.finish();

  }
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -