当前位置:  编程技术>移动开发
本页文章导读:
    ▪标记一下子        标记一下 // 调出手机market并搜索出相应的APK Uri uri = Uri.parse("market://search?q=pname:" + SCAN_PACKAGE); Intent scanintent = new Intent(Intent..........
    ▪ activity传接对象的list        activity传递对象的list 如题,将一个用户的List从a activity传递到b activity,使用putExtra。a activity部分代码: Intent intent = new Intent(); intent.putExtra("userList", userList.toArray());//userList定义时如下:.........
    ▪ memcached的施用【转】       memcached的使用【转】 windows下的Server端很简单,不用安装,双击运行后默认服务端口是11211,没有试着去更改端口,因为反正以后会用unix版本,到时再记录安装步骤。下载客户端的java API包.........

[1]标记一下子
    来源: 互联网  发布时间: 2014-02-18
标记一下
                     // 调出手机market并搜索出相应的APK

                    Uri uri = Uri.parse("market://search?q=pname:"
                            + SCAN_PACKAGE);
                    Intent scanintent = new Intent(Intent.ACTION_VIEW, uri);
                    try
                    {
                        startActivity(scanintent);
                    }
                    catch (ActivityNotFoundException anfe)
                    {
                        Log.w(TAG,
                                "Android Market is not installed; cannot install Barcode Scanner");
                    }  
	

 

// 调至系统联系人界面,选择联系人,并返回数据

 

                    Intent intent = new Intent();
                    intent.setAction(Intent.ACTION_PICK);
                    intent.setData(ContactsContract.Contacts.CONTENT_URI);
                    try
                    {
                        startActivityForResult(intent, FLAG_RESULT_SYS_CONTACTS);
                    }
                    catch (ActivityNotFoundException e1)
                    {
                        e1.printStackTrace();
                        Log.w(TAG, "No contacts pick...");
                    }

 


    
[2] activity传接对象的list
    来源: 互联网  发布时间: 2014-02-18
activity传递对象的list
如题,将一个用户的List从a activity传递到b activity,使用putExtra。
a activity部分代码:
Intent intent = new Intent();			
	intent.putExtra("userList", userList.toArray());//userList定义时如下:List<User> userList = new ArrayList<user>();,所以得要userList.toArray();
	intent.setClass(AaActivity.this, BbActivity.class);
	startActivity(intent);
	AaActivity.this.finish();

b activity端接收时:
Intent intent = this.getIntent();
		Object[] cobjs = (Object[]) intent.getSerializableExtra("userList");
		for (int i = 0; i < cobjs.length; i++) {
			User user = (User) cobjs[i];
			userList.add(user);
		}

重要一点,user要implements Serializable。
1 楼 tscfengkui 2011-08-31  
楼主可以吗?我这怎么不行 求教
2 楼 MultiArrow 2011-08-31  
tscfengkui 写道
楼主可以吗?我这怎么不行 求教

你有没有将list里的实体类序列化了?

    
[3] memcached的施用【转】
    来源: 互联网  发布时间: 2014-02-18
memcached的使用【转】
windows下的Server端很简单,不用安装,双击运行后默认服务端口是11211,没有试着去更改端口,因为反正以后会用unix版本,到时再记录安装步骤。下载客户端的java API包,接口非常简单,参考API手册上就有现成的例子。

目标,对旧框架缓存部分进行改造:
1、缓存工具类
2、hibernate的provider
3、用缓存实现session机制

今天先研究研究缓存工具类的改造,在旧框架中部分函数用了ehcache对执行结果进行了缓存处理,现在目标是提供一个缓存工具类,在配置文件中配置使用哪种缓存(memcached或ehcached),使其它程序对具体的缓存不依赖,同时使用AOP方式来对方法执行结果进行缓存。
首先是工具类的实现:
在Spring中配置
Java代码 
<!-- EhCache Manager -->  
<bean id="cacheManager" 
    >  
    <property name="configLocation">  
        <value>classpath:ehcache.xml</value>  
    </property>  
</bean>  
 
<bean id="localCache" 
    >  
    <property name="cacheManager" ref="cacheManager" />  
    <property name="cacheName" 
        value="×××.cache.LOCAL_CACHE" />  
</bean>  
 
<bean id="cacheService" 
    init-method="init" destroy-method="destory">  
    <property name="cacheServerList" value="${cache.servers}"/>  
    <property name="cacheServerWeights" value="${cache.cacheServerWeights}"/>  
    <property name="cacheCluster" value="${cache.cluster}"/>  
    <property name="localCache" ref="localCache"/>  
