final-java 多线程问题 变量问题

问题描述

java 多线程问题 变量问题

for(Iterator>> iterator = cursorMap.entrySet().iterator();iterator.hasNext();){
final Entry> entry = (Entry>)iterator.next();
final String fileName = entry.getValue().get("fileName")+".cursor";
logger.info(entry.getValue().get("fileName")+" etl start");
scheduleServiceMap.get(entry.getValue().get("fileName")).scheduleWithFixedDelay(new Runnable() {
@Override
public void run() {
LongCursor cursor = null;
try {
Entry> cursorEntry = entry;
read(fileName);

                    } catch (Throwable e) {

                    }
                }
            }, 0, delay, TimeUnit.MILLISECONDS);
        }

                这样 entry和fileName是否线程安全,我想要达到一个线程一个entry和fileName。我跟人是觉得没问题,可是程序跑出来异常。

解决方案

多线程的话你要么用concurrenthashmap,要么在map的get,set之前锁一下

解决方案二:

多线程你需要有锁机制来保护,不然就不安全。或者用lock-free的数据类型

解决方案三:

多线程运行的话确实会出现之前想不到的问题。
你的代码里没有进行任何多线程的控制,所以难免出问题。要么在程序里面用synchronized关键字,要么用Lock接口,要么改为线程安全的数据类型。

时间: 2024-11-01 18:31:26

final-java 多线程问题 变量问题的相关文章

java 多线程方法加锁获取自增变量重复问题

问题描述 java 多线程方法加锁获取自增变量重复问题 /** 测试多线程并发获取唯一子增长的值 @author Administrator * */ public class BB { private int increment = 0; final static Set set = new HashSet(); final static List list = new ArrayList(); public synchronized int getauto() { return increm

java多线程操作同一个变量的问题,难道是多核cpu所致?

问题描述 java多线程操作同一个变量的问题,难道是多核cpu所致? 大家请看代码和输出结果,我百思不得其解,为什么 amount只加了一次,开始我以为是static所致,就算去掉也还是有几率出现这样的结果,难道是多核cpu真的把两个线程同时执行了? package study; public class MyRunnable implements Runnable { public static int amount=0; @Override public void run() { // TO

深入探讨Java多线程中的volatile变量_java

volatile 变量提供了线程的可见性,并不能保证线程安全性和原子性. 什么是线程的可见性: 锁提供了两种主要特性:互斥(mutual exclusion) 和可见性(visibility).互斥即一次只允许一个线程持有某个特定的锁,因此可使用该特性实现对共享数据的协调访问协议,这样,一次就只有一个线程能够使用该共享数据.可见性要更加复杂一些,它必须确保释放锁之前对共享数据做出的更改对于随后获得该锁的另一个线程是可见的 -- 如果没有同步机制提供的这种可见性保证,线程看到的共享变量可能是修改前

《Java多线程编程核心技术》——第2章对象及变量的并发访问

第2章对象及变量的并发访问本章主要介绍Java多线程中的同步,也就是如何在Java语言中写出线程安全的程序,如何在Java语言中解决非线程安全的相关问题.多线程中的同步问题是学习多线程的重中之重,这个技术在其他的编程语言中也涉及,如C++或C#.本章应该着重掌握如下技术点:synchronized对象监视器为Object时的使用.synchronized对象监视器为Class时的使用.非线程安全是如何出现的.关键字volatile的主要作用.关键字volatile与synchronized的区别

java多线程实例的成员变量问题

问题描述 java多线程实例的成员变量问题 有一个线程通过下面listObj里面的线程实例修改线程的成员变量(修改前会判断线程实例的isBusy状态),那么被修改的该线程实例为毛有时运行会报空值,即逻辑操作取值部分? ListlistObj=new ArrayList(); for(int i=0;i<30;i++){ A a=new A(); Thread thread=new Thread(a); listObj.add(a); thread.start(); } class A imple

java多线程 参数已经传入构造方法 进入run方法时参数却被改变

问题描述 java多线程 参数已经传入构造方法 进入run方法时参数却被改变 请教各位大神:我在for循环里面执行线程,遇到一个问题,代码如下:private static final ExecutorService executors = Executors.newScheduledThreadPool(10);......for(...){executors.execute(new PublishThread(map));}PublishThread实现了Runnable方法,它有一个私有成

解决Java多线程并发的计数器问题

问题描述 解决Java多线程并发的计数器问题 3C public class Counter { public static int count = 0; public synchronized static void inc() { count++; } public static void main(String[] args) { //同时启动1000个线程,去进行i++计算,看看实际结果 for (int i = 0; i < 1000; i++) { new Thread(new Ru

java多线程和并发包入门示例_java

一.java多线程基本入门java多线程编程还是比较重要的,在实际业务开发中经常要遇到这个问题. java多线程,传统创建线程的方式有两种. 1.继承自Thread类,覆写run方法. 2.实现Runnable接口,实现run方法. 启动线程的方法都是调用start方法,真正执行调用的是run方法.参考代码如下: 复制代码 代码如下: package com.jack.thread; /** * 线程简单演示例子程序 *  * @author pinefantasy * @since 2013-

Java多线程与并发库高级应用

想快速精通多线程?看这里  http://blog.chinaunix.net/uid-540802-id-4431193.html 什么是线程         线程,是程序执行流的最小单元.是进程中的一个实体,是被系统独立调度和分派的基本单位,线程自己不拥有系统资源,只拥有一点儿在运行中必不可少的资源,但它可以与同属一个进程的其他线程共享进程所拥有的全部资源,一个线程可以创建和撤销另一个线程,同一进程中的多个线程之间可以并发执行.在单个程序中同时运行多个线程完成不同的工作,称为多线程.当自己想