2024年Android最全Android——SQLite数据库使用详解,2024年最新android面试知识点总结

总结

Android架构学习进阶是一条漫长而艰苦的道路,不能靠一时激情,更不是熬几天几夜就能学好的,必须养成平时努力学习的习惯。所以:贵在坚持!

上面分享的字节跳动公司2020年的面试真题解析大全,笔者还把一线互联网企业主流面试技术要点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。

就先写到这,码字不易,写的很片面不好之处敬请指出,如果觉得有参考价值的朋友也可以关注一下我

①「Android面试真题解析大全」PDF完整高清版+②「Android面试知识体系」学习思维导图压缩包阅读下载,最后觉得有帮助、有需要的朋友可以点个赞

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

android:layout_width=“0dp”

android:layout_height=“0dp” />

<TextView

android:layout_width=“wrap_content”

android:layout_height=“wrap_content”

android:layout_gravity=“center”

android:layout_marginTop=“80dp”

android:textColor=“#ff0000”

android:textSize=“35sp”

android:text=“数据库操作” />

<EditText

android:id=“@+id/username”

android:layout_width=“match_parent”

android:layout_height=“wrap_content”

android:background=“@drawable/edit_style”

android:layout_margin=“20dp”

android:inputType=“text”

android:textSize=“25dp”

android:maxLines=“12”

android:singleLine=“true”

android:hint=“用户名” />

<EditText

android:id=“@+id/password”

android:layout_width=“match_parent”

android:layout_height=“wrap_content”

android:background=“@drawable/edit_style”

android:inputType=“textPassword”

android:layout_marginLeft=“20dp”

android:layout_marginRight=“20dp”

android:textSize=“25dp”

android:maxLines=“12”

android:singleLine=“true”

android:hint=“密码” />

<Button

android:id=“@+id/submit”

android:layout_marginTop=“30dp”

android:layout_marginLeft=“20dp”

android:layout_marginRight=“20dp”

android:layout_marginBottom=“10dp”

android:textSize=“25dp”

android:background=“@drawable/button_style”

android:layout_width=“match_parent”

android:layout_height=“wrap_content”

android:text=“登录” />

<Button

android:id=“@+id/register”

android:layout_marginLeft=“20dp”

android:layout_marginRight=“20dp”

android:textSize=“25dp”

android:background=“@drawable/button_style”

android:layout_width=“match_parent”

android:layout_height=“wrap_content”

android:text=“注册” />

登录后的页面activity_index.xml,这个页面就显示了一个用户的姓名(开始还有几个测试按钮,之后感觉不好看删除了O(∩_∩)O哈哈~,你们可以自己加几个按钮测试)

<LinearLayout xmlns:android=“http://schemas.android.com/apk/res/android”

xmlns:tools=“http://schemas.android.com/tools”

android:id=“@+id/LinearLayout1”

android:layout_width=“match_parent”

android:layout_height=“match_parent”

android:orientation=“vertical”

tools:context=“ r e l a t i v e P a c k a g e . {relativePackage}. relativePackage.{activityClass}” >

<TextView

android:id=“@+id/text”

android:layout_width=“wrap_content”

android:layout_height=“wrap_content”

android:layout_margin=“20dp” />

<ImageView

android:layout_width=“match_parent”

android:layout_height=“0.5dp”

android:background=“@color/gray”

android:layout_marginLeft=“20dp”

android:layout_marginRight=“20dp” />

页面,样式代码都在这里了,还一张背景图片,可以到网上随便找一张。下面来看看数据库操作的代码。

TUser.java相当于实体类。

package com.example.androiddemo01.model;

public class TUser {

private Integer id;

private String username;

private String password;

private String name;

private String sex;

public Integer getId() {

return id;

}

public void setId(Integer id) {

this.id = id;

}

public String getUsername() {

return username;

}

public void setUsername(String username) {

this.username = username;

}

public String getPassword() {

return password;

}

public void setPassword(String password) {

this.password = password;

}

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

public String getSex() {

return sex;

}

public void setSex(String sex) {

this.sex = sex;

}

public TUser(Integer id, String username, String password, String name,

String sex) {

super();

this.id = id;

this.username = username;

this.password = password;

this.name = name;

this.sex = sex;

}

public TUser() {

super();

}

}

DbOpenHelper.java链接数据库,创建数据库类

package com.example.androiddemo01.dao;

import android.content.Context;

import android.database.sqlite.SQLiteDatabase;

import android.database.sqlite.SQLiteDatabase.CursorFactory;

import android.database.sqlite.SQLiteOpenHelper;