</bean> 

<!-- EhCache Manager -->
<bean id="cacheManager"
>
<property name="configLocation">
<value>classpath:ehcache.xml</value>
</property>
</bean>

<bean id="localCache"
>
<property name="cacheManager" ref="cacheManager" />
<property name="cacheName"
value="×××.cache.LOCAL_CACHE" />
</bean>

<bean id="cacheService"
init-method="init" destroy-method="destory">
<property name="cacheServerList" value="${cache.servers}"/>
<property name="cacheServerWeights" value="${cache.cacheServerWeights}"/>
<property name="cacheCluster" value="${cache.cluster}"/>
<property name="localCache" ref="localCache"/>
</bean>在properties文件中配置${cache.servers} ${cache.cacheServerWeights} ${cache.cluster}
具体工具类的代码
Java代码 
/** 
* @author Marc 
*  
*/ 
public class CacheService {  
    private Log logger = LogFactory.getLog(getClass());  
 
    private Cache localCache;  
 
    String cacheServerList;  
 
    String cacheServerWeights;  
 
    boolean cacheCluster = false;  
 
    int initialConnections = 10;  
 
    int minSpareConnections = 5;  
 
    int maxSpareConnections = 50;  
 
    long maxIdleTime = 1000 * 60 * 30; // 30 minutes  
 
    long maxBusyTime = 1000 * 60 * 5; // 5 minutes  
 
    long maintThreadSleep = 1000 * 5; // 5 seconds  
 
    int socketTimeOut = 1000 * 3; // 3 seconds to block on reads  
 
    int socketConnectTO = 1000 * 3; // 3 seconds to block on initial  
                                    // connections. If 0, then will use blocking  
                                    // connect (default)  
 
    boolean failover = false; // turn off auto-failover in event of server  
                                // down  
 
    boolean nagleAlg = false; // turn off Nagle's algorithm on all sockets in  
                                // pool  
 
    MemCachedClient mc;  
 
    public CacheService(){  
        mc = new MemCachedClient();  
        mc.setCompressEnable(false);  
    }  
    /** 
     * 放入 
     *  
     */ 
    public void put(String key, Object obj) {  
        Assert.hasText(key);  
        Assert.notNull(obj);  
        Assert.notNull(localCache);  
        if (this.cacheCluster) {  
            mc.set(key, obj);  
        } else {  
            Element element = new Element(key, (Serializable) obj);  
            localCache.put(element);  
        }  
    }  
    /** 
     * 删除  
     */ 
    public void remove(String key){  
        Assert.hasText(key);  
        Assert.notNull(localCache);  
        if (this.cacheCluster) {  
            mc.delete(key);  
        }else{  
            localCache.remove(key);  
        }  
    }  
    /** 
     * 得到 
     */ 
    public Object get(String key) {  
        Assert.hasText(key);  
        Assert.notNull(localCache);  
        Object rt = null;  
        if (this.cacheCluster) {  
            rt = mc.get(key);  
        } else {  
            Element element = null;  
            try {  
                element = localCache.get(key);  
            } catch (CacheException cacheException) {  
                throw new DataRetrievalFailureException("Cache failure: " 
                        + cacheException.getMessage());  
            }  
            if(element != null)  
                rt = element.getValue();  
        }  
        return rt;  
    }  
    /** 
     * 判断是否存在 
     *  
     */ 
    public boolean exist(String key){  
        Assert.hasText(key);  
        Assert.notNull(localCache);  
        if (this.cacheCluster) {  
            return mc.keyExists(key);  
        }else{  
            return this.localCache.isKeyInCache(key);  
        }  
    }  
    private void init() {  
        if (this.cacheCluster) {  
            String[] serverlist = cacheServerList.split(",");  
            Integer[] weights = this.split(cacheServerWeights);  
            // initialize the pool for memcache servers  
            SockIOPool pool = SockIOPool.getInstance();  
            pool.setServers(serverlist);  
            pool.setWeights(weights);  
            pool.setInitConn(initialConnections);  
            pool.setMinConn(minSpareConnections);  
            pool.setMaxConn(maxSpareConnections);  
            pool.setMaxIdle(maxIdleTime);  
            pool.setMaxBusyTime(maxBusyTime);  
            pool.setMaintSleep(maintThreadSleep);  
            pool.setSocketTO(socketTimeOut);  
            pool.setSocketConnectTO(socketConnectTO);  
            pool.setNagle(nagleAlg);  
            pool.setHashingAlg(SockIOPool.NEW_COMPAT_HASH);  
            pool.initialize();  
            logger.info("初始化memcached pool!");  
        }  
    }  
 
