`
shiqiang1
  • 浏览: 4096 次
  • 性别: Icon_minigender_1
  • 来自: 青岛
社区版块
存档分类
最新评论

springmvc多线程并发的问题

阅读更多

 下面的类直接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、求解

 

0
0
分享到:
评论
2 楼 dongjun316 2016-08-01  
System.out是单例的吧
1 楼 田梦桦 2016-08-01  
单例不是线程安全的,配置成多例是线程安全的

相关推荐

    SpringMVC简介与多线程解决方案

    通过这种方式,SpringMVC与多线程结合,可以优化复杂的Web应用程序,提升并发处理能力,为高并发场景提供更佳的性能表现。在实际项目中,还需要根据业务需求和系统资源进行合理的线程管理和优化。

    springMVC+多线程+kafka的 demo基于maven

    - 使用多线程可以提高应用程序的并发性,充分利用多核CPU资源,提高程序运行效率。 - 线程池是管理线程的一种机制,可以避免频繁创建和销毁线程带来的开销。Java中的`ExecutorService`和`ThreadPoolExecutor`是...

    springmvc配置线程池Executor做多线程并发操作的代码实例

    SpringMVC配置线程池Executor做多线程并发操作的代码实例 在本文中,我们将探讨如何使用SpringMVC框架来配置线程池Executor,以实现多线程并发操作。线程池Executor是Spring框架提供的一种线程池实现,它允许我们在...

    多线程列子多线程列子多线程列子

    通过这种方式,多线程可以在一个程序中并发执行不同的任务,从而提高程序的响应速度和处理能力。 二、多线程的作用 1. 提高程序响应性:当一个线程在等待I/O操作(如网络通信或磁盘读写)时,其他线程可以继续执行...

    多线程实例,线程实例

    在计算机编程领域,多线程是一种并发执行任务的技术,它允许多个任务或子任务同时在单个程序中运行。这种技术尤其在处理CPU密集型和I/O密集型...在学习和实践中,需要特别关注线程安全问题,避免出现意外的并发问题。

    springmvc+spring线程池处理http并发请求数据同步控制问题

    同时,Spring框架提供的线程池功能则可以帮助我们优化多线程环境下的性能,特别是处理并发请求时。在这个主题中,我们将深入探讨如何利用Spring MVC与Spring线程池来有效地管理并发请求,并解决数据同步控制问题。 ...

    Spring3.0 mvc 定时器及多线程任务demo

    定时器可以帮助我们定期执行特定任务,而多线程则可以提高程序并发能力,减少等待时间。通过合理利用这两个特性,我们可以构建出更健壮、高效的Web应用程序。在实际开发中,应根据具体需求选择合适的定时策略和...

    SpringMVC+sqlitejdbc的jar集合

    - SQLite不支持多线程写入,所以在并发较高的场景下可能不是最佳选择。 - 虽然SQLiteJDBC能简化数据库操作,但它的性能和功能可能不如大型数据库系统如MySQL或Oracle。 - 使用SpringMVC时,合理配置...

    java并发工具类

    Java并发工具类是Java平台提供的一系列用于处理多线程并发问题的类和接口,它们在`java.util.concurrent`包中。并发问题主要包括资源竞争、死锁、活锁以及饥饿等,合理使用并发工具可以有效地提高程序的并发性能并...

    高并发秒杀案例

    这里,我们将围绕“高并发秒杀案例”这一主题,结合使用SpringMVC和Mybatis两大技术框架,深入探讨如何设计和实现一个能够承受高并发压力的秒杀功能。 首先,我们需要理解SpringMVC作为一款强大的Web MVC框架,它...

    maven管理的Spring多线程任务demo

    在SSM(Spring、SpringMVC、MyBatis)框架背景下,如果你已经有所了解,那么这个例子将帮助你进一步理解Spring框架中的多线程处理。 首先,Maven是基于项目对象模型(Project Object Model,POM)的概念,通过XML...

    java面试题,ava核心知识 集合框架、JVM机制、多线程与并发框架、网络协议、SSM框架、MySQL、分布式、微服务、高并发

    3. **多线程与并发框架**:Java提供了丰富的多线程支持,如Thread类、Runnable接口、synchronized关键字、volatile变量和Lock接口。并发框架如ExecutorService和Future,帮助开发者构建高性能的并发应用。 4. **...

    SpringMvc(4.0)+hibernate(4.0)

    在 Hibernate 4.0 版本中,改进了对 JPA 2.0 的支持,引入了更灵活的查询语言 HQL 和 Criteria API,以及对多线程和并发的优化。在这个项目中,Hibernate 4.0 被用来管理数据库操作,包括创建、读取、更新和删除...

    SpringMVC+mongodb应用实例

    在"测试数据多线程生产"部分,我们将学习如何在并发环境中创建和管理数据。在多线程环境下,数据一致性、锁的使用以及事务管理成为关键问题。MongoDB虽然不支持传统的关系型数据库ACID(原子性、一致性、隔离性、...

    SpringMVC面试专题及答案.pdf

    - **潜在问题**:单例模式下的控制器可能会出现线程安全问题,特别是在处理多个并发请求时。 - **解决方案**:为了避免线程安全问题,通常不推荐在控制器中使用实例变量。如果确实需要维护状态,可以考虑使用其他...

    WebChatDemo_聊天_springmvc_网页端聊天室_DEMO_stockuu5_

    综上所述,这个项目是一个使用SpringMVC框架构建的网页端聊天室DEMO,具备多线程支持以实现在线互动聊天。通过分析源代码和配置文件,我们可以学习到如何在Web环境中集成WebSocket或其他实时通信技术,实现用户间的...

    SpringMVC精品资源-- 整合IDEA+Maven+SSM框架的高并发的商品秒杀项目.zip

    这涉及到线程安全、锁机制、队列设计、数据库事务控制等多个并发编程知识点。项目可能使用了如Redis缓存来减轻数据库压力,或者利用分布式锁避免重复秒杀。 6. **负载均衡与集群**:为了应对高并发,项目可能还涉及...

    java多线程实现下载图片并压缩

    本文旨在详细探讨Java多线程在实现下载图片并进行压缩的具体实现方法,并提供了SpringMVC定时任务、FTP环境搭建的参考,旨在为有此类需求的开发者提供实用的参考。 首先,需要创建一个SpringMVC定时任务,这允许...

    springmvc4-spring4-ibatis3.zip

    同时,JDK 8的并发库改进也有助于提高多线程应用的效率。 **lib目录** 在"lib"目录下,通常会包含项目所需的所有第三方库,如Spring、iBatis和其他依赖的JAR文件。这些库文件是运行和构建项目所必需的,确保了所有...

Global site tag (gtag.js) - Google Analytics