关于并发,多线程的一些理解
2014-08-27 18:37
274 查看
一直感觉多线程和并发之类,是比较高大上的东西,稍微有点敬而远之.但是还是要了解一下.提高一下的.
并发的概念就不说了,举例说明吧. 2个人同时登录一个网站,都要调用 user.login方法.就并发了.
多线程是并发的一种解决方案,并发还有很多其他层次和类别的解决方案,就不讨论了.
以前一直想一个问题,我要做个用户登录,如果2个用户同时登录,就是并发了,我的login方法是否要对并发做处理呢?
其实所有方法都会有这个问题,我平时开发是否都要考虑呢?
针对这个问题,下面就记录下我这些天的一些理解:
以tomcat为例,默认的话会有一个连接池,有默认的连接数量等等设置.
当2个人同时登录时,会有2个线程同时请求user.login方法. 程序同一时间只有一个线程在执行(多核CPU好像会多个,这里不考虑)
我们用 Thread.currentThread().getName() 可以得到线程名称.
这里就用到了另外一个知识点, 全局变量和局部变量
全局变量,所有线程共享,
局部变量,每个线程私有.
当user.login方法,需要修改全局变量的时候,就会引发线程同步的问题了.否则可以不需要.
我们平时写的很多方法,不考虑并发, 可能就是因为操作的全部是局部变量,不会牵扯到线程同步的问题.
这应该也是很多人不鼓励使用全局变量的原因.
但是我们的大部分方法,应该还是要操作数据库,那我们需要线程同步吗?
这其实就看是否需要线程共享数据.
例如每个人登录系统,都需要到数据库记录一条日志, 每个线程记录自己的,互不相干,就不需要线程同步.
如果每个人登录系统,都需要查询已经有多少日志,并记录,(其他线程可能影响到当前线程的结果),则应该同步处理.
总结一下就是:
如果资源需要线程间共享,则需同步.
这里也有特殊的情况,就像我们系统,使用oracle的序列来做主键id, 因为oracle保证了序列的唯一性,所以代码中就不用再进行同步.
并发的概念就不说了,举例说明吧. 2个人同时登录一个网站,都要调用 user.login方法.就并发了.
多线程是并发的一种解决方案,并发还有很多其他层次和类别的解决方案,就不讨论了.
以前一直想一个问题,我要做个用户登录,如果2个用户同时登录,就是并发了,我的login方法是否要对并发做处理呢?
其实所有方法都会有这个问题,我平时开发是否都要考虑呢?
针对这个问题,下面就记录下我这些天的一些理解:
以tomcat为例,默认的话会有一个连接池,有默认的连接数量等等设置.
当2个人同时登录时,会有2个线程同时请求user.login方法. 程序同一时间只有一个线程在执行(多核CPU好像会多个,这里不考虑)
我们用 Thread.currentThread().getName() 可以得到线程名称.
这里就用到了另外一个知识点, 全局变量和局部变量
全局变量,所有线程共享,
局部变量,每个线程私有.
当user.login方法,需要修改全局变量的时候,就会引发线程同步的问题了.否则可以不需要.
我们平时写的很多方法,不考虑并发, 可能就是因为操作的全部是局部变量,不会牵扯到线程同步的问题.
这应该也是很多人不鼓励使用全局变量的原因.
但是我们的大部分方法,应该还是要操作数据库,那我们需要线程同步吗?
这其实就看是否需要线程共享数据.
例如每个人登录系统,都需要到数据库记录一条日志, 每个线程记录自己的,互不相干,就不需要线程同步.
如果每个人登录系统,都需要查询已经有多少日志,并记录,(其他线程可能影响到当前线程的结果),则应该同步处理.
总结一下就是:
如果资源需要线程间共享,则需同步.
这里也有特殊的情况,就像我们系统,使用oracle的序列来做主键id, 因为oracle保证了序列的唯一性,所以代码中就不用再进行同步.
相关文章推荐
- 关于多线程并发包的一些学习理解(java.util.concurrent)
- 关于并行、并发与多线程的一点理解
- 关于并行、并发与多线程的一点理解
- 转载:关于多线程,并发、并行、同步、异步的理解
- 关于3种方式写多线程的一些理解
- Java中关于同步,异步,多线程,多线程同步,并发,并行的一些总结
- 关于JavaBean的一些理解
- 关于多线程的一些细节
- 关于new、delete和堆的一些理解
- 关于bitmap的一些理解
- [转]关于多线程并发:每个开发人员都应了解的内容
- 关于多线程的一些细节
- 关于SAX,DOM,JAXP,JDOM,DOM4J的一些理解
- 关于多重继承的一些理解
- 关于多线程的一些细节
- 关于多线程的一些细节
- 关于C#3.0和.net一些问题的理解
- 关于内核中spinlock的一些个人理解
- 什么是工作流,关于工作流的一些理解
- 关于SAX,DOM,JAXP,JDOM,DOM4J的一些理解