-
问题复现
- 问题描述
使用IF控制器获取前一个请求的后置脚本中设置的全局变量->并发线程下通过vars.get获取变量时,第一个线程和第二个线程获取的变量值一样->导致不同基础数据的请求入参一样
-
方法如下:
vars.put("shoppingCartIdList", shoppingCartIdList.toString());
//设置标志位,用于后续接口是否触发请求
vars.put(isSend, "true"); -
if控制器的设置
-
同一个线程循环时出现获取变量混乱的情况
第一个线程请求入参正确
第二个请求入参是第一个的入参
两者的入参一样。
-
分析原因
-
设置全局变量的方式不对,需要用
AtomicReference
类进行线程的安全操作,设置方法如下:AtomicReference<JSONArray> threadLocalShoppingCartIdList = new AtomicReference<>(shoppingCartIdList); vars.putObject("shoppingCartIdList", threadLocalShoppingCartIdList); vars.putObject(isSend, "true");
AtomicReference
说明:- 原子操作:AtomicReference 提供了原子性的引用更新操作。通过CAS
(Compare And Swap)算法,可以确保对引用对象的原子操作,避免了使用锁
带来的性能开销。
-
共享变量:AtomicReference 适用于需要在多个线程之间共享同一个引用对象的
场景,可以安全地对引用对象进行读取和更新操作。 -
线程间通信:AtomicReference 主要用于实现在多线程环境下对共享变量的原子
操作,是一种并发编程的工具。 -
设置安全的变量后,如何取出?方法如下:
AtomicReference<JSONArray> shoppingCartIdListRef = new AtomicReference<>(new JSONArray(vars.get("shoppingCartIdList")));
JSONArray shoppingCartIdList = shoppingCartIdListRef.get();
-
通过AtomicReference方法可以保障线程并发场景下使用的全局变量设置方式在共享变量间每个线程各自取自己的,不会出现变量混乱的情况。
更多测试技术分享、学习资源以及一些其他福利可关注公众号:【Coding测试】获取: