假设有一台服务器,它的IIS上部署有一个Web应用程序-S,可以通过浏览器或其他方式进行访问。
假设有A、B、C三台电脑同时访问网站S,IIS接收到3个HTTP请求,然后分别为三个请求各建立一个线程,这样就实现了IIS同时处理多个请求的需求。
如果并发量很大,需要考虑分布式架构实现。
当存在多线程时,需要考虑线程安全问题:1.存在多线程并发访问;2.存在可修改的共享数据/单例。
1.栈内存数据分析
栈内存是多例的,JVM会为每个线程创建一个栈,其中的数据不是共享的.
方法中的局部变量存放在栈中,不是共享的,所以栈内存中的数据不存在线程安全问题.
2.堆内存数据分析
一个JVM只存在一个堆内存,堆内存是共享的.被创建的对象存放在对内存,堆内存的数据是多线程共享的,所以堆内存中的数据是存在线程安全的.
3.方法去数据分析
一个JVM只存在一个方法区,类,静态变量,常量存放在方法区,方法区是多线程共享的.常量是不能修改的,所以常量不存在线程安全问题.
静态变量是存在线程安全问题.
//解决方案:
//尽量不要创建单例类.
//尽量不用静态变量.
//加锁,串行化进行
synchronized(this)
{
username =_username;
}