为什么很多人写代码会在变量名前面加一个小写的m?

本文详细解释了Android源码中变量命名的规范,包括非公有变量前缀使用m、静态变量前缀使用s等,并提供了示例代码帮助理解。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近在读Android源码,发现很多系统变量命名时都加了m,而有的变量又没有加m,这是什么情况?

于是Google了一把,“letter m before variable ”,第一条结果是来自stackoverflow的答案。

终于看到一个不同的答案了, The use of the "m" prefix is more specific than simply denoting a "member" variable.这个是Google官方的介绍。

http://source.android.com/source/code-style.html#follow-field-naming-conventions

  • Non-public, non-static field names start with m.

  • Static field names start with s.

  • Other fields start with a lower case letter.

  • Public static final fields (constants) are ALL_CAPS_WITH_UNDERSCORES.

For example:

[java]  view plain  copy
  1. public class MyClass {  
  2.     public static final int SOME_CONSTANT = 42;  
  3.     public int publicField;  
  4.     private static MyClass sSingleton;  
  5.     int mPackagePrivate;  
  6.     private int mPrivate;  
  7.     protected int mProtected;  
  8. }  


非公有的变量前面要加上小写m,

静态变量前面加上小写s,

其它变量以小写字母开头,

静态变量全大写。


除了protected外,其它的带有m的变量在子类中是无法访问的。

看起来你在提到一段代码,它可能存在一些问题,并且建议将变量名简化为小写字母以提高代码可读性。简洁的代码通常更易于理解和维护。在调整变量名时,应保持其含义明确,比如将`ExtendedEuclideanAlgorithm`这样的全大字母名称改为`extendedEuclid`,或将`SolutionFinder`改为`solution`. 例如,如果原代码片段如下: ```cpp int ExtendedEuclidean(int A, int B, int& X, int& Y) { if (B == 0) { X = 1; Y = 0; return A; } int D = ExtendedEuclidean(B, A % B, Y, X); Y -= A / B * X; return D; } int FindSolution(int bigA, int bigB) { int GCDValue; GCDValue = ExtendedEuclidean(bigA, bigB, X, Y); // 错误:这里应使用之前计算好的X和Y if (GCDValue != 1) { return -1; // 方程无解 } else { int InverseB = ModularInverse(bigB, bigB); // 错误:这里也应使用之前计算的结果 int SolutionCandidate = (X * InverseB) % bigB; // 还需要检查并返回最小正解 return SolutionCandidate; } } int ModularInverse(int BigA, int Modulus) { int X, Y, G; G = ExtendedEuclidean(BigA, Modulus, X, Y); if (G == 1) return (X % Modulus + Modulus) % Modulus; else return -1; } ``` 我们可以简化如下: ```cpp int extended_euclid(int a, int b, int& x, int& y) { // ... } int find_solution(int a, int b) { int x, y, gcd = extended_euclid(a, b, x, y); if (gcd != 1) { return -1; } int inv_b = get_inverse(b); // 使用新函数get_inverse代替ModularInverse int sol = (x * inv_b) % b; return sol; } int get_inverse(int num, int mod) { // ... } ``` 在这段简化的代码中,我们更改了函数名、变量名和局部变量命名,并移除了不必要的全局变量。同时,把模运算的逆元计算封装到新的函数`get_inverse`中。记得检查每个函数的内部实现是否正确。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值