public class DbOpenHelper extends SQLiteOpenHelper {

private static final String DBNAME = “data.db”;

private static int version = 1;

//content容器,name链接数据库名字,version版本号,factory游标工厂

public DbOpenHelper(Context context) {

super(context, DBNAME, null, version);

}

//运行DbOpenHelper时执行,建立表和数据库,没有数据库则建立,只有第一次运行执行

@Override

public void onCreate(SQLiteDatabase db) {

String sql = “create table t_user(”+

“id integer primary key autoincrement not null,”+

“username text(10),”+

“password text(10),”+

“name text(10),”+

“sex text(2))”;

//执行SQL语句

db.execSQL(sql);

sql = “insert into t_user (‘username’, ‘password’, ‘name’, ‘sex’) values(‘admin’,‘admin’, ‘张三’, ‘男’)”;

db.execSQL(sql);

}

//更新,版本升级

@Override

public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

}

}

TUserDAO.java数据库操作类,增删改查。

package com.example.androiddemo01.dao;

import java.util.ArrayList;

import java.util.List;

import com.example.androiddemo01.model.TUser;

import android.content.Context;

import android.database.Cursor;

import android.database.sqlite.SQLiteDatabase;

//持久层类,对数据库的操作

public class TUserDAO {

private SQLiteDatabase db;

//content容器,上下文

public TUserDAO(Context context){

super();

DbOpenHelper helper = new DbOpenHelper(context);

db = helper.getWritableDatabase();

}

//登录验证

public TUser findUserNameAndPassword(String str, String str1) {

String sql = “select * from t_user where username = ? and password = ?”;

Cursor cursor = db.rawQuery(sql, new String[] {str, str1});

TUser user = null;

//cursor.moveToNext判断下一个是否有值

if(cursor.moveToNext()){

user = new TUser(cursor.getInt(0), cursor.getString(1), cursor.getString(2), cursor.getString(3), cursor.getString(4));

}

return user;

}

//查找表中所有数据

public List findAll(){

String sql = “select * from t_user”;

Cursor cursor = db.rawQuery(sql, null);

List list = new ArrayList();

if(cursor.moveToNext()){

TUser user = new TUser(cursor.getInt(0), cursor.getString(1), cursor.getString(2), cursor.getString(3), cursor.getString(4));

list.add(user);

}

return list;

}

//根据姓名模糊查找

public List searchByName(String key){

List list = new ArrayList();

key = “%”+key+“%”;

Cursor cursor = db.rawQuery(“select * from t_user where name like ?”, new String[]{key});

while(cursor.moveToNext()){

TUser user = new TUser(cursor.getInt(0), cursor.getString(1), cursor.getString(2), cursor.getString(3), cursor.getString(4));

list.add(user);

}

return list;

}

//添加

public void insert(TUser t){

db.execSQL(“insert into t_user(username, password, name, sex) values(?, ?, ?, ?)”, new Object[] {t.getUsername(), t.getPassword(), t.getName(), t.getSex()});

System.out.println(“添加数据成功!”);

}

//修改

public void update (TUser user){

db.execSQL(“update t_user set name=?, sex = ?, password = ?, username = ? where id = ?”,

new Object[] {user.getName(), user.getSex(), user.getPassword(), user.getUsername(), user.getId()});

}

//根据id删除

public void delete(int id){

Integer i = new Integer(id);

db.execSQL(“delete from student where id = ?”, new Object[]{i});

}

}

MainActivity.java登录处理类

尾声

面试成功其实都是必然发生的事情,因为在此之前我做足了充分的准备工作,不单单是纯粹的刷题,更多的还会去刷一些Android核心架构进阶知识点,比如:JVM、高并发、多线程、缓存、热修复设计、插件化框架解读、组件化框架设计、图片加载框架、网络、设计模式、设计思想与代码质量优化、程序性能优化、开发效率优化、设计模式、负载均衡、算法、数据结构、高级UI晋升、Framework内核解析、Android组件内核等。

不仅有学习文档,视频+笔记提高学习效率,还能稳固你的知识,形成良好的系统的知识体系。这里,笔者分享一份从架构哲学的层面来剖析的视频及资料分享给大家梳理了多年的架构经验,筹备近6个月最新录制的,相信这份视频能给你带来不一样的启发、收获。

Android进阶学习资料库

一共十个专题,包括了Android进阶所有学习资料,Android进阶视频,Flutter,java基础,kotlin,NDK模块,计算机网络,数据结构与算法,微信小程序,面试题解析,framework源码!

image

大厂面试真题

PS:之前因为秋招收集的二十套一二线互联网公司Android面试真题 (含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)

《2017-2021字节跳动Android面试历年真题解析》

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

基础,kotlin,NDK模块,计算机网络,数据结构与算法,微信小程序,面试题解析,framework源码!

[外链图片转存中…(img-TyshpOS0-1715706872203)]

大厂面试真题

PS:之前因为秋招收集的二十套一二线互联网公司Android面试真题 (含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)

[外链图片转存中…(img-WiO3SlUP-1715706872203)]

《2017-2021字节跳动Android面试历年真题解析》

[外链图片转存中…(img-5Ml8nDOO-1715706872203)]

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值