一、前言
以下不作为Android学习路径,只是汇总的社招Android客户端开发面试考点(因为还有笔试考点,后面结合在一起给大家学习路径),后续会为大家更新10w+字数的Android校招面试题库,还有其他岗位的相关题库和资料,想要什么岗位的可以留言哦~
本篇根据各个公司的面试问的问题的大数据进行总结,后面还会更新面试中考察所占比例,当然,本文只包括技术面,不包括hr面或者一些其他谈人生理想的。
}
//用于更新数据库
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
//当当前版本和老版本不一样的时候
if (newVersion != oldVersion) {
}
}
}
DataBaseActivity如下:
public class DataBaseActivity extends AppCompatActivity {
private DataBaseHelp helper;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_data_base);
//初始化辅助类
helper = new DataBaseHelp(this);
}
//创建数据库
public void btncreate(View view) {
//getWritableDatabase()打开数据库
SQLiteDatabase db = helper.getWritableDatabase();
//当数据库不用时关闭数据库(为了防止博主Demo出错。。。。。)
db.close();
}
//添加数据
public void btninsert(View view) {
SQLiteDatabase db = helper.getWritableDatabase();
//Android为了方便程序员SQL开发,提供了一个贼好的API: ContentValues(添加数据交给它)
ContentValues values = new ContentValues();
//放值
values.put(“name”, “张三”);
values.put(“age”, 18);
db.insert(DataBaseHelp.TABLE_NAME, null, values);
values.put(“name”, “李四”);
values.put(“age”, 19);
db.insert(DataBaseHelp.TABLE_NAME, null, values);
values.put(“name”, “王五”);
values.put(“age”, 20);
db.insert(DataBaseHelp.TABLE_NAME, null, values);
//关闭数据库
db.close();
}
//删除数据
public void btndelete(View view) {
SQLiteDatabase db = helper.getWritableDatabase();
/*table :表名
-
whereClause:满足删除条件 格式:例子: “name=?”
-
whereArgs:满足删除的条件*/
db.delete(DataBaseHelp.TABLE_NAME, “name=?”, new String[]{“张三”});
//关闭数据库
db.close();
}
//修改数据
public void btnupdate(View view) {
SQLiteDatabase db = helper.getWritableDatabase();
ContentValues values = new ContentValues();
values.put(“name”, “BoRe”);
values.put(“age”, 7);
/*
-
table:表名
-
values:更新的数据
-
whereClaues:更新条件 格式:例子: “name=?”
-
whereArgs:满足更新的条件*/
db.update(DataBaseHelp.TABLE_NAME, values, “name=?”, new String[]{“李四”});
//关闭数据库
db.close();
}
//查找数据
public void btnselect(View view) {
SQLiteDatabase db = helper.getWritableDatabase();
/*
*table :表名
-
colums:被查询的列(字段)
-
selection :查询条件
-
selectionArgs:满足查询条件
-
group:指定分组
-
having:分组筛选数据的关键字
-
orderby:排序*/
Cursor cursor = db.query(DataBaseHelp.TABLE_NAME, new String[]{“name”, “age”}, null, null, null, null, null);
//数据拿到了,已经在cursor游标中,现在要遍历游标
//先拿到我们关心的列的索引
int nameIndex = cursor.getColumnIndex(“name”);
int ageIndex = cursor.getColumnIndex(“age”);
while (cursor.moveToNext()) {
//通过列的索引去获取单个格子的值
String name = cursor.getString(nameIndex);
int age = cursor.getInt(ageIndex);
Log.e(“Select”, "btnselect: " + name + age);
}
//关闭数据库
db.close();
}
}
xml文件如下:
<LinearLayout xmlns:android=“http://schemas.android.com/apk/res/android”
xmlns:app=“http://schemas.android.com/apk/res-auto”
xmlns:tools=“http://schemas.android.com/tools”
要如何成为Android架构师?
搭建自己的知识框架,全面提升自己的技术体系,并且往底层源码方向深入钻研。
大多数技术人喜欢用思维脑图来构建自己的知识体系,一目了然。这里给大家分享一份大厂主流的Android架构师技术体系,可以用来搭建自己的知识框架,或者查漏补缺;

对应这份技术大纲,我也整理了一套Android高级架构师完整系列的视频教程,主要针对3-5年Android开发经验以上,需要往高级架构师层次学习提升的同学,希望能帮你突破瓶颈,跳槽进大厂;
最后我必须强调几点:
1.搭建知识框架可不是说你整理好要学习的知识顺序,然后看一遍理解了能复制粘贴就够了,大多都是需要你自己读懂源码和原理,能自己手写出来的。
2.学习的时候你一定要多看多练几遍,把知识才吃透,还要记笔记,这些很重要! 最后你达到什么水平取决你消化了多少知识
3.最终你的知识框架应该是一个完善的,兼顾广度和深度的技术体系。然后经过多次项目实战积累经验,你才能达到高级架构师的层次。
你只需要按照在这个大的框架去填充自己,年薪40W一定不是终点,技术无止境
颈,跳槽进大厂;
最后我必须强调几点:
1.搭建知识框架可不是说你整理好要学习的知识顺序,然后看一遍理解了能复制粘贴就够了,大多都是需要你自己读懂源码和原理,能自己手写出来的。
2.学习的时候你一定要多看多练几遍,把知识才吃透,还要记笔记,这些很重要! 最后你达到什么水平取决你消化了多少知识
3.最终你的知识框架应该是一个完善的,兼顾广度和深度的技术体系。然后经过多次项目实战积累经验,你才能达到高级架构师的层次。
你只需要按照在这个大的框架去填充自己,年薪40W一定不是终点,技术无止境
1280

被折叠的 条评论
为什么被折叠?



