前言
首先我們要知道setTag方法是干什么的,SDK解釋為
Tags
Unlike IDs, tags are not used to identify views. Tags are essentially an extra piece of information that can be associated with a view. They are most often used as a convenience to store data related to views in the views themselves rather than by putting them in a separate structure.
Tag不像ID是用標示view的。Tag從本質上來講是就是相關聯的view的額外的信息。它們經常用來存儲一些view的數據,這樣做非常方便而不用存入另外的單獨結構。
convertView中的TAG
1.對於使用了LayoutInflater對象進行View擴充的Tag的使用
在之前,在adapter中,我們在getView中是這么些的代碼:
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder = null;
if (convertView == null) {
holder = new ViewHolder();
convertView = inflater.inflate(R.layout.vlist2, null);
holder.img = (ImageView) convertView.findViewById(R.id.img);
holder.title = (TextView) convertView.findViewById(R.id.title);
holder.info = (TextView)
convertView.findViewById(R.id.info);
// setTag的妙用
convertView.setTag(holder);
} else {
// setTag的妙用
holder = (ViewHolder) convertView.getTag();
}
……略
}
注意標紅的地方,他們是使用了Tag的。
首先我們要知道setTag方法是干什么的,他是給View對象的一個標簽,標簽可以是任何內容,我們這里把他設置成了一個對象,因為我們是把vlist2.xml的元素抽象出來成為一個類ViewHolder,用了setTag,這個標簽就是ViewHolder實例化后對象的一個屬性。我們之后對於ViewHolder實例化的對象holder的操作,都會因為java的引用機制而一直存活並改變convertView的內容,而不是每次都是去new一個。我們就這樣達到的重用——我希望我說清楚了。如果有更簡單的解釋,請指教。
這是我們在Adapter中的使用,那么我們在這里不使用Tag標簽會怎么樣呢?
我們試想,如果我們不用Tag標簽,那么我們的對象如何與convertView緩存結合並達到合理的效率利用?貌似答案並不明朗——所以使用Tag是比較明智的做法。
2.對於沒有使用LayoutInflater對象進行View擴充的Tag的使用。
if (convertView != null) {
view = convertView;
...
} else {
view = new Xxx(...);
...
}
這是我們的程序,我們看到,貌似沒有用Tag——是的,當沒有使用LayoutInflater進行View的擴充的時候,是沒有必要用的,雖然也可以用。
3. 對於其他View的Tag使用
我們可以對所有的View對象進行操作,至於怎么用,就看作者怎么想的了,下面舉例說一個View的子類button對於tag的一個使用。
直接貼代碼了:
public class ButtonTagTestActivity extends Activity implements OnClickListener {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
Button button1 = (Button) findViewById(R.id.button1);
Button button2 = (Button) findViewById(R.id.button2);
Button button3 = (Button) findViewById(R.id.button3);
button1.setTag(1);
button2.setTag(2);
button3.setTag(3);
button1.setOnClickListener(this);
}
@Override
public void onClick(View arg0) {
// TODO Auto-generated method stub
int tag = (Integer) arg0.getTag();
switch (tag) {
case 1: {
Toast.makeText(this, "我是button1", Toast.LENGTH_LONG).show();
break;
}
case 2: {
Toast.makeText(this, "我是button2", Toast.LENGTH_LONG).show();
break;
}
case 3: {
Toast.makeText(this, "我是button3", Toast.LENGTH_LONG).show();
break;
}
default: {
break;
}
}
}
}
Xml頁面代碼就不貼了。這個例子是點擊界面上的3個button然后會顯示用戶點擊的按鈕。我們的程序是實現了頁面全局監聽,在監聽前設置了每個button的tag,之后我們在switch的時候,使用getTag取出的標簽來看是什么操作。
這樣做的好處是可以將監聽集中管理,提高代碼的易讀性——當然,這是我的自我理解。
后記
看了這么多的實例,我想已經明白了Tag以及convertView。
對我們知道了Tag的作用就是設置標簽,標簽可以是任意玩意。
以及convertView是如何在程序中使代碼運行變的效率的:利用緩存convertView盡可能少實例化同樣結構體的對象;
http://blog.csdn.net/dinko321/article/details/7329504
from:http://blog.sina.com.cn/s/blog_4f1c99de01015skb.html