覆盖 edtitext 的 getText() 方法会导致 stackoverflow,为什么?
overriding edtitext's getText() method causes stackoverflow, why?
我正在对 TextInputEditText 进行子类化,以便我可以将字符串添加到密码 editText 字段。这是子类:
public class CustomInputEditTextWithPrefix extends TextInputEditText {
public CustomInputEditTextWithPrefix(Context context) {
super(context);
}
public CustomInputEditTextWithPrefix(Context context, AttributeSet attrs) {
super(context, attrs);
}
public CustomInputEditTextWithPrefix(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
}
@Override
public Editable getText() {
Editable s = (Editable) super.getText(); //why is this causing infinite Whosebug ?
if(s!=null && s.length()>0) {
//salt the password
Editable pwSalt = new SpannableStringBuilder("my secret string");
s= pwSalt.append(s);
}
return s;
}
}
xml 中的实现是:
<com.myapp.ui.auth.ui.customviews.CustomInputEditTextWithPrefix
android:id="@+id/password"
android:inputType="textPassword" />
我的问题是,当我执行代码时,getText() 覆盖方法不断被一遍又一遍地调用。我取出了 inputType 但在 Whosebug 之前它仍然被调用。我的想法是在 TextInputEditText 中的每个字符串的前面附加一个秘密哈希。我做错了什么?
也许如果你跳过分配一个新值 s
一切都会好的
@Override
public Editable getText() {
Editable s = (Editable) super.getText();
if(s!=null && s.length()>0) {
//salt the password
return new SpannableStringBuilder("my secret string").append(s.toString());
}
return s;
}
我正在对 TextInputEditText 进行子类化,以便我可以将字符串添加到密码 editText 字段。这是子类:
public class CustomInputEditTextWithPrefix extends TextInputEditText {
public CustomInputEditTextWithPrefix(Context context) {
super(context);
}
public CustomInputEditTextWithPrefix(Context context, AttributeSet attrs) {
super(context, attrs);
}
public CustomInputEditTextWithPrefix(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
}
@Override
public Editable getText() {
Editable s = (Editable) super.getText(); //why is this causing infinite Whosebug ?
if(s!=null && s.length()>0) {
//salt the password
Editable pwSalt = new SpannableStringBuilder("my secret string");
s= pwSalt.append(s);
}
return s;
}
}
xml 中的实现是:
<com.myapp.ui.auth.ui.customviews.CustomInputEditTextWithPrefix
android:id="@+id/password"
android:inputType="textPassword" />
我的问题是,当我执行代码时,getText() 覆盖方法不断被一遍又一遍地调用。我取出了 inputType 但在 Whosebug 之前它仍然被调用。我的想法是在 TextInputEditText 中的每个字符串的前面附加一个秘密哈希。我做错了什么?
也许如果你跳过分配一个新值 s
一切都会好的
@Override
public Editable getText() {
Editable s = (Editable) super.getText();
if(s!=null && s.length()>0) {
//salt the password
return new SpannableStringBuilder("my secret string").append(s.toString());
}
return s;
}