    private void destory() {  
        if (this.cacheCluster) {  
            SockIOPool.getInstance().shutDown();  
        }  
    }  


/**
* @author Marc
*
*/
public class CacheService {
private Log logger = LogFactory.getLog(getClass());

private Cache localCache;

String cacheServerList;

String cacheServerWeights;

boolean cacheCluster = false;

int initialConnections = 10;

int minSpareConnections = 5;

int maxSpareConnections = 50;

long maxIdleTime = 1000 * 60 * 30; // 30 minutes

long maxBusyTime = 1000 * 60 * 5; // 5 minutes

long maintThreadSleep = 1000 * 5; // 5 seconds

int socketTimeOut = 1000 * 3; // 3 seconds to block on reads

int socketConnectTO = 1000 * 3; // 3 seconds to block on initial
// connections. If 0, then will use blocking
// connect (default)

boolean failover = false; // turn off auto-failover in event of server
// down

boolean nagleAlg = false; // turn off Nagle's algorithm on all sockets in
// pool

MemCachedClient mc;

public CacheService(){
mc = new MemCachedClient();
mc.setCompressEnable(false);
}
/**
* 放入
*
*/
public void put(String key, Object obj) {
Assert.hasText(key);
Assert.notNull(obj);
Assert.notNull(localCache);
if (this.cacheCluster) {
mc.set(key, obj);
} else {
Element element = new Element(key, (Serializable) obj);
localCache.put(element);
}
}
/**
* 删除
*/
public void remove(String key){
Assert.hasText(key);
Assert.notNull(localCache);
if (this.cacheCluster) {
mc.delete(key);
}else{
localCache.remove(key);
}
}
/**
* 得到
*/
public Object get(String key) {
Assert.hasText(key);
Assert.notNull(localCache);
Object rt = null;
if (this.cacheCluster) {
rt = mc.get(key);
} else {
Element element = null;
try {
            element = localCache.get(key);
        } catch (CacheException cacheException) {
            throw new DataRetrievalFailureException("Cache failure: "
                    + cacheException.getMessage());
        }
if(element != null)
rt = element.getValue();
}
return rt;
}
/**
* 判断是否存在
*
*/
public boolean exist(String key){
Assert.hasText(key);
Assert.notNull(localCache);
if (this.cacheCluster) {
return mc.keyExists(key);
}else{
return this.localCache.isKeyInCache(key);
}
}
private void init() {
if (this.cacheCluster) {
String[] serverlist = cacheServerList.split(",");
Integer[] weights = this.split(cacheServerWeights);
// initialize the pool for memcache servers
SockIOPool pool = SockIOPool.getInstance();
pool.setServers(serverlist);
pool.setWeights(weights);
pool.setInitConn(initialConnections);
pool.setMinConn(minSpareConnections);
pool.setMaxConn(maxSpareConnections);
pool.setMaxIdle(maxIdleTime);
pool.setMaxBusyTime(maxBusyTime);
pool.setMaintSleep(maintThreadSleep);
pool.setSocketTO(socketTimeOut);
pool.setSocketConnectTO(socketConnectTO);
pool.setNagle(nagleAlg);
pool.setHashingAlg(SockIOPool.NEW_COMPAT_HASH);
pool.initialize();
logger.info("初始化memcached pool!");
}
}

private void destory() {
if (this.cacheCluster) {
SockIOPool.getInstance().shutDown();
}
}
}
然后实现函数的AOP拦截类,用来在函数执行前返回缓存内容
Java代码 
public class CachingInterceptor implements MethodInterceptor {  
 
    private CacheService cacheService;  
    private String cacheKey;  
 
    public void setCacheKey(String cacheKey) {  
        this.cacheKey = cacheKey;  
    }  
 
    public void setCacheService(CacheService cacheService) {  
        this.cacheService = cacheService;  
    }  
 
    public Object invoke(MethodInvocation invocation) throws Throwable {  
        Object result = cacheService.get(cacheKey);  
        //如果函数返回结果不在Cache中,执行函数并将结果放入Cache  
        if (result == null) {  
            result = invocation.proceed();  
            cacheService.put(cacheKey,result);  
        }  
        return result;  
    }  


public class CachingInterceptor implements MethodInterceptor {

