String.hascode()

官方给出解释如下:

Returns a hash code for this string. The hash code for a String object is computed as

 s[0]*31^(n-1) + s[1]*31^(n-2) + ... + s[n-1]
 
using  int  arithmetic, where  s[i]  is the  i th character of the string,  n  is the length of the string, and  ^  indicates exponentiation. (The hash value of the empty string is zero.)

返回一个字符串的hash值,对字符串中的每一位字符按照以上公式进行计算,计算结果形成一个int类型的数字返回。其中S[0]是该字符串所对应的十进制数字,如“a”为49,“b”为50。

s[0]*31^(n-1)//其中n为该字符串的长度,31^(n-1)是31为底,n-1为指数的幂。

测试如下:

public static void main(String[] args) throws IOException
{
String t = "1";
System.out.println(t.hashCode());

}

public static void main(String[] args) throws IOException
{
String t = "2";
System.out.println(t.hashCode());

}

public static void main(String[] args) throws IOException
{
String t = "12";
System.out.println(t.hashCode());

}

三个函数返回的值分别为49,50,1569。恰好等于该公式所求出的值。

String.hashcode() & Integer.MAX_VALUE两者取与,使得转换后的数字能够在Integer数范围以内,防止越界。

### ApplicationInfo in Android Development #### Overview of ApplicationInfo In the context of Android development, `ApplicationInfo` represents metadata about an application package that is retrieved from the manifest file. This object contains various properties and flags which provide detailed information regarding how the application should operate within the system environment[^1]. The following attributes are part of this class: - **packageName**: The name of the package. - **sourceDir**: Absolute path to the .apk file on disk. - **publicSourceDir**: Public source directories (for split APKs). - **dataDir**: Directory where persistent data can be stored by the app. - **nativeLibraryDir**: Path to native libraries directory. Additionally, several boolean fields indicate specific characteristics or capabilities such as whether it has code (`hasCode`) or supports small screens (`supportsSmallScreens`). There also exist methods like `loadLabel()`, allowing developers to access human-readable labels defined inside `<application>` tags. #### Retrieving Information Using PackageManager Developers often interact with instances of `ApplicationInfo` via the `PackageManager`. By calling appropriate APIs provided by `PackageManager`, one can obtain details concerning installed applications including their icons, names, permissions required, etc., all encapsulated within objects derived from `PackageItemInfo`. For instance, when querying for packages using `getInstalledApplications(int flags)` method, each result will contain its corresponding `ApplicationInfo` structure filled out based upon what was specified under respective `<application>` elements found during parsing process conducted over `AndroidManifest.xml`. ```java // Example Code Snippet Showing How To Get An Instance Of ApplicationInfo From Package Name try { String targetPackageName = "com.example.app"; Context context = getApplicationContext(); PackageManager pm = context.getPackageManager(); // Retrieve Application Info With Specific Flags Applied For More Detailed Data int flagValue = PackageManager.GET_META_DATA; ApplicationInfo ai = pm.getApplicationInfo(targetPackageName, flagValue); } catch (NameNotFoundException e) { Log.e("Error", "Failed to find info"); } ``` --related questions-- 1. What other classes extend from PackageItemInfo besides ApplicationInfo? 2. Can you explain more about the role of PackageManager in managing apps' lifecycle events? 3. In what scenarios would someone need to use GET_UNINSTALLED_PACKAGES flag while fetching ApplicationInfo? 4. Is there any difference between accessing ApplicationInfo through Activity versus Service components?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值