[ 
https://issues.apache.org/jira/browse/ARTEMIS-5539?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Justin Bertram updated ARTEMIS-5539:
------------------------------------
    Description: 
There are a lot of implementations of {{hashCode}} like this:
{code:java}
   @Override
   public int hashCode() {
      int result = super.hashCode();
      result = 31 * result + (strConnectorClassName != null ? 
strConnectorClassName.hashCode() : 0);
      result = 31 * result + (strConnectionParameters != null ? 
strConnectionParameters.hashCode() : 0);
      result = 31 * result + (ra != null ? ra.hashCode() : 0);
      result = 31 * result + (connectionFactoryLookup != null ? 
connectionFactoryLookup.hashCode() : 0);
      result = 31 * result + (destination != null ? destination.hashCode() : 0);
      result = 31 * result + (destinationType != null ? 
destinationType.hashCode() : 0);
      result = 31 * result + (messageSelector != null ? 
messageSelector.hashCode() : 0);
      result = 31 * result + acknowledgeMode;
      result = 31 * result + (subscriptionDurability ? 1 : 0);
      result = 31 * result + (subscriptionName != null ? 
subscriptionName.hashCode() : 0);
      result = 31 * result + (shareSubscriptions != null && shareSubscriptions 
? 1 : 0);
      result = 31 * result + (user != null ? user.hashCode() : 0);
      result = 31 * result + (password != null ? password.hashCode() : 0);
      result = 31 * result + (maxSession != null ? maxSession.hashCode() : 0);
      result = 31 * result + (singleConnection != null ? 
singleConnection.hashCode() : 0);
      result = 31 * result + (transactionTimeout != null ? 
transactionTimeout.hashCode() : 0);
      result = 31 * result + (useJNDI != null ? useJNDI.hashCode() : 0);
      result = 31 * result + (jndiParams != null ? jndiParams.hashCode() : 0);
      result = 31 * result + (parsedJndiParams != null ? 
parsedJndiParams.hashCode() : 0);
      result = 31 * result + (localTx != null ? localTx.hashCode() : 0);
      result = 31 * result + (rebalanceConnections != null ? 
rebalanceConnections.hashCode() : 0);
      result = 31 * result + (setupAttempts != null ? setupAttempts.hashCode() 
: 0);
      result = 31 * result + (setupInterval != null ? setupInterval.hashCode() 
: 0);
      result = 31 * result + (queuePrefix != null ? queuePrefix.hashCode() : 0);
      result = 31 * result + (topicPrefix != null ? topicPrefix.hashCode() : 0);
      return result;
   }{code}
This could be simplified using {{Objects.hash}}, e.g.:
{code:java}
   @Override
   public int hashCode() {
      return Objects.hash(super.hashCode(), strConnectorClassName, 
strConnectionParameters, ra, connectionFactoryLookup,
                          destination, destinationType, messageSelector, 
acknowledgeMode, subscriptionDurability,
                          subscriptionName, shareSubscriptions, user, password, 
maxSession, singleConnection,
                          transactionTimeout, useJNDI, jndiParams, 
parsedJndiParams, localTx, rebalanceConnections,
                          setupAttempts, setupInterval, queuePrefix, 
topicPrefix);
   }{code}
We already use {{Objects.hash}} in many places. Using it consistently will make 
the code simpler.

  was:
There are a lot of implementations of {{hashCode}} like this:
{code:java}
   @Override
   public int hashCode() {
      int result = super.hashCode();
      result = 31 * result + (strConnectorClassName != null ? 
strConnectorClassName.hashCode() : 0);
      result = 31 * result + (strConnectionParameters != null ? 
strConnectionParameters.hashCode() : 0);
      result = 31 * result + (ra != null ? ra.hashCode() : 0);
      result = 31 * result + (connectionFactoryLookup != null ? 
connectionFactoryLookup.hashCode() : 0);
      result = 31 * result + (destination != null ? destination.hashCode() : 0);
      result = 31 * result + (destinationType != null ? 
destinationType.hashCode() : 0);
      result = 31 * result + (messageSelector != null ? 
messageSelector.hashCode() : 0);
      result = 31 * result + acknowledgeMode;
      result = 31 * result + (subscriptionDurability ? 1 : 0);
      result = 31 * result + (subscriptionName != null ? 
subscriptionName.hashCode() : 0);
      result = 31 * result + (shareSubscriptions != null && shareSubscriptions 
? 1 : 0);
      result = 31 * result + (user != null ? user.hashCode() : 0);
      result = 31 * result + (password != null ? password.hashCode() : 0);
      result = 31 * result + (maxSession != null ? maxSession.hashCode() : 0);
      result = 31 * result + (singleConnection != null ? 
singleConnection.hashCode() : 0);
      result = 31 * result + (transactionTimeout != null ? 
transactionTimeout.hashCode() : 0);
      result = 31 * result + (useJNDI != null ? useJNDI.hashCode() : 0);
      result = 31 * result + (jndiParams != null ? jndiParams.hashCode() : 0);
      result = 31 * result + (parsedJndiParams != null ? 
parsedJndiParams.hashCode() : 0);
      result = 31 * result + (localTx != null ? localTx.hashCode() : 0);
      result = 31 * result + (rebalanceConnections != null ? 
rebalanceConnections.hashCode() : 0);
      result = 31 * result + (setupAttempts != null ? setupAttempts.hashCode() 
: 0);
      result = 31 * result + (setupInterval != null ? setupInterval.hashCode() 
: 0);
      result = 31 * result + (queuePrefix != null ? queuePrefix.hashCode() : 0);
      result = 31 * result + (topicPrefix != null ? topicPrefix.hashCode() : 0);
      return result;
   }{code}
This could be simplified using {{Objects.hash}}, e.g.:
{code:java}
   @Override
   public int hashCode() {
      return Objects.hash(
         super.hashCode(),
         strConnectorClassName,
         strConnectionParameters,
         ra,
         connectionFactoryLookup,
         destination,
         destinationType,
         messageSelector,
         acknowledgeMode,
         subscriptionDurability,
         subscriptionName,
         shareSubscriptions,
         user,
         password,
         maxSession,
         singleConnection,
         transactionTimeout,
         useJNDI,
         jndiParams,
         parsedJndiParams,
         localTx,
         rebalanceConnections,
         setupAttempts,
         setupInterval,
         queuePrefix,
         topicPrefix
      );
   }{code}
We already use {{Objects.hash}} in many places. Using it consistently will make 
the code simpler.


> Use Objects.hash consistently
> -----------------------------
>
>                 Key: ARTEMIS-5539
>                 URL: https://issues.apache.org/jira/browse/ARTEMIS-5539
>             Project: ActiveMQ Artemis
>          Issue Type: Task
>            Reporter: Justin Bertram
>            Assignee: Justin Bertram
>            Priority: Major
>
> There are a lot of implementations of {{hashCode}} like this:
> {code:java}
>    @Override
>    public int hashCode() {
>       int result = super.hashCode();
>       result = 31 * result + (strConnectorClassName != null ? 
> strConnectorClassName.hashCode() : 0);
>       result = 31 * result + (strConnectionParameters != null ? 
> strConnectionParameters.hashCode() : 0);
>       result = 31 * result + (ra != null ? ra.hashCode() : 0);
>       result = 31 * result + (connectionFactoryLookup != null ? 
> connectionFactoryLookup.hashCode() : 0);
>       result = 31 * result + (destination != null ? destination.hashCode() : 
> 0);
>       result = 31 * result + (destinationType != null ? 
> destinationType.hashCode() : 0);
>       result = 31 * result + (messageSelector != null ? 
> messageSelector.hashCode() : 0);
>       result = 31 * result + acknowledgeMode;
>       result = 31 * result + (subscriptionDurability ? 1 : 0);
>       result = 31 * result + (subscriptionName != null ? 
> subscriptionName.hashCode() : 0);
>       result = 31 * result + (shareSubscriptions != null && 
> shareSubscriptions ? 1 : 0);
>       result = 31 * result + (user != null ? user.hashCode() : 0);
>       result = 31 * result + (password != null ? password.hashCode() : 0);
>       result = 31 * result + (maxSession != null ? maxSession.hashCode() : 0);
>       result = 31 * result + (singleConnection != null ? 
> singleConnection.hashCode() : 0);
>       result = 31 * result + (transactionTimeout != null ? 
> transactionTimeout.hashCode() : 0);
>       result = 31 * result + (useJNDI != null ? useJNDI.hashCode() : 0);
>       result = 31 * result + (jndiParams != null ? jndiParams.hashCode() : 0);
>       result = 31 * result + (parsedJndiParams != null ? 
> parsedJndiParams.hashCode() : 0);
>       result = 31 * result + (localTx != null ? localTx.hashCode() : 0);
>       result = 31 * result + (rebalanceConnections != null ? 
> rebalanceConnections.hashCode() : 0);
>       result = 31 * result + (setupAttempts != null ? 
> setupAttempts.hashCode() : 0);
>       result = 31 * result + (setupInterval != null ? 
> setupInterval.hashCode() : 0);
>       result = 31 * result + (queuePrefix != null ? queuePrefix.hashCode() : 
> 0);
>       result = 31 * result + (topicPrefix != null ? topicPrefix.hashCode() : 
> 0);
>       return result;
>    }{code}
> This could be simplified using {{Objects.hash}}, e.g.:
> {code:java}
>    @Override
>    public int hashCode() {
>       return Objects.hash(super.hashCode(), strConnectorClassName, 
> strConnectionParameters, ra, connectionFactoryLookup,
>                           destination, destinationType, messageSelector, 
> acknowledgeMode, subscriptionDurability,
>                           subscriptionName, shareSubscriptions, user, 
> password, maxSession, singleConnection,
>                           transactionTimeout, useJNDI, jndiParams, 
> parsedJndiParams, localTx, rebalanceConnections,
>                           setupAttempts, setupInterval, queuePrefix, 
> topicPrefix);
>    }{code}
> We already use {{Objects.hash}} in many places. Using it consistently will 
> make the code simpler.



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]
For further information, visit: https://activemq.apache.org/contact


Reply via email to