主頁 > 移動端開發 > 移動應用程式設計基礎——資料庫實踐——簡單日記本

移動應用程式設計基礎——資料庫實踐——簡單日記本

2022-01-18 08:43:48 移動端開發

《移動應用程式設計基礎》實驗5 資料庫實踐——簡單日記本

實驗名稱:

實驗5 資料庫實踐——簡單日記本

所使用的工具軟體及環境:

JDK1.8,Android Studio

一、實驗目的:

實驗目的:

掌握安卓資料庫的應用

二、實驗內容:

模擬一個日記本程式

實作簡單日記的新建、修 改、洗掉、查詢功能,運行效果如下圖,

當點擊右下方的添加按鈕時如下圖所示,

當點擊ListView的Item時,將顯示日記的詳細資訊,

當點擊ListView的右邊的編輯圖片按鈕時,將進入編輯日記模式,

當點擊Toolbar中的值為“編輯”的TextView控制元件時,顯示如下,

使用SQLiteExpert軟體查看生成的資料庫

當使用Sqlite資料庫時,Android系統對其存放的資料庫檔案位于/data/data/[包名]/databases/*.db,如下圖所示,在安裝sdk目錄下運行monitor.bat檔案:

默認情況下,data目錄是禁止非root用戶訪問的,這時,我們就需要root權限來查看,首先打開Android SDK下的platform-tools目錄,然后按住Shift鍵并按下滑鼠右鍵,點擊“在此處打開命令視窗(W)”,如下圖所示,

然后在命令視窗輸入以下命令:

adb root

這時,我們就可以訪問/data目錄了,之后使用pull命令來復制檔案,

adb pull /data/data/com.example.sqlitedemo/databases

/DiaryDB.db DiaryDB.db

默認情況下,檔案將存放在D:\WorkSpace\ASSDK\platform-tools目錄中,

之后,打開SQLiteExpert軟體(需網上下載),依次點擊FileàOpen Database,選中剛付訓出的資料庫檔案:

在左邊的串列中,選中diary表,之后選擇右上方的Data選項,就可以查看資料,選擇旁邊的Design選項可以查看表的結構,其下方的“加號”、“減號”、“對號”、“叉號”分別為插入一條資料、洗掉選中的資料、提交更改、撤銷更改,

實驗要求:

  1. 完成實驗內容所有代碼;
  2. 圖文并重的方式敘述實作程序;
  3. 展示運行結果,

實驗程序:

Android中封裝了一個SQLiteOpenHelper抽象類,我們需要創建SQLiteOpenHelper的子類并覆寫onCreate方法,在此方法中撰寫我們需要的SQL陳述句,使用契約類SQLiteContract來定義URI、表格和列名稱的常數的容器,契約類允許我們跨同一軟體包中的所有其他類使用相同的常數,

public final class SQLiteContract {

//為了防止使用者不小心實體化類的構造方法,

//使建構式私有化,

private SQLiteContract () {}

//此內部類定義日記表的內容

public static class DiaryEntry implements BaseColumns {

public static final String TABLE_NAME = "diary";

public static final String COLUMN_NAME_TITLE = "title";

public static final String COLUMN_NAME_CONTENT = "content";

public static final String COLUMN_NAME_TIME = "time";

}

//其他表內容

}

繼承SQLiteOpenHelper并覆寫onCreate方法和onUpgrade方法,其中onUpgrade方法是一個設定資料庫版本號的方法,需要我們注意的是,當我們實體化DBHelper 時(比如new DBHelper),onCreate方法只會執行一次,即資料庫表只會創建一次,當資料庫版本號增加時,系統將呼叫onUpgrade方法,我們可以將升級的SQL陳述句放在此方法內完成資料庫的升級,

1 public class DiaryDbHelper extends SQLiteOpenHelper {

2 public static final int DATABASE_VERSION = 1;

3 public static final String DATABASE_NAME = "DiaryDB.db";

4 public DiaryDbHelper(Context context) {

5 super(context, DATABASE_NAME, null, DATABASE_VERSION);

6 }

7 @Override

8 public void onCreate(SQLiteDatabase db) {

9 db.execSQL(SQL_CREATE_ENTRIES);

10 }

11 @Override

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

13 db.execSQL(SQL_DELETE_ENTRIES);

14 onCreate(db);

15 }

16 }

向資料庫中插入一條資料時,可以使用ContentValues 物件傳遞至SQLiteDatabase物件的insert() 方法將資料插入資料庫,

SQLiteDatabase db = dbHelper.getWritableDatabase();

//設定插入值

ContentValues values = new ContentValues();

values.put(SQLiteContract.DiaryEntry.COLUMN_NAME_TITLE, title);

values.put(SQLiteContract.DiaryEntry.COLUMN_NAME_CONTENT, content);

values.put(SQLiteContract.DiaryEntry.COLUMN_NAME_TIME, date);

//執行插入方法

long newRowId = db.insert(SQLiteContract.DiaryEntry.TABLE_NAME, null, values);

db.close();

可以使用query方法查詢資料

SQLiteDatabase db = dbHelper.getReadableDatabase();

String[] projection = {

SQLiteContract.DiaryEntry._ID,

SQLiteContract.DiaryEntry.COLUMN_NAME_TITLE,

SQLiteContract.DiaryEntry.COLUMN_NAME_CONTENT,

SQLiteContract.DiaryEntry.COLUMN_NAME_TIME

};

String selection = SQLiteContract.DiaryEntry._ID + " = ?";

String[] selectionArgs = { id };

String sortOrder =SQLiteContract.DiaryEntry.COLUMN_NAME_TIME + " DESC";

Cursor c = db.query(

SQLiteContract.DiaryEntry.TABLE_NAME,

projection, selection, selectionArgs, null, null, sortOrder

);

c.moveToFirst();

String title= c.getString(c.getColumnIndex(SQLiteContract.DiaryEntry.

COLUMN_NAME_TITLE))

c.close();

db.close();

更新資料可以使用update方法

SQLiteDatabase db = dbHelper.getWritableDatabase();

ContentValues values = new ContentValues();

values.put(SQLiteContract.DiaryEntry.COLUMN_NAME_TITLE, title);

String selection = SQLiteContract.DiaryEntry._ID + " = ?";

String[] selectionArgs = { id };

int count = db.update(

SQLiteContract.DiaryEntry.TABLE_NAME,

values,

selection,

selectionArgs);

db.close();

洗掉資料可以使用delete方法

SQLiteDatabase db = dbHelper.getWritableDatabase();

String selection = SQLiteContract.DiaryEntry._ID + " = ?";

String[] selectionArgs = { id };

db.delete(SQLiteContract.DiaryEntry.TABLE_NAME, selection, selectionArgs);

db.close();

三、實驗結果測驗(完整所有代碼在資源下載壓縮包中,文章結尾有資源下載鏈接)

4java檔案以及5個布局檔案

部分主要代碼:

//MainActivity.java
package com.example.mgh.diary;

import android.annotation.SuppressLint;
import android.app.Activity;
import android.content.Intent;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.graphics.Paint;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.TextView;

import java.util.ArrayList;

public class MainActivity extends Activity implements View.OnClickListener {
    public static ArrayList<info> info = new ArrayList<>();
    private ListView mlistview;
    public static SQLiteDatabase db;
    public Button buttonHide;
    public Button btn_search;
    public ImageView iv;
    private EditText editText;
    public Button look_button;

    public int a=0;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        init();
    }

    private void init() {
        info = new ArrayList<>();
        //editText = (EditText) findViewById(R.id.editText);
        btn_search = (Button) findViewById(R.id.btn_search);
        //buttonHide = (Button) findViewById(R.id.buttonHide);
        iv = (ImageView) findViewById(R.id.imageView);
        //buttonHide.setOnClickListener(this);
        btn_search.setOnClickListener(this);
        iv.setOnClickListener(this);

        //list監聽
        mlistview = (ListView) findViewById(R.id.mlistview);
        db = new MyHelper(this).getWritableDatabase();
        Cursor cursor = db.query("diary", null, null,
                null, null, null, null);
        if (cursor.moveToFirst()) {
            do {
// 遍歷Cursor物件,取出資料
                info.add(new info(cursor.getString(cursor.getColumnIndex("name")),
                        cursor.getString(cursor.getColumnIndex("content")),
                                cursor.getInt(cursor.getColumnIndex("_id"))));
            } while (cursor.moveToNext());
        }

        db.close();
        updateAdapter();


    }

    public void updateAdapter() {
        /*View vi=View.inflate(MainActivity.this,R.layout.for_list,null);
        look_button=(Button)vi.findViewById(R.id.look_Button);
        look_button.setOnClickListener(new View.OnClickListener(){
            @Override
            public void onClick(View v) {
                Intent intent = new Intent(MainActivity.this, Show_diary.class);
                db = new MyHelper(MainActivity.this).getWritableDatabase();
                startActivity(intent);
            }
        });*/
        MyAdapter myAdapter = new MyAdapter();
        mlistview.setAdapter(myAdapter);
        mlistview.setOnItemClickListener(new AdapterView.OnItemClickListener() {

            @Override
            public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {
                Intent intent = new Intent(MainActivity.this, Show_diary.class);
                intent.putExtra("id", i);
                db = new MyHelper(MainActivity.this).getWritableDatabase();
                startActivity(intent);

            }
        });
    }


    @Override
    public void onClick(View view) {
        switch (view.getId()) {
            case R.id.imageView:
                Intent intent = new Intent(this, Add_diary.class);
                intent.putExtra("id", info.size());
                startActivity(intent);
                a=1;
            case R.id.btn_search:
                if(a==0) {
                    btn_search.setText("取消");
                    look_button.setVisibility(View.VISIBLE);
                    a=1;
                }
                else {
                    btn_search.setText("編輯");
                    look_button.setVisibility(View.INVISIBLE);
                    a=0;
                }
                /*Intent intent2 = new Intent(this, Delete_diary.class);
                intent2.putExtra("id", info.size());
                startActivity(intent2);*/
                /*info = new ArrayList<>();

                buttonHide.setVisibility(View.VISIBLE);
                db = new MyHelper(this).getWritableDatabase();
                Cursor cursor = db.query("diary", new String[]{"_id,name,content"},
                        "name like ?", new String[]{"%"+editText.getText().toString()+"%"}, null, null,
                        null, null);
                if (cursor.moveToFirst()) {
                    do {
// 遍歷Cursor物件,取出資料
                        info.add(new info(cursor.getString(cursor.getColumnIndex("name")),
                                cursor.getString(cursor.getColumnIndex("content")),
                                cursor.getInt(cursor.getColumnIndex("_id"))));
                    } while (cursor.moveToNext());
                }

                db.close();
                updateAdapter();*/
                break;
        }
    }

    class MyAdapter extends BaseAdapter {

        public MyAdapter() {
            super();
        }

        public int getCount() {
            return info.size();
        }

        @Override
        public Object getItem(int i) {
            return info.get(i).name;
        }

        @Override
        public long getItemId(int i) {
            return i;
        }

        @SuppressLint("WrongConstant")
        @Override
        public View getView(int i, View view, ViewGroup viewGroup) {
            ViewHolder viewholder;
            if (view == null) {
                view = LayoutInflater.from(getApplicationContext()).inflate(R.layout.for_list, viewGroup, false);
                viewholder = new ViewHolder();
                viewholder.tv = (TextView) view.findViewById(R.id.name);
            } else {
                viewholder = (ViewHolder) view.getTag();
            }

            //View vi=View.inflate(MainActivity.this, R.layout.for_list,null);
            look_button=(Button)view.findViewById(R.id.button3);
            //洗掉按鈕不可見
            look_button.setVisibility(View.INVISIBLE);
            look_button.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    /*int id;
                    Intent intent = getIntent();
                    id = intent.getIntExtra("id", -1);
                    MainActivity.db.delete("diary", "_id=?", new String[]{String.valueOf(MainActivity.info.get(id).id)});
                    MainActivity.db.close();*/
                    /*SQLiteDatabase db = dbHelper.getWritableDatabase();
                    String selection = SQLiteContract.DiaryEntry._ID + " = ?";
                    String[] selectionArgs = { id };
                    db.delete(SQLiteContract.DiaryEntry.TABLE_NAME, selection, selectionArgs);
                    db.close();*/

                }
            });

            viewholder.tv.setText(String.valueOf(i + 1) + ": " + info.get(i).name);
            viewholder.tv.getPaint().setFlags(Paint.UNDERLINE_TEXT_FLAG);
            return view;
        }

        class ViewHolder {
            TextView tv;
        }


    }

    class info {
        String name;
        String content;
        int id;

        public info(String name, String content, int id) {
            this.name = name;
            this.content = content;
            this.id = id;
        }
    }

}

//Add_diary.java
package com.example.mgh.diary;

import android.app.Activity;
import android.content.ContentValues;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;

import org.jetbrains.annotations.Nullable;

public class Add_diary extends Activity {
    public int id;
    private EditText name;
    private EditText diary;
    private Button btn;

    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.add_diary);
        name = (EditText) findViewById(R.id.diary_name);
        diary = (EditText) findViewById(R.id.diary);
        btn = (Button) findViewById(R.id.submit);

        Intent intent = getIntent();
        id = intent.getIntExtra("id", -1);

    }

    public void sub(View v) {
        ContentValues values = new ContentValues();
        values.put("name", name.getText().toString());
        values.put("content", diary.getText().toString());
        MainActivity.db = new MyHelper(this).getWritableDatabase();

        MainActivity.db.insert("diary", null, values);
        MainActivity.db.close();

        Toast.makeText(this, "日志保存成功", Toast.LENGTH_SHORT).show();
        Intent intent = new Intent(this, MainActivity.class);
        startActivity(intent);
    }


}
//MyHelper.java
package com.example.mgh.diary;

import android.content.ContentValues;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;

public class MyHelper extends SQLiteOpenHelper{

    public MyHelper(Context context){
        super(context,"dia.db",null,5);
    }

    @Override
    public void onCreate(SQLiteDatabase sqLiteDatabase) {
        sqLiteDatabase.execSQL("create table diary(_id integer primary key autoincrement," +
                "name varchar(11),content varchar(1000))");
    }

    @Override
    public void onUpgrade(SQLiteDatabase sqLiteDatabase, int i, int i1) {

    }
}
//Show_diary.java
package com.example.mgh.diary;

import android.app.Activity;
import android.content.ContentValues;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.EditText;

import org.jetbrains.annotations.Nullable;

//import android.support.annotation.Nullable;

public class Show_diary extends Activity {
    private EditText name;
    private EditText ed;
    int id;

    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.show_diary);

        name = (EditText) findViewById(R.id.name);
        ed = (EditText) findViewById(R.id.content);
        Intent intent = getIntent();
        id = intent.getIntExtra("id", -1);

        name.setText(MainActivity.info.get(id).name);
        ed.setText(MainActivity.info.get(id).content);
    }

    public void backandchange(View v) {

        ContentValues values=new ContentValues();
        values.put("name",name.getText().toString());
        values.put("content",ed.getText().toString());

        MainActivity.db.update("diary", values,"_id=?", new String[]{String.valueOf(MainActivity.info.get(id).id)});
        MainActivity.db.close();


        Intent intent = new Intent(this, MainActivity.class);
        startActivity(intent);

    }

    public void del(View v) {
        MainActivity.db.delete("diary", "_id=?", new String[]{String.valueOf(MainActivity.info.get(id).id)});
        MainActivity.db.close();

        Intent intent = new Intent(this, MainActivity.class);
        startActivity(intent);
    }
}

實驗結果截圖:

心得與體會:

本次實驗功能基本完成,學習到資料庫的使用,通過查找資料以及學習,完成最后日記本的制作,通過本次實驗,識訓頗多,不僅復習了以前的知識,同時也學習到了新的知識,對今后的學習有了較大的幫助,

注:本次實驗結果與原實驗要求有部分不相似,若要一樣的實驗結果請到如下鏈接博客中的代碼進行修改!(該實驗部分代碼為網上資源修改)

https://blog.csdn.net/weixin_48388330/article/details/122546221

下載資源包鏈接:

https://download.csdn.net/download/weixin_48388330/76307026

資源中的圖片以及內容只適用與學習

轉載請註明出處,本文鏈接:https://www.uj5u.com/yidong/413941.html

標籤:其他

上一篇:【Android】安卓四大組件之Activity(一)

下一篇:移動應用程式設計基礎——期末考核——登錄界面與簡單日記本的綜合實踐

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 【從零開始擼一個App】Dagger2

    Dagger2是一個IOC框架,一般用于Android平臺,第一次接觸的朋友,一定會被搞得暈頭轉向。它延續了Java平臺Spring框架代碼碎片化,注解滿天飛的傳統。嘗試將各處代碼片段串聯起來,理清思緒,真不是件容易的事。更不用說還有各版本細微的差別。 與Spring不同的是,Spring是通過反射 ......

    uj5u.com 2020-09-10 06:57:59 more
  • Flutter Weekly Issue 66

    新聞 Flutter 季度調研結果分享 教程 Flutter+FaaS一體化任務編排的思考與設計 詳解Dart中如何通過注解生成代碼 GitHub 用對了嗎?Flutter 團隊分享如何管理大型開源專案 插件 flutter-bubble-tab-indicator A Flutter librar ......

    uj5u.com 2020-09-10 06:58:52 more
  • Proguard 常用規則

    介紹 Proguard 入口,如何查看輸出,如何使用 keep 設定入口以及使用實體,如何配置壓縮,混淆,校驗等規則。

    ......

    uj5u.com 2020-09-10 06:59:00 more
  • Android 開發技術周報 Issue#292

    新聞 Android即將獲得類AirDrop功能:可向附近設備快速分享檔案 谷歌為安卓檔案管理應用引入可安全隱藏資料的Safe Folder功能 Android TV新主界面將顯示電影、電視節目和應用推薦內容 泄露的Android檔案暗示了傳說中的谷歌Pixel 5a與折疊屏新機 谷歌發布Andro ......

    uj5u.com 2020-09-10 07:00:37 more
  • AutoFitTextureView Error inflating class

    報錯: Binary XML file line #0: Binary XML file line #0: Error inflating class xxx.AutoFitTextureView 解決: <com.example.testy2.AutoFitTextureView android: ......

    uj5u.com 2020-09-10 07:00:41 more
  • 根據Uri,Cursor沒有獲取到對應的屬性

    Android: 背景:呼叫攝像頭,拍攝視頻,指定保存的地址,但是回傳的Cursor檔案,只有名稱和大小的屬性,沒有其他諸如時長,連ID屬性都沒有 使用 cursor.getInt(cursor.getColumnIndexOrThrow(MediaStore.Video.Media.DURATIO ......

    uj5u.com 2020-09-10 07:00:44 more
  • Android連載29-持久化技術

    一、持久化技術 我們平時所使用的APP產生的資料,在記憶體中都是瞬時的,會隨著斷電、關機等丟失資料,因此android系統采用了持久化技術,用于存盤這些“瞬時”資料 持久化技術包括:檔案存盤、SharedPreference存盤以及資料庫存盤,還有更復雜的SD卡記憶體儲。 二、檔案存盤 最基本存盤方式, ......

    uj5u.com 2020-09-10 07:00:47 more
  • Android Camera2Video整合到自己專案里

    背景: Android專案里呼叫攝像頭拍攝視頻,原本使用的 MediaStore.ACTION_VIDEO_CAPTURE, 后來因專案需要,改成了camera2 1.Camera2Video 官方demo有點問題,下載后,不能直接整合到專案 問題1.多次拍攝視頻崩潰 問題2.雙擊record按鈕, ......

    uj5u.com 2020-09-10 07:00:50 more
  • Android 開發技術周報 Issue#293

    新聞 谷歌為Android TV開發者提供多種新功能 Android 11將自動填表功能整合到鍵盤輸入建議中 谷歌宣布Android Auto即將支持更多的導航和數字停車應用 谷歌Pixel 5只有XL版本 搭載驍龍765G且將比Pixel 4更便宜 [圖]Wear OS將迎來重磅更新:應用啟動時間 ......

    uj5u.com 2020-09-10 07:01:38 more
  • 海豚星空掃碼投屏 Android 接收端 SDK 集成 六步驟

    掃碼投屏,開放網路,獨占設備,不需要額外下載軟體,微信掃碼,發現設備。支持標準DLNA協議,支持倍速播放。視頻,音頻,圖片投屏。好點意思。還支持自定義基于 DLNA 擴展的操作動作。好像要收費,沒體驗。 這里簡單記錄一下集成程序。 一 跟目錄的build.gradle添加私有mevan倉庫 mave ......

    uj5u.com 2020-09-10 07:01:43 more
最新发布
  • 歡迎頁輪播影片

    如圖,引導開始,球從上落下,同時淡入文字,然后文字開始輪播,最后一頁時停止,點擊進入首頁。 在來看看效果圖。 重力球先不講,主要歡迎輪播簡單實作 首先新建一個類 TextTranslationXGuideView,用于影片展示 文本是類似的,最后會有個圖片箭頭影片,布局很簡單,就是一個 TextVi ......

    uj5u.com 2023-04-20 08:40:31 more
  • 【FAQ】關于華為推送服務因營銷訊息頻次管控導致服務通訊類訊息

    一. 問題描述 使用華為推送服務下發IM訊息時,下發訊息請求成功且code碼為80000000,但是手機總是收不到訊息; 在華為推送自助分析(Beta)平臺查看發現,訊息發送觸發了頻控。 二. 問題原因及背景 2023年1月05日起,華為推送服務對咨詢營銷類訊息做了單個設備每日推送數量上限管理,具體 ......

    uj5u.com 2023-04-20 08:40:11 more
  • 歡迎頁輪播影片

    如圖,引導開始,球從上落下,同時淡入文字,然后文字開始輪播,最后一頁時停止,點擊進入首頁。 在來看看效果圖。 重力球先不講,主要歡迎輪播簡單實作 首先新建一個類 TextTranslationXGuideView,用于影片展示 文本是類似的,最后會有個圖片箭頭影片,布局很簡單,就是一個 TextVi ......

    uj5u.com 2023-04-20 08:39:36 more
  • 【FAQ】關于華為推送服務因營銷訊息頻次管控導致服務通訊類訊息

    一. 問題描述 使用華為推送服務下發IM訊息時,下發訊息請求成功且code碼為80000000,但是手機總是收不到訊息; 在華為推送自助分析(Beta)平臺查看發現,訊息發送觸發了頻控。 二. 問題原因及背景 2023年1月05日起,華為推送服務對咨詢營銷類訊息做了單個設備每日推送數量上限管理,具體 ......

    uj5u.com 2023-04-20 08:39:13 more
  • iOS從UI記憶體地址到讀取成員變數(oc/swift)

    開發除錯時,我們發現bug時常首先是從UI顯示發現例外,下一步才會去定位UI相關連的資料的。XCode有給我們提供一系列debug工具,但是很多人可能還沒有形成一套穩定的除錯流程,因此本文嘗試解決這個問題,順便提出一個暴論:UI顯示例外問題只需要兩個步驟就能完成定位作業的80%: 定位例外 UI 組 ......

    uj5u.com 2023-04-19 09:16:23 more
  • FIDE重磅更新!性能飛躍!體驗有禮!

    FIDE 開發者工具重構升級啦!實作500%性能提升,誠邀體驗! 一直以來不少開發者朋友在社區反饋,在使用 FIDE 工具的程序中,時常會遇到諸如加載不及時、代碼預覽/渲染性能不如意的情況,十分影響開發體驗。 作為技術團隊,我們深知一件趁手的開發工具對開發者的重要性,因此,在2023年開年,FinC ......

    uj5u.com 2023-04-19 09:16:15 more
  • 游戲內嵌社區服務開放,助力開發者提升玩家互動與留存

    華為 HMS Core 游戲內嵌社區服務提供快速訪問華為游戲中心論壇能力,支持玩家直接在游戲內瀏覽帖子和交流互動,助力開發者擴展內容生產和觸達的場景。 一、為什么要游戲內嵌社區? 二、游戲內嵌社區的典型使用場景 1、游戲內打開論壇 您可以在游戲內繪制論壇入口,為玩家提供沉浸式發帖、瀏覽、點贊、回帖、 ......

    uj5u.com 2023-04-19 09:15:46 more
  • iOS從UI記憶體地址到讀取成員變數(oc/swift)

    開發除錯時,我們發現bug時常首先是從UI顯示發現例外,下一步才會去定位UI相關連的資料的。XCode有給我們提供一系列debug工具,但是很多人可能還沒有形成一套穩定的除錯流程,因此本文嘗試解決這個問題,順便提出一個暴論:UI顯示例外問題只需要兩個步驟就能完成定位作業的80%: 定位例外 UI 組 ......

    uj5u.com 2023-04-19 09:14:53 more
  • FIDE重磅更新!性能飛躍!體驗有禮!

    FIDE 開發者工具重構升級啦!實作500%性能提升,誠邀體驗! 一直以來不少開發者朋友在社區反饋,在使用 FIDE 工具的程序中,時常會遇到諸如加載不及時、代碼預覽/渲染性能不如意的情況,十分影響開發體驗。 作為技術團隊,我們深知一件趁手的開發工具對開發者的重要性,因此,在2023年開年,FinC ......

    uj5u.com 2023-04-19 09:14:08 more
  • 游戲內嵌社區服務開放,助力開發者提升玩家互動與留存

    華為 HMS Core 游戲內嵌社區服務提供快速訪問華為游戲中心論壇能力,支持玩家直接在游戲內瀏覽帖子和交流互動,助力開發者擴展內容生產和觸達的場景。 一、為什么要游戲內嵌社區? 二、游戲內嵌社區的典型使用場景 1、游戲內打開論壇 您可以在游戲內繪制論壇入口,為玩家提供沉浸式發帖、瀏覽、點贊、回帖、 ......

    uj5u.com 2023-04-19 09:08:34 more