內部類怎麼傳遞引數給外部類???
阿新 • • 發佈:2018-12-26
參考連結:http://wendal.net/404.html
傳入:
//匿名內部類,只能訪問final的本地變數及方法引數
public void addUser(final String name, String passwd, final String userType) {
User user = null;
if ("admin".equal(userType))
user = new AdminUser(name, passwd); //僅作演示.
else
user = new User(name, passwd);
final User _user = user; //因為user變數不能設定為final,所以需要新加一個變數來中轉
Trans.run(new Atom(){
public void run() {
dao.insert(_user);
if (log.isDebugEnable())
log.debugf("Add user id=%d, name=%s , type=%s", _user.getId(), name, userType);
}
});
}
傳出(獲取方法返回值等等):
方法1 – 物件陣列法 通過一個final的Object物件陣列,存放需要的值
public long countUser(final String userType) {
final Object[] objs = new Object[1];
Trans.run(new Atom(){
public void run() {
objs[0] = dao.count(User.class, Cnd.where('userType', '=', userType));
}
});
return ((Number)objs[0]).longValue();
}
方法2 – ThreadLocal法 通過一個ThreadLocal來存放結果,這個ThreadLocal可以是靜態的,供全app使用的
private static final ThreadLocal re = new ThreadLocal(); //自行補上泛型Object
public long countUser(final String userType) {
Trans.run(new Atom(){
public void run() {
re.set(dao.count(User.class, Cnd.where('userType', '=', userType)));
}
});
return ((Number)re.get()).longValue(); //嚴謹一點的話,應該將ThreadLocal置空
}
方法3 – Molecule法 Molecule類是Nutz內建的抽象類類,實現Runnable和Atom介面,添加了兩個獲取/設定值的方法.
public long countUser(final String userType) {
Molecule mole = new Molecule() { //需要自行補齊泛型
public void run() {
setObj(dao.count(User.class, Cnd.where('userType', '=', userType)));
}
};
Trans.run(mole);
return ((Number)mole.getObj()).longValue();
}
傳入:
//匿名內部類,只能訪問final的本地變數及方法引數
public void addUser(final String name, String passwd, final String userType) {
User user = null;
if ("admin".equal(userType))
user = new AdminUser(name, passwd); //僅作演示.
else
user = new User(name, passwd);
final User _user = user; //因為user變數不能設定為final,所以需要新加一個變數來中轉
Trans.run(new Atom(){
public void run() {
dao.insert(_user);
if (log.isDebugEnable())
log.debugf("Add user id=%d, name=%s , type=%s", _user.getId(), name, userType);
}
});
}
傳出(獲取方法返回值等等):
方法1 – 物件陣列法 通過一個final的Object物件陣列,存放需要的值
public long countUser(final String userType) {
final Object[] objs = new Object[1];
Trans.run(new Atom(){
public void run() {
objs[0] = dao.count(User.class, Cnd.where('userType', '=', userType));
}
});
return ((Number)objs[0]).longValue();
}
方法2 – ThreadLocal法 通過一個ThreadLocal來存放結果,這個ThreadLocal可以是靜態的,供全app使用的
private static final ThreadLocal re = new ThreadLocal(); //自行補上泛型Object
public long countUser(final String userType) {
Trans.run(new Atom(){
public void run() {
re.set(dao.count(User.class, Cnd.where('userType', '=', userType)));
}
});
return ((Number)re.get()).longValue(); //嚴謹一點的話,應該將ThreadLocal置空
}
方法3 – Molecule法 Molecule類是Nutz內建的抽象類類,實現Runnable和Atom介面,添加了兩個獲取/設定值的方法.
public long countUser(final String userType) {
Molecule mole = new Molecule() { //需要自行補齊泛型
public void run() {
setObj(dao.count(User.class, Cnd.where('userType', '=', userType)));
}
};
Trans.run(mole);
return ((Number)mole.getObj()).longValue();
}