diff --git a/123/123.docx b/123/123.docx new file mode 100644 index 0000000..e69de29 diff --git a/src/app/src/main/java/net/micode/notes/data/Contact.java b/src/app/src/main/java/net/micode/notes/data/Contact.java index d97ac5d..6c3dee9 100644 --- a/src/app/src/main/java/net/micode/notes/data/Contact.java +++ b/src/app/src/main/java/net/micode/notes/data/Contact.java @@ -29,24 +29,47 @@ public class Contact { private static HashMap sContactCache; private static final String TAG = "Contact"; - private static final String CALLER_ID_SELECTION = "PHONE_NUMBERS_EQUAL(" + Phone.NUMBER + /** + * 用于查询联系人数据库的SQL选择条件字符串。 + * 该字符串定义了查询条件,用于匹配与给定电话号码相关联的联系人。 + * 条件包括: + * 1. 电话号码与查询参数相等。 + * 2. 数据MIME类型为电话类型。 + * 3. 数据行的RAW_CONTACT_ID必须存在于phone_lookup表中,且min_match字段为'+'。 + */ +private static final String CALLER_ID_SELECTION = "PHONE_NUMBERS_EQUAL(" + Phone.NUMBER + ",?) AND " + Data.MIMETYPE + "='" + Phone.CONTENT_ITEM_TYPE + "'" + " AND " + Data.RAW_CONTACT_ID + " IN " + "(SELECT raw_contact_id " + " FROM phone_lookup" + " WHERE min_match = '+')"; + + /** + * 根据给定的电话号码获取联系人名称。 + * 该方法首先检查缓存中是否已存在该电话号码对应的联系人名称,如果存在则直接返回缓存中的结果。 + * 如果缓存中不存在,则通过查询系统联系人数据库来获取联系人名称,并将结果缓存以备后续使用。 + * + * @param context 上下文对象,用于访问内容解析器。 + * @param phoneNumber 需要查询的电话号码。 + * @return 返回与电话号码对应的联系人名称,如果未找到则返回null。 + */ public static String getContact(Context context, String phoneNumber) { + // 初始化联系人缓存 if(sContactCache == null) { sContactCache = new HashMap(); } + // 检查缓存中是否已存在该电话号码对应的联系人名称 if(sContactCache.containsKey(phoneNumber)) { return sContactCache.get(phoneNumber); } + // 构建查询条件,用于在联系人数据库中查找匹配的电话号码 String selection = CALLER_ID_SELECTION.replace("+", PhoneNumberUtils.toCallerIDMinMatch(phoneNumber)); + + // 查询联系人数据库,获取与电话号码对应的联系人名称 Cursor cursor = context.getContentResolver().query( Data.CONTENT_URI, new String [] { Phone.DISPLAY_NAME }, @@ -54,6 +77,7 @@ public class Contact { new String[] { phoneNumber }, null); + // 如果查询结果不为空,则获取联系人名称并缓存 if (cursor != null && cursor.moveToFirst()) { try { String name = cursor.getString(0); @@ -66,6 +90,7 @@ public class Contact { cursor.close(); } } else { + // 如果未找到匹配的联系人,记录日志并返回null Log.d(TAG, "No contact matched with number:" + phoneNumber); return null; }