[
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