大四实习准备1_java构造器_android ListView
2015-4-23
Java构造器
与类名同名;无返回值(void也不行);被不同的修饰符修饰是有区别的;当构造函数被private修饰时,只有本类可访问。其他类可以通过该类的get函数得到对象。如单子模式;子类的构造函数默认调用super(),即父类的构造函数,然后再回到子类自己的构造函数。子类的构造函数中写了super()效果也一样,相当于没写(只能写在第一句,否则出错);构造函数可以重载(当父类有多个构造函数时,可以用super(xxx)来指定调用父类的哪个构造函数);当自定义了构造函数后,系统就不自动生成构造函数了。所以最好为每个类写无参构造函数,以免出错;运行过程:有继承关系时,1>初始化父类的静态块和静态成员变量 2>初始化子类的静态块和静态成员变量 3>执行父类的构造函数 4>执行子类的构造函数;
单子模式,是指一段时间内该类的对象只存在一份。
如
//test.java
class ace{
private static ace a;
private ace(){
System.out.println("1");
}
public static ace getAce(){
if( null == a ){
a = new ace();
}
return a;
}
} public class test{
public static void main(String[] args) {
//ace a = new ace();错
ace b = ace.getAce();
ace c = ace.getAce(); if( b==c )
System.out.println("equal");
}
}
单子模式
android ListView
1.简单的使用库本身的布局
把数据和布局塞到适配器里,把适配器塞到ListView里。
String[] data = {"1","2","3","4","5","6","7","8","9","1","2","3","4","5","6","7","8","9"};
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
ArrayAdapter<String> adapter = new ArrayAdapter<String>(MainActivity.this,
android.R.layout.simple_list_item_1,data);
ListView lv = (ListView)findViewById(R.id.listview);
lv.setAdapter(adapter);
};
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="${relativePackage}.${activityClass}" > <ListView
android:id="@+id/listview"
android:layout_width="match_parent"
android:layout_height="match_parent"
></ListView>
</RelativeLayout>
2.自定义每项的布局
自定义了布局diy_list_item、每一行数据的类fruit、继承自ArrayAdapter<fruit>的类fruitAdapter
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal" >
<ImageView
android:id="@+id/imageView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
/>
<TextView
android:id="@+id/textView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
/> </LinearLayout>
diy_list_item.xml
package com.example.listviewtest;
public class fruit {
private String name;
private int imageId;
public fruit(String name,int imageId){
this.name = name;
this.imageId = imageId;
}
public String getName(){
return name;
}
public int getImageId(){
return imageId;
}
}
fruit.class
package com.example.listviewtest; import java.util.List; import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.ImageView;
import android.widget.TextView; public class fruitAdapter extends ArrayAdapter<fruit>{ private int resourceId;
public fruitAdapter(Context context, int resource, List<fruit> objects) {
super(context, resource, objects);
// TODO Auto-generated constructor stub
resourceId = resource;
} @Override
public View getView(int position, View convertView, ViewGroup parent) {
// TODO Auto-generated method stub
fruit f = getItem(position);
View v ;
v = LayoutInflater.from(getContext()).inflate(resourceId, null);
ImageView fruitImage = (ImageView)v.findViewById(R.id.imageView);
TextView fruitName = (TextView)v.findViewById(R.id.textView);
fruitImage.setImageResource(f.getImageId());
fruitName.setText(f.getName());
return v;
}
}
fruitAdapter.class
package com.example.listviewtest; import java.util.ArrayList; import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.Toast; public class MainActivity extends Activity { ArrayList<fruit> fruitList = new ArrayList<fruit>();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initFruit();
fruitAdapter adapter = new fruitAdapter(MainActivity.this,
R.layout.diy_list_item,fruitList);
ListView lv = (ListView) findViewById(R.id.listview);
lv.setAdapter(adapter);
} private void initFruit(){
fruit one = new fruit("1",R.drawable._1);
fruitList.add(one);
fruit two = new fruit("2",R.drawable._2);
fruitList.add(two);
fruit three = new fruit("3",R.drawable._3);
fruitList.add(three);
fruit four = new fruit("4",R.drawable._4);
fruitList.add(four);
fruit five = new fruit("5",R.drawable._5);
fruitList.add(five);
fruit six = new fruit("6",R.drawable._6);
fruitList.add(six);
fruit seven = new fruit("7",R.drawable._7);
fruitList.add(seven);
fruit eight = new fruit("8",R.drawable._8);
fruitList.add(eight);
fruit nine = new fruit("9",R.drawable._9);
fruitList.add(nine);
}
}
MainActivity.class
问题:
1>diy_list_item.xml里线性布局的宽和高都是match_parent,会不会太大了,留出空白?
2>为什么要写一个fruitAdapter类?(当然这里重写了getView()方法,是可以实现目标的。但不写这个类,用原有的适配器,可以吗?)
Hint: "_1"、"_2"等图片要自己下载,放在res/drawalbe-hdpi下。
3.在public View getView(int position, View convertView, ViewGroup parent)中利用convertView这个缓存来进行优化
public View getView(int position, View convertView/*用于将之前加载好的布局进行缓存,以便重用*/, ViewGroup parent) {
// TODO Auto-generated method stub
fruit f = getItem(position);//该position对应的fruit对象
View v ;//理解是diy_list_item这个布局,布局也是一种view
ViewHolder vHolder = null;//用于缓存fruitImage和fruitName,避免每次都findViewById()
if( null == convertView ){
v = LayoutInflater.from(getContext()).inflate(resourceId, null);
vHolder = new ViewHolder();
vHolder.fruitImage = (ImageView)v.findViewById(R.id.imageView);
vHolder.fruitName = (TextView)v.findViewById(R.id.textView);
v.setTag(vHolder);
}
else{
v = convertView;
vHolder = (ViewHolder) v.getTag();
}
vHolder.fruitImage.setImageResource(f.getImageId());
vHolder.fruitName.setText(f.getName());
return v;
}
//内部类ViewHolder
class ViewHolder{
ImageView fruitImage;
TextView fruitName;
}
getView()
4.添加点击事件
lv.setOnItemClickListener(new OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position,long id) {
// TODO Auto-generated method stub
fruit f = fruitList.get(position);
Toast.makeText(MainActivity.this, f.getName(), Toast.LENGTH_SHORT).show();
}
});
大四实习准备1_java构造器_android ListView的更多相关文章
- 大四实习准备2_java异常处理_android控件练习
2015-4-24 Java 异常处理 可以有多个catch;ArrayIndexOutOfBoundsException类是Exception类的子类RuntimeException类的一个间接子类 ...
- 大四实习准备6_android服务
2015-5-9 1.服务是什么 android四大组件之一,有一些特点: 1)服务的运行不依赖于用户界面,即使程序被切换到后台.或者用户打开了另外一个应用程序,服务仍然能够保持正常运行.(当对应的程 ...
- 大四实习准备5_android广播机制
2015-5-1 android 广播机制 5.1简介 分为标准广播(Normal broadcasts)(无先后顺序,几乎同时接收,不可截断)和有序广播(Ordered broadcasts)(有先 ...
- 大四实习准备4_java内部类
2015-4-30 [昨天又可耻地休息了一天,懒劲比较大啊.跟懒劲有直接关系,这几天对幸福的感知也黯淡了,对未来的幸福不是那么渴望了.表现在对亲情和爱情上. 我想生活的本意是积极进取.茁壮生长并时常感 ...
- 大四实习准备3_java多线程
4.25.27无耻地懒散了.....26号陪女朋友去了.今天28号,继续加油! 2015-4-28 Java 多线程 (java中类不能多继承,可以多层继承:接口则都可以) 定义和创建: 方法一:继承 ...
- jQuery-H5-css3转盘抽奖-遁地龙卷风
(-1)写在前面 这个idea不是我的,首先向这位前辈致敬. 我用的是chrome49, jquery3.0. 完整的程序案例在我的百度云盘http://pan.baidu.com/s/1jI2QSn ...
- OneAPM x 腾讯 | OneAPM 技术公开课·深圳 报名:前端性能大作战!
「 OneAPM 技术公开课」由应用性能管理第一品牌 OneAPM 发起,内容面向 IT 开发和运维人员.云集技术牛人.知名架构师.实践专家共同探讨技术热点. 11月28日,OneAPM 技术公开课第 ...
- 我的2011年总结--大明zeroson程序猿一周年总结
花絮:看到csdn举办"我的2011"年度征文活动,我恰好工作也一年多了,上个月写了篇博客,主要是我换工作方面的流水账,这篇我从主观.客观.多方位地谈谈我这一年的变化. ...
- 【蜗牛—漫漫IT路之大学篇(九)
】
再来一篇叨叨的博客 近期,状态还是那个状态,人还是那个人. 前两天,感冒了,可能是宿舍阴面的事吧.然后,中午睡觉的时候穿着短袖披了一件外套,然后鼻子就不通气了.只是,前天晚上,我骑着崔国强的车子跑了不 ...
随机推荐
- 多线程的单元测试工具 - GroboUtils
写过Junit单元测试的同学应该会有感觉,Junit本身是不支持普通的多线程测试的,这是因为Junit的底层实现上,是用System.exit退出用例执行的.JVM都终止了,在测试线程启动的其他线程自 ...
- wpf 绑定ObservableCollection 的Count属性
相信大家都遇到过这样的需求,DataGrid里显示符合筛选条件的学生列表,上方TextBolck里显示学生总数,大家可以这样做: 1,XAML代码 <Window x:Class="O ...
- Only the original thread that created a view hierarchy can touch its views
在调试软件的时候出现如下的错误: 01-05 20:53:36.492: E/ZZShip(2043): android.view.ViewRootImpl$CalledFromWrongThread ...
- 十一、mysql输入安全
.尽量使用“绑定参数”功能,php中可用pdo进行一系列操作 .php可使用mysql_real_escape_string()函数进行输入过滤:
- 【ibatis】cachemodel、属性 及特殊配置
http://www.cnblogs.com/13590/archive/2013/03/01/2938126.html <?xml version="1.0" encodi ...
- bnuoj 20832 Calculating Yuan Fen(暴力模拟)
http://www.bnuoj.com/bnuoj/problem_show.php?pid=20832 [题意]: 给你一串字符串,求一个ST(0<ST<=10000),对字符串中字符 ...
- Hibernate应用SQL查询返回实体类型
Hibernate应用SQL查询返回实体类型 Hibernate使用SQL查询返回实体类型 以前,使用SQL查询,结果放在 RS 结果集中,还要去转换影射到Java类中.Hibernate中,可以自动 ...
- Bypass Preventing CSRF
CSRF在过去的n年(n>2)一直都火,在bh/defcon/owasp等会议上多次探讨CSRF的攻防[具体你可以看看以往的那些pp].前 段时间PLAYHACK.net上发表了一个总结性的pp ...
- Spark的TorrentBroadcast:实现
依据Spark 1.4版 序列化和反序列化 前边提到,TorrentBroadcast的关键就在于特殊的序列化和反序列化设置.1.1版的TorrentBroadcast实现了自己的readObject ...
- chardet安装
1.下载 chardet-2.2.1.tar.gz (md5) https://pypi.python.org/pypi/chardet#downloads 2.解压至C:\Python27\Li ...