时光不散小青年 2015-08-14 09:46 采纳率: 0%
浏览 3001

急急急! 线程调用对象报空指针

先上代码。请看下面

 package com.socket.client;

import java.util.List;

import org.apache.log4j.Logger;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;

import com.socket.model.RequestCommand;
import com.socket.server.SocketServer;
import com.socket.service.RequestCommandService;

/** 
 * 启动端口监听入口
 * @author  JQ.Wang   E-mail:wang53400487@hotmail.com 
 * @date 创建时间:2015年8月13日 下午3:46:22 
 * @version 1.0 
 * @parameter  
 * @since  JDK1.7
 * @return  
 */
@Controller
public class RunSocket {

    protected static final Logger log=Logger.getLogger(RunSocket.class);

    private int port = 0;

    @Autowired
    private RequestCommandService requestCommandService;

    public void invoke(){
        new Thread(new Runnable() {

            @Override
            public void run() {
                System.out.println("=============================im here=====================");

                System.out.println(requestCommandService);

                List<RequestCommand> rcList=requestCommandService.findAllPort(); 
//              log.info("===========================将会启动监听的端口数量为:   "+rcList.size());
//              if (rcList.isEmpty()) {
//                  try {
//                      Thread.sleep(3000);
//                  } catch (InterruptedException e) {
//                      e.printStackTrace();
//                  }
//              }
//              for (RequestCommand requestCommand : rcList) {
//                  //把当前的端口号覆盖port
//                  port=requestCommand.getServer_port();
                    log.info("===========================正在启动的端口是:     "+port);
                    new Thread(new Runnable() {
                        @Override
                        public void run(){
                            log.info("===========================正在启动的端口是:     xxxxxx"+port);
                            new SocketServer().NioServer(8001);
                        }
                    }).start();
//              }
            }
        }).start();
    }
}

由于刚接触线程,线程代码方面的问题,各位朋友也可以指正下。

回归正题,问题出在调用 requestCommandService 时,报了空指针。

  1. =============================im here=====================
  2. Exception in thread "Thread-0" java.lang.NullPointerException
  3. at com.socket.client.RunSocket$1.run(RunSocket.java:44)
  4. at java.lang.Thread.run(Thread.java:745)

可以确认一点的是,这个Service已经注入容器中,因为在Controller类中能正确调用,

请各位大神,帮忙分析下问题所在,万分感谢!

  • 写回答

1条回答 默认 最新

  • devmiao 2015-08-14 23:14
    关注
    评论

报告相同问题?

悬赏问题

  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)