OSGI中使用DS的类对象有关问题

OSGI中使用DS的类对象问题
DS方式生成component的使用一直有一个问题不求甚解,我写了一个简单的例子来说明。 

写了一个IHello.java接口 


public interface IHello {  
    public void sayHello();  
}
  



写了一个Speaker.java类包含IHello接口对象 

public class Speaker {  
      
    private IHello iHello=null;  
  
    public IHello getiHello() {  
        return iHello;  
    }  
  
    public void setiHello(IHello iHello) {  
        System.err.println("iHello---------- "+iHello);  
        System.err.println("speaker== "+this);  
        this.iHello = iHello;  
    }  
      
    void AAA(){  
        System.err.println("AAA");  
//      this.getiHello().sayHello();  
    }  
  
    void BBB(){  
        System.err.println("BBB");  
    }  
}
  


其ds实现的component.xml为 

<?xml version="1.0" encoding="UTF-8"?>  
<scr:component xmlns:scr="http://www.osgi.org/xmlns/scr/v1.1.0" activate="AAA" deactivate="BBB" name="Speaker">  
   <implementation class="com.kedong.test.Speaker"/>  
   <reference bind="setiHello" cardinality="1..1" interface="com.kedong.test.IHello" name="helloService" policy="static"/>      
</scr:component>



实现接口的类JapaneseHello.java为 

public class JapaneseHello implements IHello{  
  
    @Override  
    public void sayHello() {  
        // TODO Auto-generated method stub  
        System.err.println("con ni chi wa------------!!!");  
    }  
  
}
  


该类提供服务的component.xml为 

<scr:component xmlns:scr="http://www.osgi.org/xmlns/scr/v1.1.0" name="JapaneseHello">  
   <implementation class="Japanesehello.JapaneseHello"/>  
   <service>  
      <provide interface="com.kedong.test.IHello"/>  
   </service>  
</scr:component>
  


问题是我知道此时通过Speaker的set方法可以实例化得到IHello的对象JapaneseHello 

但是如何得到此时的Speaker对象呢,如果Speaker类里面的IHello对象不是静态的话,我每次new出的Speaker对象都是空的?难道只能再将Speaker也作为一个服务通过component.xml提供出来作为服务使用?? 

其实很多情况只是想每个new出来Speaker对象中包含一个JapaneseHello 对象 
而已,如何实现?
------解决思路----------------------
1.服务引用的配置要改一下,要么配成基于事件的,要么配成基于lookup的。
可以 参照http://www.ibm.com/developerworks/cn/opensource/os-ecl-osgids/这篇文章
2.Speaker对象的获取一般是不必要的,使用静态方法对外暴露服务接口,就可以满足需求,服务本身也要求是唯一的,静态方法正与之对应。
使用一些技巧也是可以达到这个目的。在Speaker的构造函数中赋值this给一个静态field,并对外提供静态field的访问,就把自己暴露给外面了。