- 浏览: 282620 次
- 性别:
- 来自: 杭州
文章分类
- 全部博客 (153)
- unix (2)
- sql (3)
- pl/sql (1)
- cvs (1)
- core java (36)
- OOAD UML (1)
- XML (4)
- JDBC (5)
- Hibernate (1)
- HTML (1)
- javascript (2)
- servlet (2)
- jsp (1)
- AJAX (1)
- Struts1.x (0)
- Struts2.x (5)
- Spring (6)
- EJB (2)
- WebService (2)
- 生活 (2)
- 感情 (0)
- 其他 (9)
- jbuilder2005 (1)
- db2 (1)
- groovy (1)
- 银行业务 (1)
- Android (9)
- java设计模式 (8)
- J2SE (2)
- DataBase (4)
- lucene (2)
- java卡 (1)
- flex (3)
- 烹饪 (1)
- 测试 (1)
- java硬件 (2)
- upnp (3)
- S2SH lib (1)
- nio CshBBrain (1)
- socket (1)
- 二维码 (1)
- 热加载 (1)
- hadoop (3)
- NIO (1)
- 新银行前置机预研 (1)
- springmvc3 (1)
- jvm (1)
- sf (0)
最新评论
-
niwowl:
可以!
gson使用在android使用例子 -
smallbee:
xin_jmail 写道首先感谢楼主的文章,让我知道了lock ...
java ReentrantLock Condition调试记录 -
xin_jmail:
首先感谢楼主的文章,让我知道了lock.newConditio ...
java ReentrantLock Condition调试记录 -
smallbee:
brad2309 写道lz 你的两个messageReceiv ...
基于Apache Mina实现的TCP长连接和短连接实例 -
brad2309:
lz 你的两个messageReceived方法是不是错乱了
基于Apache Mina实现的TCP长连接和短连接实例
package com.yuan; import java.io.Serializable; import java.util.concurrent.ArrayBlockingQueue; import java.util.concurrent.ThreadPoolExecutor; import java.util.concurrent.TimeUnit; public class TestThreadPool { private static int produceTaskSleepTime = 3000; private static int consumeTaskSleepTime = 2000; private static int produceTaskMaxNumber = 1; public static void main(String[] args) { // 构造一个线程池 ThreadPoolExecutor threadPool = new ThreadPoolExecutor(2,4, 3, TimeUnit.SECONDS, new ArrayBlockingQueue<Runnable>(3), new ThreadPoolExecutor.DiscardOldestPolicy()); for (int i = 1; i <= produceTaskMaxNumber; i++) { try { // 产生一个任务,并将其加入到线程池 String task = "task@ " + i; User u = new User(); u.setId(1); u.setName("yqf"); System.out.println("put " + task); ThreadPoolTask t = new ThreadPoolTask(u); threadPool.execute(t); // 便于观察,等待一段时间 Thread.sleep(produceTaskSleepTime); System.out.println("MAIN TASK:"+ u.getName()); System.out.println(" t user: " + t.getUser().getName()); } catch (Exception e) { e.printStackTrace(); } } } /** * 线程池执行的任务 * @author hdpan */ public static class ThreadPoolTask implements Runnable, Serializable { private static final long serialVersionUID = 0; // 保存任务所需要的数据 private User threadPoolTaskData; ThreadPoolTask(User tasks) { this.threadPoolTaskData = tasks; } public void run() { // 处理一个任务,这里的处理方式太简单了,仅仅是一个打印语句 System.out.println("start .." + threadPoolTaskData); /*try { // //便于观察,等待一段时间 Thread.sleep(consumeTaskSleepTime); } catch (Exception e) { e.printStackTrace(); }*/ System.out.println("ThreadPoolTask task:" + threadPoolTaskData); threadPoolTaskData = null; //threadPoolTaskData.setName("3333"); } public User getUser(){ return threadPoolTaskData; } } }
以上代码是主线程构造一个User对象,将user对象传入线程,线程里面对user进行了=null操作。然后回主线程,发现去取System.out.println("MAIN TASK:"+ u.getName());
的时候,还是可以取到,但是调用System.out.println(" t user: " + t.getUser().getName());
确实空指针。
而且如果你在子线程里面对user进行了修改名字操作,System.out.println("MAIN TASK:"+ u.getName());
也是可以找到子线程操作后的user的。
不明白为何会这样??
发表评论
-
bike1
2015-12-07 17:10 0rt -
GPRS打印机的原理
2015-07-31 09:09 753一、什么是GPRS无线打印 ... -
关于 expression="execution(* com.xy.service.*.*(..))"
2015-05-21 09:22 2661先来看看这个spring的配 ... -
md5 sha1 java和javascript实现
2015-05-21 08:11 878<%@ page language="ja ... -
RSA帮助类
2014-11-21 09:36 925package com.cmb.fmserver.passp ... -
src2014-2-17
2014-02-17 21:55 0rt -
springmvc例子
2014-02-11 11:09 0rt -
qhdescjyw
2014-02-11 10:33 0rt -
按字节截取含有中文汉字的字符串
2013-05-07 18:55 3103要求实现一个按字节截取字符串的方法,比如对于字符串&quo ... -
SSL多线程安全问题
2013-04-23 15:44 1760项目原因,代码实现 ... -
wait notify 对象锁
2013-03-14 15:21 1162通常,多线程之间需要协调工作。例如,浏览器的一个显示图片的 ... -
eclipse下配置hadoop环境
2012-12-05 11:44 1415按照http://smallbee.iteye.com ... -
centos虚拟机上安装运行hadoop(伪分布)
2012-11-15 15:28 19611、先在确认能否不输入口令就用ssh登录localhost: ... -
nio 远程主机强迫关闭了一个现有的连接 解决方案
2012-10-17 12:37 4603nio编程过程中会出现: Exception in thre ... -
java nio过程
2012-10-17 11:32 12371、服务端:ServerSocketChannel进行监听,注 ... -
socket 客户端连接池实现
2012-10-15 16:58 6716本文参考:http://cache.baidu.com/c?m ... -
java dom 解析xml例子
2012-08-02 14:09 1560XML格式如下: <?xml version=&quo ... -
DM5 java 例子
2012-08-02 10:38 1247package com.cmb.fbcbcserver; ... -
HTTP短连接模拟长连接 连接数不能超过2个
2012-08-01 15:47 2029项目中有用到服务器推技术,也是由于环境因素,银行系统,行内机房 ... -
java注解使用例子
2012-07-30 11:50 11821、注解定义: import java.lang.annot ...
相关推荐
事件对象可以用于同步开始或结束操作,或者作为信号机制。 4. **等待定时器内核对象**:等待定时器允许线程在一定时间后被唤醒,或者在被通知后立即唤醒。这对于实现超时机制非常有用,可以防止线程无限制地等待。 ...
线程互斥对象允许我们限制对共享资源的访问,防止多个线程同时访问同一资源,从而避免数据竞争和不一致状态。 1. **线程互斥对象(Mutex)**: 线程互斥对象是一种同步机制,当一个线程获得了Mutex的所有权后,...
"多线程事件对象通讯"的示例,如`vc技术内幕11章例子`所示,深入探讨了如何在Visual C++(VC)环境下利用事件对象进行线程间的交互。 事件对象有三种状态:信号状态(Signaled State)和非信号状态(Non-Signaled ...
线程调用类对象 在前面的示例中,我们为线程任务使用了通常的函数。实际上,我们可以使用任何可调用对象或者lambda函数,如下调用类对象的例子: #include #include class MyFunctor { public: void operator()...
例如,使用`lock`关键字可以确保在同一时刻只有一个线程能够访问特定对象: ```csharp lock (myObject) { // 临界区代码,只允许一个线程执行 } ``` **线程池**是C#中管理线程的一种高效方式,通过`ThreadPool`类...
### Java多线程操作数据库:深入解析与应用 在当今高度并发的应用环境中,Java多线程技术被广泛应用于处理数据库操作,以提升系统的响应速度和处理能力。本文将基于一个具体的Java多线程操作数据库的应用程序,深入...
在C++编程中,面向对象和多线程是两个重要的概念,它们对于开发高效、并发的软件至关重要。本文将深入探讨这两个主题,并结合C++语言特性进行详细解释。 首先,让我们了解一下面向对象编程(Object-Oriented ...
内核对象是操作系统维护的一类特殊数据结构,它们允许线程通过内核模式的交互来协调同步行为。这些对象包括进程、线程、事件、信号量、互斥量、定时器等,它们都有一个“通知”或“未通知”的状态,这个状态的变化由...
Delphi提供了各种同步对象,如TCriticalSection、TSemaphore、TMutex等,来实现线程同步。例如,TCriticalSection用于在多线程中保护临界区,确保同一时间只有一个线程能进入该区域。使用TryEnterCriticalSection和...
6. **事件对象**:在某些情况下,可能还需要使用事件对象(如`std::condition_variable`)来同步线程间的操作。例如,当线程需要等待某个条件满足时,可以使用`wait()`函数释放互斥量并挂起线程,而其他线程可以使用...
在本文中,我们将深入探讨如何使用面向对象编程和多线程技术来设计一个电梯系统,以实现高效且并发的操作。这个项目是基于VC6.0开发环境,它是一款经典的Microsoft Visual C++集成开发环境,虽然现在已经有些过时,...
创建新的线程时需要注意,对UI的操作必须在UI线程中进行。 7. **Worker线程**: - Worker线程是负责执行后台任务的线程,不直接与用户交互。它们通常用于执行计算密集型任务或长时间运行的任务,以免阻塞UI线程。 ...
本示例"java多线程的条件对象和锁对象demo"着重探讨了如何利用锁对象和条件对象来精细控制线程的执行流程。 首先,我们需要了解Java中的锁对象。Java提供了多种类型的锁,其中最基础的是`synchronized`关键字,它...
特别是当对象可能在多线程环境中被访问时,必须确保在销毁对象之前,所有对对象的引用都被正确地释放。传统的互斥器(Mutex)并不能完全解决这个问题,因为互斥器只能控制对对象的访问,而无法控制对象的生命周期。 ...
`CMutex`的工作原理类似于互斥锁,通过获取和释放互斥对象的拥有权来控制对资源的访问。当一个线程获得了`CMutex`,其他尝试获取的线程将会被阻塞,直到拥有者释放。 在“ThreadProblem1”的代码示例中,可能包含了...
在C++11标准中引入了对线程的支持,并且在后续版本中不断改进。通过使用`<thread>`库,开发者可以轻松地创建和管理线程,实现更高效的应用程序。 ##### 线程基础 - **线程对象**:`std::thread`是C++标准库中用于...
本教程将深入探讨四种常见的线程同步机制:事件对象、信号量、互斥量以及临界区,帮助开发者理解和掌握如何在VC++中安全地实现多线程通信。 一、事件对象 事件对象是Windows API中用于线程间通信的一种同步机制。它...
这种数据结构允许多个线程同时读取,而对写入操作则采用锁定或其他同步机制,保证数据的一致性。 综上所述,"STA客户跨线程调用STA对象"涉及到COM编程中的线程模型、消息循环、跨线程通信机制以及同步原语的使用。...
《C++面向对象多线程编程》共分13章,全面讲解构建多线程架构与增量多线程编程技术。第1章介绍了用于构建面向对象程序的不同类型C++组件,以及如何使用这些组件来构建多线程架构。第2、3、4章简要介绍进程、线程、多...
通过对“线程的互斥”这一实验的学习,我们不仅掌握了如何在Windows系统环境中创建和管理线程,更重要的是学会了使用临界区对象或互斥对象来避免竞态条件,确保多线程环境下的数据一致性。这对于软件开发特别是并发...