`

多线程环境下,用户信息统计问题

阅读更多

使用nick和订单id来进行锁定,

如果锁定失败,那么等待.

 

Queue<Future<Boolean>> queue = new LinkedList<Future<Boolean>>();

final ConcurrentMap<String, String> buyerLock = new ConcurrentHashMap<String, String>();

for (final Trade tbTrade : tbTradeList) {

             

queue.offer(topExecutePool.submit(new Callable<Boolean>() {

public Boolean call() throws Exception {

try {

for(int j=0;j<10;j++){

String existBuyerNickTid = buyerLock.putIfAbsent(tbTrade.getBuyerNick(),""+tbTrade.getTid());

if(existBuyerNickTid==null){

break;

}

Thread.sleep(5*1000L);

continue;

}

           ..............................................

} catch (Exception e) {

logger.error(e);

}finally{

buyerLock.remove(tbTrade.getBuyerNick());

}

return Boolean.TRUE;

 

}

}));

}

分享到:
评论

相关推荐

    多线程打开TXT

    4. **线程同步与互斥**:在多线程环境中,数据安全和一致性是必须考虑的问题。为了防止多个线程同时访问同一资源(如TXT文件)导致的数据冲突,我们需要使用同步机制,如锁(Mutex)、信号量(Semaphore)或读写锁...

    LINUX下多线程编程

    ### LINUX下多线程编程详解 #### 一、引言 多线程技术自60年代初被提出以来,直到80年代中期才在操作系统层面...通过本篇文章的学习,希望读者能够理解多线程的基本概念,并掌握在Linux环境下进行多线程编程的方法。

    基于B/S的多线程学生成绩信息管理系统

    在多线程环境下,系统能有效地分配资源,提高并发性能,使得多个用户可以同时进行成绩录入、查询、修改等操作而互不干扰。这种设计提高了系统的响应速度和整体效率,避免了单线程模型中可能出现的阻塞问题,尤其在...

    JAVA多线程测试工具

    首先,Java多线程测试工具能够模拟大量并发用户对应用程序进行访问,这对于评估和优化系统在高负载情况下的性能至关重要。在互联网时代,服务的稳定性和响应速度直接影响用户体验,因此开发者需要确保系统在面对大...

    QNX环境下多线程编程.pdf

    在《QNX环境下多线程编程》这一主题中,我们探讨了在QNX实时操作系统(RTOS)中进行多线程编程的技术与实践。QNX系统以其高可靠性和实时性著称,广泛应用于嵌入式系统、汽车电子、医疗设备、航空航天等领域。多线程...

    [代码]在线统计+多线程模拟+单例

    在IT行业中,多线程和...其中可能使用了单例模式来管理统计服务,同时在多线程环境下保证了数据一致性。具体实现细节可能在`com`目录下的源代码文件中。学习和理解这些技术对于提升系统性能和设计能力具有重要意义。

    Linux下的多线程编程

    ### Linux下的多线程编程...通过上述示例可以看出,多线程编程在Linux环境下是非常实用且强大的,能够显著提升程序的性能和响应能力。然而,需要注意的是,合理地设计线程间的同步机制是保证多线程程序正确运行的关键。

    多线程和队列下载

    - **线程同步**:在多线程环境下,需要考虑线程间的同步问题,以防止数据冲突。可以使用`synchronized`关键字、`Lock`接口或者`Semaphore`等工具来实现。 - **线程池**:为了管理线程的创建和销毁,通常会使用...

    Linux 多线程 短消息缓存

    线程安全是多线程编程中非常关键的一个概念,意味着在多线程环境下,程序的行为不会因线程间的交互而变得不确定。在这个短消息缓存中,线程安全主要是通过互斥锁来实现的。在修改链表(如添加或删除消息)时,线程会...

    基于socket多线程图片传输程序

    "基于socket多线程图片传输程序"的项目就是一个典型的实例,它利用了C++编程语言(通过Visual C++,简称VC)来实现在局域网内高效传输图片的功能。这个程序的核心在于socket通信和多线程技术,这两者都是网络编程的...

    基于SOCKET和多线程的应用程序间通信技术的研究.pdf

    在多线程环境中,必须注意线程之间的同步和资源共享问题。为了避免数据竞争和死锁,可以使用互斥锁、信号量等同步对象来控制对共享资源的访问。合理设计线程间的通信机制,可以有效避免数据一致性问题,保证系统的...

    WIN API 蒙特卡洛法 多线程计算PI值

    通过本项目,初学者可以学习到如何在Windows环境下使用API进行多线程编程,以及如何应用蒙特卡洛方法解决实际问题。同时,这也是一种练习编程技巧和理解并发编程的好方式。在实际操作中,可以逐步改进代码,比如使用...

    多线程打字练习

    在多线程环境下,我们可以创建不同的线程来处理不同的任务。例如,一个线程负责显示文字,另一个线程负责接收用户的输入。这样,用户在看到新文字的同时可以继续输入,实现了打字练习的实时性。为了确保线程间的同步...

    易语言 利用超级列表框多线程参数传递文本

    3. **多线程处理文本**:在新线程中,可以读取大文本文件,进行处理,例如统计词频、分析内容等。使用`读文件`命令读取文本,配合`字符串处理`命令进行分析。 4. **更新超级列表框**:处理完数据后,线程需要将结果...

    多线程HTTP服务器源代码

    通过多线程,服务器能够同时处理多个用户的连接请求,避免了单线程模型中的串行执行问题,提高了服务响应速度。 从压缩包的文件名来看,我们可以推测这个项目包含了以下部分: 1. "http.bmp" 可能是一个与服务器...

    计算机网络安全课设-基于libpcap和winpcap的多线程网络包嗅探器

    内容概要:简洁的多线程网络包嗅探器 环境依赖: Python3 winpcap(if you are using Linux, please install libpcap) pcapy PyQt5 设计简介: 本次设计采用的编程语言为python。在Windows和Linux平台下先分别安装...

    1工作临时-servlet 多线程问题

    标题 "1工作临时-servlet 多线程问题" 暗示了我们在讨论Servlet在处理多线程环境下的挑战和解决方案。Servlet是Java Web开发中用于处理HTTP请求的服务端组件,常常需要处理并发请求,因此多线程是其核心特性之一。 ...

    三种排序方法比较的演示程序——Borland C++ Builder中的多线程应用

    通过将这些算法嵌入到多线程环境中,该演示程序不仅能够同时展示不同排序算法的工作过程,还能直观地比较它们的性能差异。 #### 关键知识点解析 ##### 1. 进程与线程概念 - **进程**:操作系统中运行的一个应用...

    VC编写的多线程抽签小工具

    《VC编写的多线程抽签小工具》 在信息技术领域,编程语言是构建软件的基础,而...通过分析和运行这个程序,开发者可以提升自己的编程技巧,理解多线程环境下的同步与通信,以及如何在实际应用中优化程序性能。

    百万知乎用户数据分析 这是一个多线程抓取知乎用户的程序 Requirements

    这是一个多线程抓取知乎用户的程序 Requirements 需要用到的包: beautifulsoup4 html5lib image requests redis PyMySQL pip安装所有依赖包: pip install Image requests beautifulsoup4 ...

Global site tag (gtag.js) - Google Analytics