Сортировка буквенно-цифровых строк Java

У меня есть этот массив, хранящий суффикс некоторых URL, добавляемых пользователем:

[U2, U3, U1, U5, U8, U4, U7, U6]

Когда я делаю это:

for (Map<String, String> map : getUrlAttachments()) {
            String tmpId = map.get("id"); //it receives the U2, in the 1st iteration, then U3, then U1,...
            if (tmpId.charAt(0) == 'U') {
                tmpId.charAt(1);//2, then 3, then 1,...
                String url = map.get("url");
                String description = map.get("description");
                URLAttachment attachment;
                String cleanup = map.get("cleanup");
                if (cleanup == null && url != null && description != null) {
                    attachment = new URLAttachmentImpl();
                    attachment.setOwnerClass(FileUploadOwnerClass.Event.toString());
                    attachment.setUrl(url);
                    attachment.setDescription(description);
                    attachment.setOwnerId(auctionHeaderID);
                    attachment.setUrlAttachmentType(URLAttachmentTypeEnum.EVENT_ATTACHMENT);
                    attachment.setDateAdded(new Date());
                    urlBPO.save(attachment);

            }

Моя проблема:

Я хочу изменить этоFor&nbsp;условие путем передачи другого списка, отображающего данные, отсортированные как[U1, U2, U3, U4, U5, U6, U7, U8].

Я хотел бы, чтобы ваша помощь знала, как лучше всего это сделать.

Я думал о создании массива с перечислением идентификаторов, а затем сортировать, но я не знаю, как именно сортировать буквенно-цифровые строки в Java.