zoukankan      html  css  js  c++  java
  • Concurrency,Java 并发

    //TestLock.java
    package com.test.thread;
    
    import java.util.ArrayList;
    import java.util.List;
    import java.util.concurrent.ExecutionException;
    import java.util.concurrent.ExecutorService;
    import java.util.concurrent.Executors;
    import java.util.concurrent.Future;
    import java.util.concurrent.TimeUnit;
    import java.util.concurrent.locks.Lock;
    import java.util.concurrent.locks.ReentrantLock;
    
    public class TestLock {
    
    	private static int cnt=0;
    	private final int num=cnt++;
    	private static Lock lock=new ReentrantLock();
    	
    	private TestLock(){}
    	private static TestLock ins=null;
    	public static /*synchronized */ TestLock getInstance(){		
    		if(ins==null){
    			//若在此处声明锁,则不能保证多个线程访问时,此段代码的安全
    			//Lock lock=new ReentrantLock();
    			lock.lock();
    			try {
    				if (ins== null) {
    					TimeUnit.MILLISECONDS.sleep(10);
    					ins = new TestLock();
    				}
    			} catch (InterruptedException e) {
    				e.printStackTrace();
    			}
    			finally{
    				lock.unlock();
    			}
    		}
    		return ins;
    	}
    	
    	public int getNum() {
    		return num;
    	}
    
    	/**
    	 * @param args
    	 */
    	public static void main(String[] args) {
    		ExecutorService svs = Executors.newCachedThreadPool();
    		List< Future<TestLock> > lstObjs=new ArrayList< Future<TestLock> >();
    		for (int i = 0;i<10;i++){
    			 lstObjs.add( svs.submit(new TestLockThread()) );
    		}
    		for (Future<TestLock> ftl : lstObjs) {
    			try {
    				TestLock tl=  ftl.get();
    				
    			} catch (InterruptedException e) {
    				e.printStackTrace();
    			} catch (ExecutionException e) {
    				e.printStackTrace();
    			}
    		}
    		svs.shutdown();
    	}
    
    }
    
    //TestLockThread.java
    
    package com.test.thread;
    import java.util.concurrent.Callable;
    
    public class TestLockThread implements Callable<TestLock> {
    	@Override
    	public TestLock call() throws Exception {
    		TestLock tl = TestLock.getInstance();
    		System.out.println("call:"+tl.getNum());
    		return tl;
    	}
    
    }
    
  • 相关阅读:
    sql server分布式事务解决方案 (笔记)
    深入理解Datatable(笔记)
    SQLSERVER 2005 实现文件读写操作
    局部变量、全局变量、堆、堆栈、静态和全局
    分布式事务DISTRIBUTED TRANSACTION
    SQLSEVER2005中找不到存储过程xp_getfiledetails 解决办法
    模式窗口
    理解析构函数的执行过程
    Oracle分页
    DataTable导出到Excel、GSV (转)
  • 原文地址:https://www.cnblogs.com/wucg/p/1989721.html
Copyright © 2011-2022 走看看