下面的类直接copy到eclipse中进行测试
---------------------------------下面是springmvc的请求类-------------------------
@Controller
@Scope("prototype")
@RequestMapping(value = "/${adminPath}/categoryController")
public class CategoryController extends BaseController {
/**
* Logger for this class
*/
private static final Logger logger = Logger.getLogger(CategoryController.class);
private static final String CATEGORY_LIST = "system/category/categoryList";
private static final String CATEGORY_ADD_OR_UPDATE = "system/category/category";
@Autowired
private CategoryServiceI categoryService;
@Autowired
private SystemService systemService;
//PrintName printName = new PrintName();
/**
* 分类管理列表 页面跳转
*
* @return
*/
@RequestMapping(params = "category")
public String category(HttpServletRequest request) {
PrintName printName = new PrintName();
printName.printName("shiqiang");
return CATEGORY_LIST;
}
}
-------------------------------------------下面是方被测试的方法-------------------------
由此检验是否有问题
public class PrintName {
//synchronized
public void printName(String name){
//synchronized(PrintName.class){
for(int i=0;i<name.length();i++){
System.out.print(name.charAt(i));
}
System.out.println("-----------");
//}
}
}
------------------------------------------下面是测试并发的请求类-------------------------------
其他的不用管,主要关注main方法里面的并发请求
package www.wifuns.com.runnable;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.net.URL;
import java.net.URLConnection;
import java.util.List;
import java.util.Map;
import java.util.concurrent.atomic.AtomicInteger;
public class BingFa {
private static AtomicInteger j =new AtomicInteger(0);
public static void main(String[] args) {
// //发送 GET 请求
// String s=BingFa.sendGet("http://localhost:6144/Home/RequestString", "key=123&v=456");
// System.out.println(s);
for(int i=0;i<300;i++){
new Thread(new Runnable(){
@Override
public void run() {
BingFa bf = new BingFa();
String sr=bf.sendPost("http://192.168.1.198/wuliu/wifuns/categoryController.do?category", "key=123&v=456");
System.out.println(sr);
j.incrementAndGet();
}
}).start();
}
try {
Thread.sleep(4000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println(j.get());
}
/**
* 向指定URL发送GET方法的请求
*
* @param url
* 发送请求的URL
* @param param
* 请求参数,请求参数应该是 name1=value1&name2=value2 的形式。
* @return URL 所代表远程资源的响应结果
*/
public String sendGet(String url, String param) {
String result = "";
BufferedReader in = null;
try {
String urlNameString = url + "?" + param;
URL realUrl = new URL(urlNameString);
// 打开和URL之间的连接
URLConnection connection = realUrl.openConnection();
// 设置通用的请求属性
connection.setRequestProperty("accept", "*/*");
connection.setRequestProperty("connection", "Keep-Alive");
connection.setRequestProperty("user-agent",
"Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");
// 建立实际的连接
connection.connect();
// 获取所有响应头字段
Map<String, List<String>> map = connection.getHeaderFields();
// 遍历所有的响应头字段
for (String key : map.keySet()) {
System.out.println(key + "--->" + map.get(key));
}
// 定义 BufferedReader输入流来读取URL的响应
in = new BufferedReader(new InputStreamReader(
connection.getInputStream()));
String line;
while ((line = in.readLine()) != null) {
result += line;
}
} catch (Exception e) {
System.out.println("发送GET请求出现异常!" + e);
e.printStackTrace();
}
// 使用finally块来关闭输入流
finally {
try {
if (in != null) {
in.close();
}
} catch (Exception e2) {
e2.printStackTrace();
}
}
return result;
}
/**
* 向指定 URL 发送POST方法的请求
*
* @param url
* 发送请求的 URL
* @param param
* 请求参数,请求参数应该是 name1=value1&name2=value2 的形式。
* @return 所代表远程资源的响应结果
*/
public String sendPost(String url, String param) {
PrintWriter out = null;
BufferedReader in = null;
String result = "";
try {
URL realUrl = new URL(url);
// 打开和URL之间的连接
URLConnection conn = realUrl.openConnection();
// 设置通用的请求属性
conn.setRequestProperty("accept", "*/*");
conn.setRequestProperty("connection", "Keep-Alive");
conn.setRequestProperty("user-agent",
"Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");
// 发送POST请求必须设置如下两行
conn.setDoOutput(true);
conn.setDoInput(true);
// 获取URLConnection对象对应的输出流
out = new PrintWriter(conn.getOutputStream());
// 发送请求参数
out.print(param);
// flush输出流的缓冲
out.flush();
// 定义BufferedReader输入流来读取URL的响应
in = new BufferedReader(
new InputStreamReader(conn.getInputStream()));
String line;
while ((line = in.readLine()) != null) {
result += line;
}
} catch (Exception e) {
System.out.println("发送 POST 请求出现异常!"+e);
e.printStackTrace();
}
//使用finally块来关闭输出流、输入流
finally{
try{
if(out!=null){
out.close();
}
if(in!=null){
in.close();
}
}
catch(IOException ex){
ex.printStackTrace();
}
}
return result;
}
}
----------------------------------------------------下面是输出结果-----------------------------
输出中有不规则的结果--是否说明了 并发的问题
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqishiqiang-----------
ang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqishiqiang-----------
shiqiang-----------
ang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shshiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
iqiang-----------
sshiqiang-----------
hiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
sshiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
hiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqishiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
ang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
shiqiang-----------
---------------------------------------------------------结论---------------------------------
1、按网上说的 这种情况应该是线程安全的。
2、但是按照上面测试情况好像不行呀。
3、如果在被测试的方法上添加 synchronized 结果是正常的
4、求解
相关推荐
通过这种方式,SpringMVC与多线程结合,可以优化复杂的Web应用程序,提升并发处理能力,为高并发场景提供更佳的性能表现。在实际项目中,还需要根据业务需求和系统资源进行合理的线程管理和优化。
- 使用多线程可以提高应用程序的并发性,充分利用多核CPU资源,提高程序运行效率。 - 线程池是管理线程的一种机制,可以避免频繁创建和销毁线程带来的开销。Java中的`ExecutorService`和`ThreadPoolExecutor`是...
SpringMVC配置线程池Executor做多线程并发操作的代码实例 在本文中,我们将探讨如何使用SpringMVC框架来配置线程池Executor,以实现多线程并发操作。线程池Executor是Spring框架提供的一种线程池实现,它允许我们在...
通过这种方式,多线程可以在一个程序中并发执行不同的任务,从而提高程序的响应速度和处理能力。 二、多线程的作用 1. 提高程序响应性:当一个线程在等待I/O操作(如网络通信或磁盘读写)时,其他线程可以继续执行...
在计算机编程领域,多线程是一种并发执行任务的技术,它允许多个任务或子任务同时在单个程序中运行。这种技术尤其在处理CPU密集型和I/O密集型...在学习和实践中,需要特别关注线程安全问题,避免出现意外的并发问题。
同时,Spring框架提供的线程池功能则可以帮助我们优化多线程环境下的性能,特别是处理并发请求时。在这个主题中,我们将深入探讨如何利用Spring MVC与Spring线程池来有效地管理并发请求,并解决数据同步控制问题。 ...
定时器可以帮助我们定期执行特定任务,而多线程则可以提高程序并发能力,减少等待时间。通过合理利用这两个特性,我们可以构建出更健壮、高效的Web应用程序。在实际开发中,应根据具体需求选择合适的定时策略和...
- SQLite不支持多线程写入,所以在并发较高的场景下可能不是最佳选择。 - 虽然SQLiteJDBC能简化数据库操作,但它的性能和功能可能不如大型数据库系统如MySQL或Oracle。 - 使用SpringMVC时,合理配置...
Java并发工具类是Java平台提供的一系列用于处理多线程并发问题的类和接口,它们在`java.util.concurrent`包中。并发问题主要包括资源竞争、死锁、活锁以及饥饿等,合理使用并发工具可以有效地提高程序的并发性能并...
这里,我们将围绕“高并发秒杀案例”这一主题,结合使用SpringMVC和Mybatis两大技术框架,深入探讨如何设计和实现一个能够承受高并发压力的秒杀功能。 首先,我们需要理解SpringMVC作为一款强大的Web MVC框架,它...
在SSM(Spring、SpringMVC、MyBatis)框架背景下,如果你已经有所了解,那么这个例子将帮助你进一步理解Spring框架中的多线程处理。 首先,Maven是基于项目对象模型(Project Object Model,POM)的概念,通过XML...
3. **多线程与并发框架**:Java提供了丰富的多线程支持,如Thread类、Runnable接口、synchronized关键字、volatile变量和Lock接口。并发框架如ExecutorService和Future,帮助开发者构建高性能的并发应用。 4. **...
在 Hibernate 4.0 版本中,改进了对 JPA 2.0 的支持,引入了更灵活的查询语言 HQL 和 Criteria API,以及对多线程和并发的优化。在这个项目中,Hibernate 4.0 被用来管理数据库操作,包括创建、读取、更新和删除...
在"测试数据多线程生产"部分,我们将学习如何在并发环境中创建和管理数据。在多线程环境下,数据一致性、锁的使用以及事务管理成为关键问题。MongoDB虽然不支持传统的关系型数据库ACID(原子性、一致性、隔离性、...
- **潜在问题**:单例模式下的控制器可能会出现线程安全问题,特别是在处理多个并发请求时。 - **解决方案**:为了避免线程安全问题,通常不推荐在控制器中使用实例变量。如果确实需要维护状态,可以考虑使用其他...
综上所述,这个项目是一个使用SpringMVC框架构建的网页端聊天室DEMO,具备多线程支持以实现在线互动聊天。通过分析源代码和配置文件,我们可以学习到如何在Web环境中集成WebSocket或其他实时通信技术,实现用户间的...
这涉及到线程安全、锁机制、队列设计、数据库事务控制等多个并发编程知识点。项目可能使用了如Redis缓存来减轻数据库压力,或者利用分布式锁避免重复秒杀。 6. **负载均衡与集群**:为了应对高并发,项目可能还涉及...
本文旨在详细探讨Java多线程在实现下载图片并进行压缩的具体实现方法,并提供了SpringMVC定时任务、FTP环境搭建的参考,旨在为有此类需求的开发者提供实用的参考。 首先,需要创建一个SpringMVC定时任务,这允许...
同时,JDK 8的并发库改进也有助于提高多线程应用的效率。 **lib目录** 在"lib"目录下,通常会包含项目所需的所有第三方库,如Spring、iBatis和其他依赖的JAR文件。这些库文件是运行和构建项目所必需的,确保了所有...