当前位置:  技术问答>java相关

一个多线程搜索主机名(或IP地址)的问题

    来源: 互联网  发布时间:2015-06-04

    本文导语:  main()中建立一Vector pool存放全部待搜索的IP地址(设有50个),并创建5个线程,每个线程从pool中获取ip地址来搜索主机名,搜索结束后并不停止线程,继续从pool取IP,知道pool为空。 线程程序如下: public void run()...

main()中建立一Vector pool存放全部待搜索的IP地址(设有50个),并创建5个线程,每个线程从pool中获取ip地址来搜索主机名,搜索结束后并不停止线程,继续从pool取IP,知道pool为空。

线程程序如下:
public void run() 
{
   while (nIPSearched != nIP) 
  {
      synchronized (pool) 
     {

while (pool.isEmpty()) 
         {
              if (nIPSearched == nIP) return;
     try {
pool.wait();
              }
     catch (InterruptedException e) { }
}

String cIP = (String)pool.remove(pool.size()-1);

try {
    InetAddress address = InetAddress.getByName(cIP);
    String hostName = address.getHostName();
    this.incrementIPSearched();
    searchResult.add(hostName);
    this.incrementComputerFounded();
}

catch (UnknownHostException e) {
       System.out.println("wrong");
}
     }
  } // end first while
} // end run


设线程名分别是1,2,3,4,5。pool中的ip分别是a,b,c,d,e;f,g,h,i,j.....。
第一次从pool中取ip(a,b,c,d,e)后,线程1,2,4,5搜索任务较慢,运行时间长。线程3(任务c)搜索很快。我的问题是:线程3下次是取的是任务怎么是h,而不是g。

|
没看懂你想干什么,但用synchronized一直锁定pool对并行效率很不利

|
你的 notify()在哪里?

如jimjxr(宝宝猫) 所说,你这样的处理并不能提高多大效率,大家都得等待 pool的锁,不如模仿 NetAnts等的方法,把IP地址分成5份,各分给5个线程去查找 hostname.


    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Java中多线程相关类Thread介绍
  • 一个进程创建了两个线程,如何使得当任何一个线程(比如线程a)结束时,同时也结束线程b,也就是使两个线程一起死掉,怎么办呢?
  • c#多线程更新窗口(winform)GUI的数据
  • java 线程,对当前线程(非主线程)调用sleep,为什么主线程(窗口)也没反应了
  • Windows和Linux下C++类成员方法作为线程函数方法介绍
  • 如何实现一个线程组内多线程的非同不执行,即一个线程执行完毕后再执行下一个线程???
  • c++的boost库多线程(Thread)编程(线程操作,互斥体mutex,条件变量)详解
  • 请问:进程创建的线程是怎样运行的啊,线程的处理函数运行完了,线程就退出了吗?
  • Linux下GCC内置原子操作函数(多线程资源访问)介绍
  • 关于线程的问题,什么样的线程不是active线程?
  • 请问Linux核心支持多线程吗?开发库有线程库吗?线程好用吗?(稳定?)
  • 请问,在一个进程中创建多线程时如何能避免不同的线程获得同一个线程标识
  • 我的一个多线程服务里, 总是有一个线程莫名其妙的变成僵尸线程。
  • 能否通过线程id控制线程的状态?或是观察到线程的状态?
  • 如何在一个线程中启动另外一个线程,然后本线程就退出?
  • 我要设置一个线程的优先级, 这个属性结构并没有线程的id,它怎么知道是设置哪个线程呢?
  • 请问在java多线程中,是只有run(){}内的代码运行在一个新线程下呢?还是这个类中的代码都运行在一个新线程下?
  • gcc链接的库,分不分单线程版本的和多线程版本的?
  • 内核栈~ 内核线程 ~用户线程 之间关系 问题
  • 子线程的数据如何返回给主线程?
  • 如果父线程死掉 那么子线程会不会死掉呢


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3