时间:2021-07-02 08:56:21 | 栏目:Android代码 | 点击:次
Android中时间戳的详细解释:
(1).定义:
时间戳就是根据当前系统时间生成的一组随机数字。
(2).作用:
作为对数据唯一性的一种判断依据。避免了重复修改数据所带来的错误!
(3).应用:
(1).在银行account表中建立时间戳字段timestamp,设定为文本类型varchar。
(2).当银行A读取account表中的存款字段时,同时也读取时间戳字段,比如123456。
(3).当银行A修改完存款数值后,进行存盘操作时,将先前读取的时间戳123456与当时表中的时间戳进行一次对比,如果一致,那么允许存盘,然后生成一个新的时间戳比如456789替换表中原有的时间戳123456。
若没有使用时间戳:
银行A和银行B同时打开你的账户,看到的金额都是1000元。与此同时,两个银行读取的时间戳都是12345.
若使用时间戳:
当银行A打开账户的时候,把1000元改成1500元,存盘,系统将对比先前的时间戳与存盘时表中的时间戳是否一致,现在一致,允许存盘。存盘时,将生成了一个新的时间戳45678。B银行也将1000元修改成了1500元,存盘,系统对比先前的时间戳123456是否与存盘时表中的时间戳一致,发现先前的时间戳123456已经与现在的时间戳456789相异,系统拒绝存盘,要求刷新数据,那么数据刷新之后1000元已经因为之前A银行存入了500元而成为了1500元,那么B银行就会在1500元的基础上改为2000元,再次存盘,系统允许.
简而言之:就是在操作的时候,通过对比修改之前的数据表中的时间戳与修改之后的数据表中的时间戳是否一致。
若一致,允许存储,同时生成一个新的时间戳。
若不一致,就要求刷新数据,在新的数据上进行修改。再次存储。
引言
在性能调优时经常要打印函数执行时间、参数值等, 为了调试加了很多代码,调完后还要删掉, 这个事很繁琐。 我们可以用Android Profiler或methodtracing打印函数执行时间,但日志太多了且缺少参数值。所以JakeWharton写了个hugo库, 是用AspectJ实现的,基于AOP思想。 我看了hugo源码,总共四个文件左右,代码量很少。
我想做个同功能的插件,顺便学习一下gradle插件制作方法和字节码注入。
用法很简单,参考https://github.com/brycegao/TimePlugin/tree/master/demo
项目build.gradle文件里添加classpath和maven。
buildscript { repositories { google() jcenter() maven { url "https://dl.bintray.com/brycegmail/maven" } } dependencies { classpath 'com.android.tools.build:gradle:3.1.3' classpath 'com.brycegao.timeplugin:timeplugin:1.0.4' // NOTE: Do not place your application dependencies here; they belong // in the individual module build.gradle files } } allprojects { repositories { google() jcenter() maven { url "https://dl.bintray.com/brycegmail/maven" } } } task clean(type: Delete) { delete rootProject.buildDir }
在app模块的build.gradle文件添加
apply plugin: 'timeplugin' ... implementation 'com.brycegao.tpannotation:tpannotation:1.0.2'
在想打印日志的类或方法前添加注解@DebugLogger即可,用法参照hugo实现的。
@DebugLogger public class MainActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); showMsg(1, "this is test"); findViewById(R.id.btn_next).setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { Intent intent = new Intent(MainActivity.this, SecondActivity.class); startActivity(intent); } }); } private void showMsg(int i, String msg) { try { Thread.sleep(100); //仅仅为了测试 } catch (Exception ex) { ex.printStackTrace(); } } @Override public void onWindowFocusChanged(boolean hasFocus) { super.onWindowFocusChanged(hasFocus); } }
运行程序:
原理:
注解的作用表示要修改哪个函数, gradle插件的作用是遍历.class, Javassist是字节码注入工具。
在编译期间进行字节码注入, 打开./app/build/intermediates/classes/debug/transforms/TPTransform/1目录可以看到修改后的字节码。
优点:在编译期间注入业务逻辑代码,比在源码里加log更方便,不用feature时只要配置gradle 插件不参与编译即可。
展望:在编译期间加日志只是一个点, 还可以实现很多其它业务逻辑。
完整代码:https://github.com/brycegao/TimePlugin 求star
总结