XOR Swap Algorithm - Reasons For Avoidance in Practice

Reasons For Avoidance in Practice

Most modern compilers can optimize away the temporary variable in the naive swap, in which case the naive swap uses the same amount of memory and the same number of registers as the XOR swap and is at least as fast, and often faster. The XOR swap is also much less readable and completely opaque to anyone unfamiliar with the technique.

On modern CPU architectures, the XOR technique is considerably slower than using a temporary variable to do swapping. One reason is that modern CPUs strive to execute instructions in parallel via instruction pipelines. In the XOR technique, the inputs to each operation depend on the results of the previous operation, so they must be executed in strictly sequential order. If efficiency is of tremendous concern, it is advised to test the speeds of both the XOR technique and temporary variable swapping on the target architecture.

Read more about this topic:  XOR Swap Algorithm

Famous quotes containing the words reasons for, reasons, avoidance and/or practice:

    While there are practical and sometimes moral reasons for the decomposition of the family, it coincides neither with what most people in society say they desire nor, especially in the case of children, with their best interests.
    Robert Neelly Bellah (20th century)

    Happy the man who has been able to know the reasons for things.
    Virgil [Publius Vergilius Maro] (70–19 B.C.)

    Tax avoidance means that you hire a $250,000-fee lawyer, and he changes the word ‘evasion’ into the word ‘avoidance.’
    Franklin D. Roosevelt (1882–1945)

    In my practice I’ve seen how people have allowed their humanity to drain away. Only it happens slowly instead of all at once. I didn’t seem to mind.... All of us, a little bit. We harden our hearts. Grow callous. Only when we have to fight to stay human do we realize how precious it is to us, how dear.
    Daniel Mainwaring (1902–1977)