Respect knowledge, reprinted please indicate this article from: programming artist poechant csdn blog http://blog.csdn.net/poechant
1. Non-cas
First, let's look at a memcached program instance that is not CAS. For more information about the prototype of the instance, see the previous blog.
Program instance:
package com.sinosuperman.memcached;import java.io.IOException;import java.net.InetSocketAddress;import net.spy.memcached.MemcachedClient;public class Test {public static void main(String[] args) throws IOException {MemcachedClient cache = new MemcachedClient(new InetSocketAddress("127.0.0.1", 11211));cache.set("x", 1800, "Love");String obj1 = (String) cache.get("x");String obj2 = (String) cache.get("x");obj2 = "Michael";cache.set("x", 1800, obj2);System.out.println("Non-CAS 2:\t" + obj2);System.out.println("Non-CAS 1:\t" + obj1);}}
Running result:
2011-12-18 23:12:39.836 INFO net.spy.memcached.MemcachedConnection: Added {QA sa=/127.0.0.1:11211, #Rops=0, #Wops=0, #iq=0, topRop=null, topWop=null, toWrite=0, interested=0} to connect queue2011-12-18 23:12:39.843 INFO net.spy.memcached.MemcachedConnection: Connection state changed for sun.nio.ch.SelectionKeyImpl@b09e89Non-CAS 2:MichaelNon-CAS 1:Love
It can be seen that multiple client operations will inevitably cause write inconsistency.
2. CAS
Program instance:
package com.sinosuperman.memcached;import java.io.IOException;import java.net.InetSocketAddress;import net.spy.memcached.CASValue;import net.spy.memcached.MemcachedClient;public class Test {@SuppressWarnings("unchecked")public static void main(String[] args) throws IOException {MemcachedClient cache = new MemcachedClient(new InetSocketAddress("127.0.0.1", 11211));cache.set("y", 1800, "Love");CASValue casValue1 = cache.gets("y");CASValue casValue2 = cache.gets("y");cache.cas("y", casValue2.getCas(), casValue2.getValue());System.out.println("CAS 2:\t" + casValue2.getCas());System.out.println("Value 2:\t" + casValue2.getValue());System.out.println("CAS 1:\t" + casValue1.getCas());System.out.println("Value 1:\t" + casValue1.getValue());}}
Running result:
2011-12-18 23:07:14.528 INFO net.spy.memcached.MemcachedConnection: Added {QA sa=/127.0.0.1:11211, #Rops=0, #Wops=0, #iq=0, topRop=null, topWop=null, toWrite=0, interested=0} to connect queue2011-12-18 23:07:14.541 INFO net.spy.memcached.MemcachedConnection: Connection state changed for sun.nio.ch.SelectionKeyImpl@1621e42CAS 2:11Value 2:LoveCAS 1:11Value 1:Love