AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / user-768644

rzwitserloot's questions

Martin Hope
rzwitserloot
Asked: 2024-08-27 01:43:38 +0800 CST

Uma maneira concisa de obter o maior entre um conjunto de comparáveis

  • 6

Contexto: Java moderno (a versão mais recente; JDK23 no momento em que esta pergunta foi escrita)

Dados 2 objetos comparáveis ​​(implemento Comparable<T>, onde T é um tipo que todos compartilham), como obter o maior dos dois?

Se esta pergunta fosse sobre números inteiros, a resposta seria razoavelmente simples:

int largest = Math.max(a, b);

É um pouco irritante (mas, talvez da perspectiva dos varargs que introduzem um array recém-alocado no heap, sensato devido a questões de desempenho) que isso funcione apenas para precisamente 2 números inteiros.

Mas não há maxpara <T>. Poderia existir; seria fácil:

public static <T implements Comparable<? super T>> T max(T a, T b) {
  return a.compareTo(b) < 0 ? b : a;
}

Porém, java.lang.Mathnão contém este método; apenas maxmétodos de primitivos.

Complicações:

  • Seria bom se você pudesse ter mais do que exatamente 2 valores, por exemplo, tendo a assinatura: <T> T max(T... inputs).
  • Seria bom se, em vez de usar números naturalmente comparáveis, permitisse especificar um comparador personalizado.

Nesse sentido, eu esperava que esse método existisse em java.util.Comparator:

public default T max(T... inputs) {
  if (inputs.length == 0) throw new IllegalArgumentException("inputs is empty"); // [1]
  T out = inputs[0];
  for (int i = 1; i < inputs.length; i++) {
    T t = inputs[i];
    if (out.compareTo(t) < 0) out = t;
  }
  return out;
}

No entanto, nenhuma das classes em que se poderia esperar isso ( java.util.Comparator, java.util.Comparators, java.util.Comparable) parece ter tal método.

Verificando alguns dos meus projetos de código, tenho alguns métodos espalhados, como:

public LocalDate latest(LocalDate a, LocalDate b) {
   return a.isBefore(b) ? b : a;
}

que poderiam ser substituídos por tal método; LocalDateimplementa Comparable, portanto, se maxexistisse um método, eu poderia simplesmente ter chamado max(date1, date2).

Existe em algum lugar nas java.*bibliotecas principais? Existem planos em andamento em versões futuras do JDK para ter esse método?

Não estou pedindo bibliotecas específicas, apenas uma espécie de inventário: alguma biblioteca popular que o inclua, em termos tão genéricos quanto os trechos desta pergunta? 2


[1] Um designer pode inicialmente pensar que retornar an Optional<T>é melhor aqui; este seria o design errado. Os chamadores, praticamente sempre, passariam argumentos explícitos, garantindo assim que opcional.none literalmente não pudesse acontecer. Pela mesma razão, é um projeto de API ruim criar um método que declare o lançamento de uma exceção verificada que os documentos dizem que nunca pode ocorrer em casos de uso comum, ter uma API que retorna um opcional que nunca pode ser NONEé igualmente irritante. A exceção é, portanto, a solução correta aqui.

[2] nullo manuseio está em debate aqui. Se alguém atribuir a visão SQL de null(que nullrepresenta valores desconhecidos), então uma implementação que, por exemplo, retorne bif ais nullseria incorreta (como você sabe, entre um valor conhecido e um valor desconhecido, que o valor conhecido é aquele isso era maior?): Um NPE está correto. Mas, se alguém atribuir a visão que nullsignifica 'ausente', então NPE está errado e retornar o máximo entre os valores não nulos está correto. A questão já é bastante complexa; digamos que qualquer nulltratamento razoável seja aceitável.

java
  • 1 respostas
  • 35 Views

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Reformatar números, inserindo separadores em posições fixas

    • 6 respostas
  • Marko Smith

    Por que os conceitos do C++20 causam erros de restrição cíclica, enquanto o SFINAE antigo não?

    • 2 respostas
  • Marko Smith

    Problema com extensão desinstalada automaticamente do VScode (tema Material)

    • 2 respostas
  • Marko Smith

    Vue 3: Erro na criação "Identificador esperado, mas encontrado 'import'" [duplicado]

    • 1 respostas
  • Marko Smith

    Qual é o propósito de `enum class` com um tipo subjacente especificado, mas sem enumeradores?

    • 1 respostas
  • Marko Smith

    Como faço para corrigir um erro MODULE_NOT_FOUND para um módulo que não importei manualmente?

    • 6 respostas
  • Marko Smith

    `(expression, lvalue) = rvalue` é uma atribuição válida em C ou C++? Por que alguns compiladores aceitam/rejeitam isso?

    • 3 respostas
  • Marko Smith

    Um programa vazio que não faz nada em C++ precisa de um heap de 204 KB, mas não em C

    • 1 respostas
  • Marko Smith

    PowerBI atualmente quebrado com BigQuery: problema de driver Simba com atualização do Windows

    • 2 respostas
  • Marko Smith

    AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos

    • 1 respostas
  • Martin Hope
    Fantastic Mr Fox Somente o tipo copiável não é aceito na implementação std::vector do MSVC 2025-04-23 06:40:49 +0800 CST
  • Martin Hope
    Howard Hinnant Encontre o próximo dia da semana usando o cronógrafo 2025-04-21 08:30:25 +0800 CST
  • Martin Hope
    Fedor O inicializador de membro do construtor pode incluir a inicialização de outro membro? 2025-04-15 01:01:44 +0800 CST
  • Martin Hope
    Petr Filipský Por que os conceitos do C++20 causam erros de restrição cíclica, enquanto o SFINAE antigo não? 2025-03-23 21:39:40 +0800 CST
  • Martin Hope
    Catskul O C++20 mudou para permitir a conversão de `type(&)[N]` de matriz de limites conhecidos para `type(&)[]` de matriz de limites desconhecidos? 2025-03-04 06:57:53 +0800 CST
  • Martin Hope
    Stefan Pochmann Como/por que {2,3,10} e {x,3,10} com x=2 são ordenados de forma diferente? 2025-01-13 23:24:07 +0800 CST
  • Martin Hope
    Chad Feller O ponto e vírgula agora é opcional em condicionais bash com [[ .. ]] na versão 5.2? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench Por que um traço duplo (--) faz com que esta cláusula MariaDB seja avaliada como verdadeira? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng Por que `dict(id=1, **{'id': 2})` às vezes gera `KeyError: 'id'` em vez de um TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos 2024-03-20 03:12:31 +0800 CST

Hot tag

python javascript c++ c# java typescript sql reactjs html

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve