移动开发考试复习总结

Android

代码填空

  1. 设置控件的可见性和不可见性

    • 设置控件可见
    myButton.setVisiblility(View.VISIBLE)
    
    • 设置控件不可见保留空间
    myButton.setVisiblility(View.INVISIBLE)
    
    • 设置控件为不可见不保留空间
    myButton.setVisiblility(View.GONE)
    
  2. sharepreferens存储读取

    //存储数据
    SharedPreferences sharedPreferences = getSharedPreferences("MyPreferences",Context.MODE_PRIVATE);
    SharedPreferences.Editor editor = sharedPreferences.edit();
    edit.putString("key_string","hello world!");
    editor.apply();
    //读数据
    String valueString = sharedPreferences.getString("key_string","No value found");
    Toast.makeText(this,"Value: " + valueString,Toast.LENGTH_SHORT).show()
    
  3. 关闭当前页面

    • 在Activity内部关闭自身:简单调用finish()方法
    public void closeActivity(){
        finish()
    }
    //你可以在按钮的点击事件监听器、菜单项的选择监听器等地方调用这个方法
    
    • 另一个Activity中关闭前一个Activity: 使用startActivityForResult()setResult() , 并在前一个Activity的onActivityResult()方法中调用finish().更常见的做法是让结果页面自己调用finish()
    • 在Fragment中关闭它的Activity: 如果你在一个Fragment中,并且想要包含该Fragment的Activity,你可以通过调用**getActivity.finish()**来实现
    public void closeContainingActivity(){
        if(getActivity != null){
            getActivity().finish();
        }
    }
    //注意:在调用 finish()之前检查 getActivity()是否返回 null 是很重要的,因为 Fragment 可能在 Activity 已经销毁之后仍然保留在内存中。
    
    • 对话窗弹出窗口中关闭背后的Activity: 通常需要在对话框某个回调中调用finish() . 但是,这通常意味着对话框是由该 Activity 管理的, 所以你应该在该 Activity 的某个方法中调用 finish()

    4.接受页面传递对象的序列化

    5.页面延时跳转

    6.应用样式到布局文件中

    7.video view 控件的使用

    简答题

    1. 如何实现数据回传

      • 启动Activity并等待结果:在原始Activity中,使用Intent启动另一个Activity,并调用startActivityForResult(intent,requestCode).

        其中,requestCode是一个用于在结果返回时区分不同请求的整数值

      • 在目标Activity中设置结果:在目标 Activity 中,当用户完成操作后,创建一个新的 Intent, 将需要回传的数据放入其中.

        调用 setResult(resultCode, intent)。其中,resultCode 通常 使用 RESULT_OK 或 RESULT_CANCELED来表示成功或取消.

        调用 finish()来关闭目标 Activity 并返回结果

      • 在原始Activity中接收结果:在原始Activity中,重写**onActivityResult(int requestCode,int resultCode,Intent data)**方法

        在这个方法中,你可以通过 requestCode 来区分不同的请求,通 过 resultCode 来判断操作是否成功,通过 data 来获取回传的数据。

        虽然这些方法主要用于持久化存储数据,但你也可以将它们 用于在 Activity 之间传递数据。然而,这种方法通常不是最佳实践,因为它可能会导致不必要 的 I/O 操作和性能问

    2. 创建对话框步骤

      • 确定对话框类型

      根据需求确定对话框的类型,如提示对话框、选择对话框(单选、 多选)、列表对话框等。

      • 设置对话框属性

      标题:为对话框设置标题,用于简要说明对话框的用途。

      图标:如果需要,可以为对话框设置图标,以增强视觉效果。

      内容:为对话框设置要显示的内容,这可以是简单的文本消息,也可以是复杂的布局。

      按钮:根据需要添加按钮,如“确定”、“取消”等,并为这些按 钮设置点击事件监听器。

      构 建 对 话 框: 使 用 Android 提 供 的 对 话 框 构 建 工 具 ( 如 AlertDialog.Builder)来构建对话框。

      • 显示对话框

      调用对话框的 show()方法来显示对话框。

      处理对话框关闭事件(可选):如果需要在对话框关闭时执行某些操作(如清理资源),可以设置 一个对话框关闭事件监听器。

    代码题

  4. SQLite创建增删改查四个方法:

public class MyDatabaseHelper extends SQLiteOpenHelper {
    private static final String DB_NAME = "MyDatabase.db";
    private static final int DB_VERSION = 1;
    private static final String TABLE_NAME = "MyTable";
    private static final String COLUMN_ID = "_id";
    private static final String COLUMN_NAME = "name";

    public MyDatabaseHelper(Context context) {
        super(context, DB_NAME, null, DB_VERSION);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        String createTableQuery = "CREATE TABLE " + TABLE_NAME + " (" + COLUMN_ID + " INTEGER PRIMARY KEY AUTOINCREMENT,
        " + COLUMN_NAME + " TEXT " + ")"; db.execSQL(createTableQuery);
    }
// ... 其他方法,如 onUpgrade()等
}
2.插入(增)
        java public void insertData(String name){
        SQLiteDatabase db = myDatabaseHelper.getWritableDatabase();
        ContentValues values=new ContentValues();
        values.put(MyDatabaseHelper.COLUMN_NAME,name);
        db.insert(MyDatabaseHelper.TABLE_NAME,null,values);
        db.close();
        }
3.删除(删)
        java public void deleteData(int id){
        SQLiteDatabase db=
        myDatabaseHelper.getWritableDatabase();
        db.delete(MyDatabaseHelper.TABLE_NAME,
        MyDatabaseHelper.COLUMN_ID+" = ?",
        new String[]{String.valueOf(id)});
        db.close();
        }
4.查询(查)
        java public Cursor getData(){
        SQLiteDatabase db=myDatabaseHelper.getReadableDatabase();
        return db.query(MyDatabaseHelper.TABLE_NAME,null,null,
        null,null,null,null);
        }
// 然后在某个地方使用 Cursor 遍历结果
        Cursor cursor=getData();
        if(cursor.moveToFirst()){
        do{
        int id=
        cursor.getInt(cursor.getColumnIndex(MyDatabaseHelper.COLUMN_ID));
        String name=
        cursor.getString(cursor.getColumnIndex(MyDatabaseHelper.COLUMN_NAME));
// 处理数据...
        }while(cursor.moveToNext());
        }
        cursor.close();
5.更新(改)
        java public void updateData(int id,String new newName){
        SQLiteDatabase db=myDatabaseHelper.getWritableDatabase();
        ContentValues values=new ContentValues();
        values.put(MyDatabaseHelper.COLUMN_NAME,newName);
        db.update(MyDatabaseHelper.TABLE_NAME,values,
        MyDatabaseHelper.COLUMN_ID+" = ?",
        new String[]{String.valueOf(id)});
        db.close();
        }
  1. Recycle View适配器

    // 定义数据源
    ArrayList<String> dataList=new ArrayList<>();
    // ... 填充数据到 dataList 中
    // 初始化 ListView
            ListView listView=findViewById(R.id.list_view);
    // 使用 ArrayAdapter
            ArrayAdapter<String> adapter=new ArrayAdapter<>(this,android.R.layout.simple_list_item_1,dataList);
    // 将适配器设置到 ListView
            listView.setAdapter(adapter);
    // 如果需要更新数据,只需更新 dataList 并调用 notifyDataSetChanged()(但ArrayAdapter 没有直接提供这个方法)
            // 一个简单的解决办法是重新创建适配器并设置到 ListView
            dataList.add("新增的条目");
            adapter=new ArrayAdapter<>(this,android.R.layout.simple_list_item_1,dataList);
            listView.setAdapter(adapter);
           // Recycle View 适配器
    public class MyRecyclerViewAdapter extends RecyclerView.Adapter<MyRecyclerViewAdapter.ViewHolder> {
        private ArrayList<String> dataList;
        public MyRecyclerViewAdapter(ArrayList<String> dataList) {
            this.dataList = dataList;
        }
        @NonNull
        @Override
        public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
    // 创建 ViewHolder 并绑定视图
            View itemView = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_list, parent, false);
            return new ViewHolder(itemView);
        }
        @Override
        public void onBindViewHolder(@NonNull ViewHolder holder, int position) {
    // 绑定数据到 ViewHolder 的视图上
            holder.textView.setText(dataList.get(position));
        }
        @Override
        public int getItemCount() {
    // 返回数据项的数量
            return dataList.size();
        }
        public class ViewHolder extends RecyclerView.ViewHolder {
            TextView textView;
            public ViewHolder(@NonNull View itemView) {
                super(itemView);
                textView = itemView.findViewById(R.id.text_view); //
               // 假设 item_list.xml 中有一个 TextView,其 ID 为 text_view
            }
        }
        // 如 果 需 要 更 新 数 据 , 只 需 更 新 dataList 并 调 用
        notifyDataSetChanged()
        public void updateData(ArrayList<String> newData) {
            this.dataList = newData;
            notifyDataSetChanged();
        }
    }
    
  • 21
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值