尾声
开发是需要一定的基础的,我是08年开始进入Android这行的,在这期间经历了Android的鼎盛时期,和所谓的Android”凉了“。中间当然也有着,不可说的心酸,看着身边朋友,同事一个个转前端,换行业,其实当时我的心也有过犹豫,但是我还是坚持下来了,这次的疫情就是一个好的机会,大浪淘沙,优胜劣汰。再等等,说不定下一个黄金浪潮就被你等到了。
- 330页 PDF Android核心笔记
- 几十套阿里 、字节跳动、腾讯、华为、美团等公司2020年的面试题
- PDF和思维脑图,包含知识脉络 + 诸多细节
- Android进阶系统学习视频
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
}
public void setPhone(String phone) {
this.phone = phone;
}
}
package cn.itcast.service;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
public class DBOpenHelper extends SQLiteOpenHelper{
private static final int VERSION = 2; //数据库版本
public DBOpenHelper(Context context){
super(context, "itcast.db", null, VERSION); //<包>/database/
}
@Override
public void onCreate(SQLiteDatabase db) { //是在数据库第一次被创建的时候调用的
db.execSQL("CREATE TABLE person(personId integer primary key autoincrement, " + "name varchar(20))");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { //数据库版本号发生改变的时候调用的
db.execSQL("ALTER TABLE person ADD phone VARCHAR(12) NULL");
}
}
package cn.itcast.service;
import java.util.ArrayList;
import java.util.List;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import cn.itcast.domain.Person;
public class PersonService {
private DBOpenHelper dbOpenHelper;
public PersonService(Context context){
this.dbOpenHelper = new DBOpenHelper(context);
}
/\*\*
\* 添加记录
\* @param person
\*/
public void save(Person person){
SQLiteDatabase db \= dbOpenHelper.getWritableDatabase();
db.execSQL("insert into person(name, phone) values(?, ?)",new Object\[\]{person.getName(), person.getPhone()});
//如果只在一个类中使用db,则不需要关闭,提高性能
//但是若是多处使用,则需要关闭
// db.close();
}
/\*\*
\* 删除记录
\* @param id 记录ID
\*/
public void delete(Integer id){
SQLiteDatabase db \= dbOpenHelper.getWritableDatabase();
db.execSQL("delete from person where personId=?", new Object\[\]{id});
}
/\*\*
\* 更新记录
\* @param person
\*/
public void update(Person person){
SQLiteDatabase db \= dbOpenHelper.getWritableDatabase();
db.execSQL("update person set name=?, phone=? where personId=?",
new Object\[\]{person.getName(), person.getPhone(), person.getId()});
}
/\*\*
\* 查询记录
\* @param id 记录ID
\* @return
\*/
public Person find(Integer id){
SQLiteDatabase db \= dbOpenHelper.getReadableDatabase();
Cursor cursor \= db.rawQuery("select \* from person where personId=?", new String\[\]{id.toString()});
if(cursor.moveToFirst()){
int personId = cursor.getInt(cursor.getColumnIndex("personId"));
String name \= cursor.getString(cursor.getColumnIndex("name"));
String phone \= cursor.getString(cursor.getColumnIndex("phone"));
return new Person(personId, name, phone);
}
cursor.close();
return null;
}
/\*\*
\* 分布获取记录
\* @param offset 跳过前面 多少条记录
\* @param maxResult 每页获取多少条记录
\* @return
\*/
public List<Person> getScrollData(int offset, int maxResult){
List<Person> persons = new ArrayList<Person>();
SQLiteDatabase db \= dbOpenHelper.getReadableDatabase();
Cursor cursor \= db.rawQuery("select \* from person order by personId asc limit ?,?",
new String\[\]{String.valueOf(offset), String.valueOf(maxResult)});
while(cursor.moveToNext()){
int personId = cursor.getInt(cursor.getColumnIndex("personId"));
String name \= cursor.getString(cursor.getColumnIndex("name"));
String phone \= cursor.getString(cursor.getColumnIndex("phone"));
persons.add(new Person(personId, name, phone));
}
cursor.close();
return null;
}
/\*\*
\* 获取记录总数
\* @return
\*/
public long getCount(){
SQLiteDatabase db \= dbOpenHelper.getReadableDatabase();
Cursor cursor \= db.rawQuery("select count(\*) from person", null);
cursor.moveToFirst();
long result = cursor.getLong(0);
cursor.close();
return result;
}
}
package cn.itcast.test;
import java.util.List;
import cn.itcast.domain.Person;
import cn.itcast.service.DBOpenHelper;
import cn.itcast.service.PersonService;
import android.test.AndroidTestCase;
import android.util.Log;
public class PersonServiceTest extends AndroidTestCase{
private static final String TAG = "PersonServiceTest";
public void testCreateDB() throws Exception{
DBOpenHelper dbOpenHelper \= new DBOpenHelper(getContext());
dbOpenHelper.getWritableDatabase();
}
public void testSave() throws Exception{
PersonService service \= new PersonService(this.getContext());
for(int i = 0; i < 20; i++){
Person person \= new Person("zhangsan", "123456");
service.save(person);
}
}
public void testDelete() throws Exception{
PersonService service \= new PersonService(this.getContext());
service.delete(21);
}
public void testUpdate() throws Exception{
PersonService service \= new PersonService(this.getContext());
Person person \= service.find(1);
person.setName("zhangxiaoxiao");
service.update(person);
}
public void testFind() throws Exception{
PersonService service \= new PersonService(this.getContext());
Person person \= service.find(1);
Log.i(TAG, person.toString());
}
public void testScrollData() throws Exception{
PersonService service \= new PersonService(this.getContext());
List<Person> persons = service.getScrollData(0, 5);
for(Person person : persons){
Log.i(TAG, person.toString());
}
}
public void testCount() throws Exception{
PersonService service \= new PersonService(this.getContext());
long result = service.getCount();
Log.i(TAG, result \+ "");
}
//除了execSQL()和rawQuery方法,还提供了对应于添加、删除、更新、查询的操作方法
总结
最后小编想说:不论以后选择什么方向发展,目前重要的是把Android方面的技术学好,毕竟其实对于程序员来说,要学习的知识内容、技术有太多太多,要想不被环境淘汰就只有不断提升自己,从来都是我们去适应环境,而不是环境来适应我们!
这里附上我整理的几十套腾讯、字节跳动,京东,小米,头条、阿里、美团等公司19年的Android面试题。把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。
由于篇幅有限,这里以图片的形式给大家展示一小部分。
网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。
技术进阶之路很漫长,一起共勉吧~
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
适应环境,而不是环境来适应我们!**
这里附上我整理的几十套腾讯、字节跳动,京东,小米,头条、阿里、美团等公司19年的Android面试题。把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。
由于篇幅有限,这里以图片的形式给大家展示一小部分。
[外链图片转存中…(img-rC7CaHjq-1715106103153)]
网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。
技术进阶之路很漫长,一起共勉吧~
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!