Comparable Non-Sort Object

It’s hard for me to sort objects according to its properties .

I have a list of patient objects that I want to sort by their last name, but they do not sort them at all. Can you tell me what I'm doing wrong?

Here is the code.

Patient.java

import java.util.Comparator;

public class Patient implements Comparable<Patient> {
    String fname, lname, mname, ID;

    public static class OrderByLastName implements Comparator<Patient> {

        @Override
        public int compare(Patient p1, Patient p2) {
            return p1.lname.compareTo(p2.lname);
        }
    }

    public static class OrderByID implements Comparator<Patient> {

        @Override
        public int compare(Patient p1, Patient p2) {
            return p1.ID.compareTo(p2.ID);
        }
    }

    @Override
    public int compareTo(Patient another) {
        // TODO Auto-generated method stub
        return 0;
    }
}

MainActivity.java

public class PatientList extends ActionBarActivity {

String[] newFName = {"Mark","Andy","Bryan"};
String[] newLName = {"Uy","Igy","Nator"};
String[] newMName = {"Wi","Menos","Pat"};
String[] newID = {"3","5","1"};
ArrayList<Patient> patientList;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    createPatientList();
    sortPatient(1);

}

private void createPatientList() {
    patientList = new ArrayList<Patient>();
    for (int i = 0; i < newFName.length; i++) {
        Patient patient = new Patient();
        patient.lname = newLName[i];
        patient.fname = newFName[i];
        patient.mname = newMName[i];
        patient.ID = newID[i];
        patientList.add(patient);
    }
}

private void sortPatient(int order){
    switch (order) {
        case 1:
            Collections.sort(patientList, new Patient.OrderByLastName());
            break;
        case 2:
            Collections.sort(patientList, new Patient.OrderByID());
            break;
        default:
            break;
        }
}
}
+4
source share
2 answers

As far as I can see, your code should work, and I suspect that unit test will prove it. If your problem is that you cannot see the update, then perhaps your view refresh logic is to blame.

+1
source

, java. , . ; .

Test.java:

import java.util.ArrayList;
import java.util.Collections;

public class Test {

    static String[] newFName = { "Mark", "Andy", "Bryan" };
    static String[] newLName = { "Uy", "Igy", "Nator" };
    static String[] newMName = { "Wi", "Menos", "Pat" };
    static String[] newID = { "3", "5", "1" };
    static ArrayList<Patient> patientList;

    public static void main(String[] args) {

        createPatientList();

        System.out.println("Before: ");
        for (Patient p : patientList) {
            System.out.println(p.lname);
        }

        sortPatient(1);

        System.out.println("\nAfter: ");
        for (Patient p : patientList) {
            System.out.println(p.lname);
        }
    }

    private static void createPatientList() {
        patientList = new ArrayList<Patient>();
        for (int i = 0; i < newFName.length; i++) {
            Patient patient = new Patient();
            patient.lname = newLName[i];
            patient.fname = newFName[i];
            patient.mname = newMName[i];
            patient.ID = newID[i];
            patientList.add(patient);
        }
    }

    private static void sortPatient(int order) {
        switch (order) {
        case 1:
            Collections.sort(patientList, new Patient.OrderByLastName());
            break;
        case 2:
            Collections.sort(patientList, new Patient.OrderByID());
            break;
        default:
            break;
        }
    }
}

:

screen shot

+1

Source: https://habr.com/ru/post/1543367/


All Articles