    private CacheService cacheService;
    private String cacheKey;

    public void setCacheKey(String cacheKey) {
        this.cacheKey = cacheKey;
    }

    public void setCacheService(CacheService cacheService) {
        this.cacheService = cacheService;
    }

    public Object invoke(MethodInvocation invocation) throws Throwable {
        Object result = cacheService.get(cacheKey);
        //如果函数返回结果不在Cache中,执行函数并将结果放入Cache
        if (result == null) {
            result = invocation.proceed();
            cacheService.put(cacheKey,result);
        }
        return result;
    }
}Spring的AOP配置如下:
Java代码 
<aop:config proxy-target->  
        <aop:advisor  
            pointcut="execution(* ×××.PoiService.getOne(..))" 
            advice-ref="PoiServiceCachingAdvice" />  
    </aop:config>  
 
    <bean id="BasPoiServiceCachingAdvice" 
        >  
        <property name="cacheKey" value="PoiService" />  
        <property name="cacheService" ref="cacheService" />  
    </bean> 


实现hibernate的cache provider,让hibernate使用memcached缓存。
这里比较简单,由于memcached的SockIOPool已经在(一)中spring中初始化了,这里就不考虑pool的初始化,直接获得MemCachedClient使用即可。
然后配置给hibernate<prop key="hibernate.cache.provider_class">×××</prop>

附代码:
Java代码 
/** 
* @author Marc 

*/ 
public class MemcachedProvider implements CacheProvider {  
    public Cache buildCache(String name, Properties properties) throws CacheException {  
        return new MemCache(name);  
    }  
 
    public boolean isMinimalPutsEnabledByDefault() {  
        return false;  
    }  
 
    public long nextTimestamp() {  
        return Timestamper.next();  
    }  
 
    public void start(Properties properties) throws CacheException {  
    }  
 
    public void stop() {  
    }  
 


/**
* @author Marc
*
*/
public class MemcachedProvider implements CacheProvider {
public Cache buildCache(String name, Properties properties) throws CacheException {
return new MemCache(name);
}

public boolean isMinimalPutsEnabledByDefault() {
return false;
}

public long nextTimestamp() {
return Timestamper.next();
}

public void start(Properties properties) throws CacheException {
}

public void stop() {
}

}
Java代码 
/** 
* @author Marc 
*  
*/ 
public class MemCache implements Cache {  
    private static final Log log = LogFactory.getLog(MemCache.class);  
 
    private static final int SIXTY_THOUSAND_MS = 60000;  
 
    MemCachedClient mc;  
    String regionName;  
 
    /** 
     * Creates a new Hibernate pluggable cache based on a cache name. <p/> 
     *  
     * @param cache 
     *            The underlying EhCache instance to use. 
     */ 
    public MemCache(String regionName) {  
        mc = new MemCachedClient();  
        mc.setCompressEnable(false);  
        this.regionName = regionName;  
    }  
 
    /** 
     * Gets a value of an element which matches the given key. 
     *  
     * @param key 
     *            the key of the element to return. 
     * @return The value placed into the cache with an earlier put, or null if 
     *         not found or expired 
     * @throws CacheException 
     */ 
    public Object get(Object key) throws CacheException {  
        if (log.isDebugEnabled()) {  
            log.debug("key: " + key);  
        }  
        if (key == null) {  
            return null;  
        } else {  
            Object rt = mc.get(key.toString());  
            if (rt == null) {  
                if (log.isDebugEnabled()) {  
                    log.debug("Element for " + key + " is null");  
                }  
                return null;  
            } else {  
                return rt;  
            }  
        }  
 
    }  
 
    public Object read(Object key) throws CacheException {  
        return get(key);  
    }  
 
    /** 
     * Puts an object into the cache. 
     *  
     * @param key 
     *            a key 
     * @param value 
     *            a value 
     * @throws CacheException 
     *             if the {@link CacheManager} is shutdown or another 
     *             {@link Exception} occurs. 
     */ 
    public void update(Object key, Object value) throws CacheException {  
        put(key, value);  
    }  
 
    /** 
     * Puts an object into the cache. 
     *  
     * @param key 
     *            a key 
     * @param value 
     *            a value 
     * @throws CacheException 
     *             if the {@link CacheManager} is shutdown or another 
     *             {@link Exception} occurs. 
     */ 
    public void put(Object key, Object value) throws CacheException {  
        mc.set(key.toString(), value);  
    }  
 
