JAVA 다 중 스 레 드 보너스 뺏 기 실현 예시

대체적인 사고 방식.
보너스 나 눠 주기JAVA 작업―보 너 스 를 나 누 어 주다.
보 너 스 를 빼 앗 는 것 은 스 레 드 문제 다.
사실은 비교적 간단 합 니 다.인원 수 를 설정 하고 모든 사람 이 하나의 스 레 드 를 실행 합 니 다.모든 스 레 드 는 한 번 실행 하고 보너스 가 있 으 면 뺏 습 니 다.보너스 가 없 으 면 뺏 을 수 없 기 때문에 run 함수 에서 아직 보너스 가 있 는 지 없 는 지 판단 하면 됩 니 다.
코드 구현

import java.util.Random;
import java.util.Scanner;

public class Main {
  public static void main(String[] args) {
    int person_num, red_pocket_num, sum_money;
    Scanner scanner = new Scanner(System.in);
    System.out.println("       :");
    red_pocket_num = scanner.nextInt();
    System.out.println("        ( ):");
    sum_money = scanner.nextInt();
    if(sum_money < red_pocket_num) {
      System.out.println("   ,    。");
      return;
    }
    System.out.println("          :");
    person_num = scanner.nextInt();
    myRunnable myrunnable = new myRunnable(sum_money,red_pocket_num);
    Thread []person = new Thread[person_num];
    for (int i = 0; i < person_num; i++) {
      person[i] = new Thread(myrunnable);
      person[i].setName("  "+(i+1));
      person[i].start();
    }
  }
}
class myRunnable implements Runnable{
  private int []red_pocket;
  private int num;
  private int now_num;
  public myRunnable(int money, int num) {
    this.red_pocket = new Red_Pocket(money, num).get_red_packets();
    this.num = num;
    this.now_num = num;
  }
  @Override
  public void run() {
    if(this.num>0){
      System.out.println(Thread.currentThread().getName()+"      "+(this.num-this.now_num+1)+" : "+red_pocket[--this.now_num]+" ");
    }
    else{
      System.out.println(Thread.currentThread().getName()+"     。");
    }
  }
}
class Red_Pocket{
  private long seed;
  private int money;
  private int num;
  public int[] get_red_packets() {
    if(this.money < this.num) return new int[0];
    Random random = new Random(this.seed);
    this.seed = random.nextLong();
    int[] res = new int[this.num];
    double[] temp = new double[this.num];
    double sum = 0;
    int sum2 = 0;
    for (int i = 0; i < this.num; i++) {
      temp[i] = random.nextDouble();
      sum += temp[i];
    }
    for (int i = 0; i < this.num; i++) {
      res[i] = 1 + (int)(temp[i] / sum * (this.money - this.num));
      sum2 += res[i];
    }
    res[random.nextInt(this.num)] += this.money - sum2;
    return res;
  }
  private void init() {
    this.seed = new Random(System.currentTimeMillis()).nextLong();
  }
  public Red_Pocket(int money,int num) {
    init();
    this.money = money;
    this.num = num;
  }
}

JAVA 다 중 스 레 드 보너스 쟁탈 의 실현 예시 에 관 한 이 글 은 여기까지 소개 되 었 습 니 다.더 많은 JAVA 다 중 스 레 드 보너스 쟁탈 내용 은 우리 의 이전 글 을 검색 하거나 아래 의 관련 글 을 계속 조회 하 시기 바 랍 니 다.앞으로 많은 응원 바 랍 니 다!

좋은 웹페이지 즐겨찾기