`

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

阅读更多

使用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进行多线程编程,以及如何应用蒙特卡洛方法解决实际问题。同时,这也是一种练习编程技巧和理解并发编程的好方式。在实际操作中,可以逐步改进代码,比如使用...

    多线程打字练习

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

    多线程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