    /** 
     * Removes the element which matches the key. <p/> If no element matches, 
     * nothing is removed and no Exception is thrown. 
     *  
     * @param key 
     *            the key of the element to remove 
     * @throws CacheException 
     */ 
    public void remove(Object key) throws CacheException {  
        mc.delete(key.toString());  
    }  
 
    /** 
     * Remove all elements in the cache, but leave the cache in a useable state. 
     *  
     * @throws CacheException 
     */ 
    public void clear() throws CacheException {  
        log.warn("cann't clear all items in memcached!");  
        throw new CacheException("cann't clear all items in memcached!");  
    }  
 
    /** 
     * Remove the cache and make it unuseable. 
     *  
     * @throws CacheException 
     */ 
    public void destroy() throws CacheException {  
 
    }  
 
    /** 
     * Calls to this method should perform there own synchronization. It is 
     * provided for distributed caches. Because EHCache is not distributed this 
     * method does nothing. 
     */ 
    public void lock(Object key) throws CacheException {  
    }  
 
    /** 
     * Calls to this method should perform there own synchronization. It is 
     * provided for distributed caches. Because EHCache is not distributed this 
     * method does nothing. 
     */ 
    public void unlock(Object key) throws CacheException {  
    }  
 
    /** 
     * Gets the next timestamp; 
     */ 
    public long nextTimestamp() {  
        return Timestamper.next();  
    }  
 
    /** 
     * Returns the lock timeout for this cache. 
     */ 
    public int getTimeout() {  
        // 60 second lock timeout  
        return Timestamper.ONE_MS * SIXTY_THOUSAND_MS;  
    }  
 
    public String getRegionName() {  
        return this.regionName;  
    }  
 
    /** 
     * Warning: This method can be very expensive to run. Allow approximately 1 
     * second per 1MB of entries. Running this method could create liveness 
     * problems because the object lock is held for a long period <p/> 
     *  
     * @return the approximate size of memory ehcache is using for the 
     *         MemoryStore for this cache 
     */ 
    public long getSizeInMemory() {  
        log.warn("cann't getSizeInMemory in memcached!");  
        throw new CacheException("cann't getSizeInMemory in memcached!");  
    }  
 
    public long getElementCountInMemory() {  
        log.warn("cann't getElementCountInMemory in memcached!");  
        throw new CacheException("cann't getElementCountInMemory in memcached!");  
    }  
 
    public long getElementCountOnDisk() {  
        log.warn("cann't getElementCountOnDisk in memcached!");  
        throw new CacheException("cann't getElementCountOnDisk in memcached!");  
    }  
 
    public Map toMap() {  
        log.warn("cann't toMap in memcached!");  
        throw new CacheException("cann't toMap in memcached!");  
    }  
 
    public String toString() {  
        return "MemCached(" + getRegionName() + ')';  
    }  
 
}

http://www.iteye.com/topic/28700

    
最新技术文章:
▪Android开发之登录验证实例教程
▪Android开发之注册登录方法示例
▪Android获取手机SIM卡运营商信息的方法
▪Android实现将已发送的短信写入短信数据库的...
▪Android发送短信功能代码
▪Android根据电话号码获得联系人头像实例代码
▪Android中GPS定位的用法实例
▪Android实现退出时关闭所有Activity的方法
▪Android实现文件的分割和组装
▪Android录音应用实例教程
▪Android双击返回键退出程序的实现方法
▪Android实现侦听电池状态显示、电量及充电动...
▪Android获取当前已连接的wifi信号强度的方法
▪Android实现动态显示或隐藏密码输入框的内容
▪根据USER-AGENT判断手机类型并跳转到相应的app...
▪Android Touch事件分发过程详解
▪Android中实现为TextView添加多个可点击的文本
▪Android程序设计之AIDL实例详解
▪Android显式启动与隐式启动Activity的区别介绍
▪Android按钮单击事件的四种常用写法总结
▪Android消息处理机制Looper和Handler详解
▪Android实现Back功能代码片段总结
▪Android实用的代码片段 常用代码总结
▪Android实现弹出键盘的方法
▪Android中通过view方式获取当前Activity的屏幕截...
▪Android提高之自定义Menu(TabMenu)实现方法
▪Android提高之多方向抽屉实现方法
▪Android提高之MediaPlayer播放网络音频的实现方法...
▪Android提高之MediaPlayer播放网络视频的实现方法...
▪Android提高之手游转电视游戏的模拟操控
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3