次の点で問題があります...コードの重要でない部分を削除したので、それほど混乱しません。他のすべてのシンボル/変数はすでに定義または初期化されています。
基本的に私がやろうとしていることはこれです:
numsalchange は、indsaldif 配列の値が 0 であるかどうかをループで判断する別のメソッドです。0 である場合は、もちろん増分変更です。
変更は後で表示されるレポート メソッドに送信されます。私はそれをいくつかの異なる方法で試しましたが、0 に等しくなる値と等しくならない値を使用しました。
変更を次のように宣言しようとしました
int change;
そして、メソッドでゼロに設定しますが、メインで初期化せずにメソッドに送信することはできません。
ゼロとして初期化され、更新された値ではなく 0 としてレポートに送信されるため、レポート メソッドに 0 として表示されているような気がします。
public static void main blah(String[] args){
int change = 0;
numsalchange (userinput, change, indsaldif);
report (userinput, oldsalary, newsal, indsaldif, change);
public static void numsalchange(String[] userinput, int change, double[] indsaldif){
for ( int i=0; i<userinput.length; i++){
if(indsaldif[i] != 0){
change++;}}}
public static void report(String[] userinput, double[] oldsalary, double[] newsal, double[] indsaldif, int change){
DecimalFormat twoDigits = new DecimalFormat("0.00");
double saldiff = 0;
for( double i : indsaldif) {
saldiff += i;
}
String toString;
StringBuilder sb = new StringBuilder(64);
sb.append("PB Incorporated Salary Report \n");
for (int i = 0; i < userinput.length; i++) {
sb.append("---------- \nEmployee:"+ userinput[i] + "\nOld Salary: $"+ twoDigits.format(oldsalary[i]) + "\nNew Salary: $" + twoDigits.format(newsal[i]) + "\nSalary Change: $" + twoDigits.format(indsaldif[i])+"\n");
//**
}
sb.append("---------- \nTotal Employee Salary Increase: $" + twoDigits.format(saldiff) + "\n# of Salary Increases: " + change);
JOptionPane.showMessageDialog(null, sb.toString());}
}