- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在 Hashmap 中遇到空指针异常,它是一个全局变量,并且由单独的线程进行更新。在调试时,所有线程都运行良好并更新 HashMap ,但是当我执行程序时,一个线程抛出空指针。
public class RunEngine {
/**
* @param args
*/
public static Map<Integer, List<Event>> queue_map = new HashMap<Integer, List<Event>>();
public static void main(String[] args) {
/*
* check file present in data set folder or not , if present fetch the file name
* and store then in a list
*/
File folder = new File(ConfigurationParameters.FOLDER_PATH);
File[] listOfFiles = folder.listFiles();
/* Create a thread pool for number of Publishers which you want to initialise */
ThreadPoolExecutor executor = new ThreadPoolExecutor(ConfigurationParameters.P_NUMBER,
ConfigurationParameters.P_NUMBER + 3, 100, TimeUnit.MILLISECONDS,
new LinkedBlockingQueue<Runnable>(), new ThreadPoolExecutor.CallerRunsPolicy()); // P_NUMBER = 2
for (int i = 1; i <= ConfigurationParameters.P_NUMBER; i++) {
ConnectP conn = new ConnectP(
ConfigurationParameters.FOLDER_PATH + "\\" + listOfFiles[i - 1].getName(),
ConfigurationParameters.DISTRIBUTION_RANDOM, i);
executor.execute(conn);
}
executor.shutdown();
}
}
ConnectP 类如下所示:
public class ConnectP implements Runnable {
private String file_path;
private String distribution_constant;
private int pub_id;
/**
* @param file_path
* @param distribution_constant
*/
public ConnectP(String file_path, String distribution_constant, int pub_id) {
super();
this.file_path = file_path;
this.distribution_constant = distribution_constant;
this.pub_id = pub_id;
}
public void streamevent(List<Event> eventlist, String distributionconstant)
throws InterruptedException {
if (distributionconstant.matches(ConfigurationParameters.PUBLISHER_DISTRIBUTION_RANDOM)) {
List<Event> publisherqueue = new ArrayList<>();
RunEngine.queue_map.put(pub_id, publisherqueue);
for (Event event : eventlist) {
long start = System.currentTimeMillis(); // get present system timestamp
event.setTimeStamp(start);
publisherqueue.add(event); // add to publisher queue
Random rand = new Random();
int value = rand.nextInt(1000); // add a random seed for streaming
Thread.sleep(value); // sleep the process for that value
System.out.println("Publisher " + String.valueOf(pub_id) + " : " + RunEngine.queue_map.get(pub_id).size()); **(throwing exception line 68)**
}
}
}
// function to connect to source file and return list of publication event
public List<Event> connectsource(String filepath) {
// return list after reading file
return list;
}
@Override
public void run() {
// TODO Auto-generated method stub
List<Event> event = this.connectsource(file_path); // connect to source
try {
System.out.println("THREAD " + String.valueOf(pub_id)+ " Initiated");
this.streamevent(event, distribution_constant);**(throwing exception line 121)**
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
我得到的异常(exception)是
Exception in thread "pool-1-thread-1" java.lang.NullPointerException
at org.test.event.ConnectP.streamevent(ConnectP.java:68)
at org.test.event.ConnectP.run(ConnectP.java:121)
at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
at java.lang.Thread.run(Unknown Source)
我将感谢您的帮助。如果有一些有效的方法可以做到这一点,我们将不胜感激。
最佳答案
I am getting a Null pointer exception in my Hashmap which is a global variable and is getting updated by separate threads.
HashMap
不是同步类。如果多个线程同时更新映射,那么它们的该映射的内存 View 很可能会不同步,这可能会导致 NPE、无限循环或其他不好的事情。
// thread-1
RunEngine.queue_map.put(pub_id, publisherqueue);
...
// thread-2
RunEngine.queue_map.get(pub_id).size()
对。一个线程看起来正在放入,而另一个线程正在获取。当您在多个线程中执行此操作时,您需要担心:
基本上每个线程都有一个每个处理器的本地内存缓存,允许它有效地访问缓存的结果,而不必从主内存获取所有内容。因此,当线程 1 更新映射时,它只能在其缓存中执行此操作。如果线程 2 然后从映射中获取,它可能看不到任何更新,或者更糟糕的是,根据虚拟内存详细信息,映射的部分更新。如果两个线程都在更新映射,则将其内存缓存刷新到主内存的线程将覆盖另一个线程所做的更新。
对于您在线程之间共享的任何对象都是如此。只有具有最终字段的不可变对象(immutable对象)才可以在线程之间共享而无需担心。否则,您需要使用 volatile
或 synchronized
关键字来确保它们正确共享。要正确地做到这一点相当困难,并且需要丰富的 Java 线程和内存同步结构经验。
Java tutorial about synchronization可能是一个很好的起点。
关于java - 使用单独的线程更新全局 HashMap 时出现空指针异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51378326/
SQLite、Content provider 和 Shared Preference 之间的所有已知区别。 但我想知道什么时候需要根据情况使用 SQLite 或 Content Provider 或
警告:我正在使用一个我无法完全控制的后端,所以我正在努力解决 Backbone 中的一些注意事项,这些注意事项可能在其他地方更好地解决......不幸的是,我别无选择,只能在这里处理它们! 所以,我的
我一整天都在挣扎。我的预输入搜索表达式与远程 json 数据完美配合。但是当我尝试使用相同的 json 数据作为预取数据时,建议为空。点击第一个标志后,我收到预定义消息“无法找到任何内容...”,结果
我正在制作一个模拟 NHL 选秀彩票的程序,其中屏幕右侧应该有一个 JTextField,并且在左侧绘制弹跳的选秀球。我创建了一个名为 Ball 的类,它实现了 Runnable,并在我的主 Draf
这个问题已经有答案了: How can I calculate a time span in Java and format the output? (18 个回答) 已关闭 9 年前。 这是我的代码
我有一个 ASP.NET Web API 应用程序在我的本地 IIS 实例上运行。 Web 应用程序配置有 CORS。我调用的 Web API 方法类似于: [POST("/API/{foo}/{ba
我将用户输入的时间和日期作为: DatePicker dp = (DatePicker) findViewById(R.id.datePicker); TimePicker tp = (TimePic
放宽“邻居”的标准是否足够,或者是否有其他标准行动可以采取? 最佳答案 如果所有相邻解决方案都是 Tabu,则听起来您的 Tabu 列表的大小太长或您的释放策略太严格。一个好的 Tabu 列表长度是
我正在阅读来自 cppreference 的代码示例: #include #include #include #include template void print_queue(T& q)
我快疯了,我试图理解工具提示的行为,但没有成功。 1. 第一个问题是当我尝试通过插件(按钮 1)在点击事件中使用它时 -> 如果您转到 Fiddle,您会在“内容”内看到该函数' 每次点击都会调用该属
我在功能组件中有以下代码: const [ folder, setFolder ] = useState([]); const folderData = useContext(FolderContex
我在使用预签名网址和 AFNetworking 3.0 从 S3 获取图像时遇到问题。我可以使用 NSMutableURLRequest 和 NSURLSession 获取图像,但是当我使用 AFHT
我正在使用 Oracle ojdbc 12 和 Java 8 处理 Oracle UCP 管理器的问题。当 UCP 池启动失败时,我希望关闭它创建的连接。 当池初始化期间遇到 ORA-02391:超过
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 9 年前。 Improve
引用这个plunker: https://plnkr.co/edit/GWsbdDWVvBYNMqyxzlLY?p=preview 我在 styles.css 文件和 src/app.ts 文件中指定
为什么我的条形这么细?我尝试将宽度设置为 1,它们变得非常厚。我不知道还能尝试什么。默认厚度为 0.8,这是应该的样子吗? import matplotlib.pyplot as plt import
当我编写时,查询按预期执行: SELECT id, day2.count - day1.count AS diff FROM day1 NATURAL JOIN day2; 但我真正想要的是右连接。当
我有以下时间数据: 0 08/01/16 13:07:46,335437 1 18/02/16 08:40:40,565575 2 14/01/16 22:2
一些背景知识 -我的 NodeJS 服务器在端口 3001 上运行,我的 React 应用程序在端口 3000 上运行。我在 React 应用程序 package.json 中设置了一个代理来代理对端
我面临着一个愚蠢的问题。我试图在我的 Angular 应用程序中延迟加载我的图像,我已经尝试过这个2: 但是他们都设置了 src attr 而不是 data-src,我在这里遗漏了什么吗?保留 d
我是一名优秀的程序员,十分优秀!