您的位置:首页 > 其它

关于并发,多线程的一些理解

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保证了序列的唯一性,所以代码中就不用再进行同步.
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: