1.auto_ptrç代ç
2.AAUçç¼ç¨è¯è¨
3.Spring注解驱动开发二狗子让我给他讲讲@EnableAspectJAutoProxy注解
4.autojs之lua
5.C++基础:auto_ptr的源码特性与源码浅析
6.autojsproå®ç¾ç ´è§£çï¼
auto_ptrç代ç
å¨C++ä¸ï¼ auto_ptræ¯ä¸ä¸ªç±»ï¼å®ç¨æ¥å®ç°å¯¹å¨æåé 对象çèªå¨éæ¾ãå®çæºä»£ç ï¼ template<class T>class auto_ptr{ private: T*ap;public: //constructor & destructor-----------------------------------(1) explicit auto_ptr(T*ptr=0)throw():ap(ptr) { } ~auto_ptr()throw() { delete ap; } //Copy & assignment--------------------------------------------(2) auto_ptr(auto_ptr& rhs)throw():ap(rhs.release()) { } template<class Y> auto_ptr(auto_ptr<Y>&rhs)throw():ap(rhs.release()) { } auto_ptr& operator=(auto_ptr&rhs)throw() { reset(rhs.release()); return*this; } template<class Y> auto_ptr& operator=(auto_ptr<Y>&rhs)throw() { reset(rhs.release()); return*this; } //Dereference----------------------------------------------------(3) T& operator*()const throw() { return*ap; } T* operator->()const throw() { returnap; } //Helper functions------------------------------------------------(4) //value access T* get()const throw() { returnap; } //release owner ship T* release()throw() { T*tmp(ap); ap=0; return tmp; } //reset value void reset(T*ptr=0)throw() { if(ap!=ptr) { deleteap; ap=ptr; } } //Special conversions-----------------------------------------------(5) template<class Y> struct auto_ptr_ref { Y*yp; auto_ptr_ref(Y*rhs):yp(rhs){ } }; auto_ptr(auto_ptr_ref<T>rhs)throw():ap(rhs.yp) { } auto_ptr& operator=(auto_ptr_ref<T>rhs)throw() { reset(rhs.yp); return*this; } template<class Y> operator auto_ptr_ref<Y>()throw() { returnauto_ptr_ref<Y>(release()); } template<class Y> operator auto_ptr<Y>()throw() { returnauto_ptr<Y>(release()); }};
AAUçç¼ç¨è¯è¨
AAUæ¯AAutoç¼ç¨è¯è¨çç®ç§°, *.aau æ¯AAutoçæºç æä»¶æ ¼å¼ï¼AAutoæ¯ä¸ç¨äºæ¡é¢è½¯ä»¶å¿«éå¼åçæ°ä¸ä»£æ··ååç¼ç¨è¯è¨ï¼ å ¼å ·å¨æãéæè¯è¨ä¼å¿ï¼è¯æ³æ´å¯å ¼å®¹å¤§é¨åæµè¡è¯è¨ï¼å¦ä¹ ææ¬ä½ï¼å¼åé度快ï¼å¹¶æ°¸ä¹ å è´¹ã
AAutoæ¯ä¸ç§å¨æè¯è¨ï¼ä½æ¯åæ¶æ¯æéæç±»åå¼åï¼ä¸é¢ç代ç å®ä¹äºä¸ä¸ªç»æä½ï¼å¨è¿ä¸ªç»æä½ä¸å¯ä»¥è±¡éæè¯è¨ä¸æ ·ä½¿ç¨éæç±»åï¼åå¯ä»¥è±¡å¨æè¯è¨ä¸æ ·ä½¿ç¨å¨æç±»å;
//å®ä¹ç±»
class POINT {
int x; int y; //éæç±»å
func = function(){
//å¨æç±»å
}
}
è¿ç§å ¨æ°çæ··åç¼ç¨è¯è¨å¼åäºä¸ç§å ¨æ°çç¼ç¨æ¹å¼ï¼AAutoæ¥æå¨æè¯è¨è½»ä¾¿ãçµæ´»ãå¿«éå¼åçç¹æ§ï¼åæ¶åå¯ä»¥è±¡éæè¯è¨ä¸æ ·å¼ºå¤§ï¼ç´æ¥æ¯æåçDLLï¼æ¹ä¾¿ç声æAPIå½æ°ï¼å¹¶ä¸å¯ä»¥å°AAutoçå½æ°å¯¹è±¡è½¬æ¢ä¸ºCè¯è¨å ¼å®¹çå½æ°æéï¼å³ä½¿æ¯å¤é¨EXEè¿ç¨ä¸çå½æ°ï¼ä¹å¯ä»¥ä½¿ç¨ä¸å¥ä»£ç 声æ为æ®éçAAutoå½æ°å¯¹è±¡( åçcallæ¯æ )ã
AAutoè½ç¶å°ï¼ä½æ¯æ¯æçæ¥å£å¾ä¸°å¯ï¼å¯æ¯ææ åDLLçstdcallï¼cdeclï¼thiscallçè°ç¨çº¦å®ï¼å¯ä»¥æ¯æC++导åºç类对象ï¼å¯ä»¥æ¯æcoméæå¨æåæ¥å£ï¼è±¡VBSä¸æ ·åçæ¯æcom对象ã
AAutoè¿å¯ä»¥ç´æ¥åµå ¥æ±ç¼æºå¨ç ï¼Cè¯è¨ï¼Javaï¼PHPï¼C#ï¼Pythonï¼Javascriptï¼VBScript......ççæ°éä¼å¤ç第ä¸æ¹ç¼ç¨è¯è¨ï¼æ¹ä¾¿çäºè°å½æ°ï¼å¹¶ä¸è¿äºè°ç¨ç¬¬ä¸è¨è¯è¨çåè½æ¨¡åé½æ¯ä½¿ç¨AAutoå®ç°ï¼å¹¶ä¸å¼æ¾æºç ãæ··ååè¯è¨è®©æ们å¯ä»¥ä½éªå°æ¿å¨äººå¿çå ¨æ°ç¼ç¨æ¹å¼ã
AAutoå¯ä»¥å°ç¡¬çç®å½ï¼ç¡¬çæ件ä¸é®åµå ¥EXEæ件ï¼å°å ¨é¨ç¨åºå å«ææèµæºçæç¬ç«ç绿è²EXEæ件ï¼æææ件读åçç¸å ³å½æ°èªå¨æ¯æï¼æ éæ´æ¹ä»£ç ï¼AAutoå¶ä½çç¨åºä¸éè¦å®è£ ç¨åºï¼ä¹ä¸éè¦éæ¾DLLè¿è¡åºï¼AAutoå¶ä½çç¨åºé½æ¯å å®è£ 绿è²è½¯ä»¶ã
AAutoè¯æ³ä¼ç¾ï¼æå¤§å ¼å®¹æµè¡çCç³»ï¼Pascalè¯æ³ï¼å¹¶ä¸å¯ä»¥èªå®ä¹ä¸å¥èªå·±çè¯æ³ãæå ¶ä»è¯è¨åºç¡çå¯ä»¥è½»æ¾ä¸æï¼å¦ä¹ AAuto以åå¦ä¹ å ¶ä»ç¼ç¨è¯è¨æ´å¯äºåååï¼AAutoä¸è±¡å ¶ä»çä¸äºç¼ç¨è¯è¨ï¼å¨è¯æ³é£æ ¼ï¼å½æ°å½åä¸é½ä¿æäºè¯å¥½çå ¼å®¹æ§ãéç¨æ§ã
AAutoåçæ¯æå¤çº¿ç¨å¼åï¼å¤æçå¤çº¿ç¨å¼åå¨AAutoä¸åå¾é常ç®åï¼AAutoææ对象å 天线ç¨å®å ¨ï¼èªå¨è§£å³ææ并åé®é¢ï¼æ ååºæä¾å¤§éç®åå¤çº¿ç¨å¼åçè¾ å©æ¯æåºãä¾å¦ thread.command å®ç°ç线ç¨å½ä»¤è®¢é 模å¼ï¼ä¸ºå¤çº¿ç¨è½¯ä»¶å¼å带æ¥å¾å¤§çæ¹ä¾¿ã
AAutoçæ ååºåºæ¬ä½¿ç¨çº¯AAutoæºç å®ç°ï¼å¹¶ä¸å ¨é¨å¼æºï¼æ ååºæä¾äºå¤§éçç®åç¼ç¨ç常ç¨å½æ°ï¼æ¶åå°è½¯ä»¶å¼åçæ¹æ¹é¢é¢ï¼æ大çç®åäºæ¡é¢è½¯ä»¶å¼åè¿ç¨ã
Spring注解驱动开发二狗子让我给他讲讲@EnableAspectJAutoProxy注解
在配置类上添加@EnableAspectJAutoProxy注解,能够开启注解版的分享AOP功能。这意味着,源码如果在AOP中要启用注解版的分享AOP功能,就需要在配置类上添加@EnableAspectJAutoProxy注解。源码让我们来看看@EnableAspectJAutoProxy注解的分享预约课时 源码源码,如下所示。源码
从源码可以看出,分享@EnableAspectJAutoProxy注解使用@Import注解引入了AspectJAutoProxyRegister.class对象。源码那么,分享AspectJAutoProxyRegistrar是源码做什么的呢?我们点击到AspectJAutoProxyRegistrar类的源码中,如下所示。分享
可以看到AspectJAutoProxyRegistrar类实现了ImportBeanDefinitionRegistrar接口。源码我们回顾ImportBeanDefinitionRegistrar接口的分享定义,如下所示。源码
通过ImportBeanDefinitionRegistrar接口,我们可以实现将自定义的组件添加到IOC容器中。也就是宝藏公式源码说,@EnableAspectJAutoProxy注解使用AspectJAutoProxyRegistrar对象自定义组件,并将相应的组件添加到IOC容器中。
在AspectJAutoProxyRegistrar类的registerBeanDefinitions()方法中设置断点,我们以debug的方法来运行AopTest类的testAop()方法。当程序运行到断点位置时,我们可以看到程序已经暂停,IDEA的左下角显示了方法的调用栈。
在registerBeanDefinitions()方法中,首先调用AopConfigUtils类的registerAspectJAnnotationAutoProxyCreatorIfNecessary()方法来注册registry。在registerAspectJAnnotationAutoProxyCreatorIfNecessary()方法中,直接调用了重载的registerAspectJAnnotationAutoProxyCreatorIfNecessary()方法。在重载的registerAspectJAnnotationAutoProxyCreatorIfNecessary()方法中,传入了AnnotationAwareAspectJAutoProxyCreator.class对象。
在registerOrEscalateApcAsRequired()方法中,接收到的Class对象的类型为:org.springframework.aop.aspectj.annotation.AnnotationAwareAspectJAutoProxyCreator。然后,我们继续跟进代码。源码度娘
在registerOrEscalateApcAsRequired()方法中,首先判断registry是否包含org.springframework.aop.config.internalAutoProxyCreator类型的bean。接下来,我们继续看代码。
最终,AopConfigUtils类的registerOrEscalateApcAsRequired()方法中,会通过registry调用registerBeanDefinition()方法注册组件,并注册的bean的名称为org.springframework.aop.config.internalAutoProxyCreator。
接下来,我们继续看AspectJAutoProxyRegistrar类的registerBeanDefinitions()源码。我们通过AnnotationConfigUtils类的attributesFor方法来获取@EnableAspectJAutoProxy注解的信息。接下来,我们继续判断proxyTargetClass属性的值是否为true,如果为true则调用AopConfigUtils类的forceAutoProxyCreatorToUseClassProxying()方法;继续判断exposeProxy属性的值是否为true,如果为true则调用AopConfigUtils类的forceAutoProxyCreatorToExposeProxy()方法。
综上所述,向Spring的够完美源码配置类上添加@EnableAspectJAutoProxy注解后,会向IOC容器中注册AnnotationAwareAspectJAutoProxyCreator。
了解了这些之后,我们就可以关注「冰河技术」微信公众号,后台回复不同的关键字获取相应的PDF文档。这些文档都是由冰河原创并整理的超硬核教程,包括《深入浅出Java 种设计模式》、《Java8新特性教程》和《亿级流量下的分布式限流解决方案》,都是面试必备的资料。
最后,如果你觉得这篇文章对你有帮助,别忘了点个赞,给个在看和转发,让更多的人看到,一起学习,一起进步!
autojs之lua
在autojs中使用lua能提升自动化脚本的灵活性和功能。为了实现这一目标,分时强弱 源码依赖于一个名为luaJ的java实现的lua脚本解释器。下面将逐步展示如何在autojs中集成lua,以及实现的步骤和效果展示。
首先,导入luaJ类,这是实现lua脚本运行的基础。确保在项目中正确导入此类,以利用luaJ的解释功能。
接下来,创建一个Globals对象,用于管理全局状态。通过这个对象,可以轻松地在脚本中访问和设置全局变量,使脚本的使用更加灵活。
之后,执行lua文件成为关键步骤。通过加载lua文件并调用其中的函数或执行指令,可以实现自动化的任务,如模拟用户操作、自动化数据处理等。
获取lua变量的值,是进一步操作的基础。这允许根据脚本中的逻辑,动态地访问和使用变量,从而实现复杂的功能。
还有一种运行lua脚本的方式,即通过直接执行lua代码,而非加载文件。这种方式适合编写和执行简短的脚本,或在脚本执行过程中动态生成代码。
在实际应用中,一个典型的lua代码示例可以是自动化点击操作。通过编写简单的脚本,可以模拟用户点击屏幕上的特定位置,实现自动化任务。
完整源码示例如下:
lua
Globals.set('clickPosition', { x: , y: })
function doClick()
local position = Globals.get('clickPosition')
TouchAction(device).tap({ x: position.x, y: position.y}).perform()
end
以上源码展示了如何在autojs中集成lua,通过导入luaJ类、创建全局变量、执行lua代码来实现自动化功能。使用这种方法,可以极大地提升自动化脚本的效率和可扩展性。
C++基础:auto_ptr的特性与源码浅析
在C++的早期版本中,auto_ptr是一种智能指针,但在C++之后被标记为废弃。理解其废弃原因前,我们首先来探讨auto_ptr的特性及其源码解析。
C++中的auto_ptr具有独特的特性,体现在其核心代码(Visual Studio .0/VC/include/xmemory中的实现)中。关键在于其拷贝构造函数和赋值操作符的参数类型,它们都是auto_ptr的引用,而非const auto_ptr的引用。这种设计的目的是确保auto_ptr对裸指针拥有唯一控制权,防止出现多份auto_ptr指向同一裸指针,从而导致内存泄漏或程序崩溃。然而,尝试将const auto_ptr传递给这些操作会引发编译错误,因为auto_ptr不具备接受const引用的拷贝构造函数。
代码示例中的错误就源于此,编译器无法处理这种构造。实际上,vector的push_back函数要求参数为const value_type的引用,而auto_ptr缺少这个功能,因此导致了编译失败。
随着C++引入了unique_ptr,它作为auto_ptr的替代品,提供了更完善的独占式指针管理,使得auto_ptr的废弃变得合理。unique_ptr避免了auto_ptr的缺陷,因此在新的标准中,auto_ptr的使用被推荐替换为unique_ptr,以确保代码的健壮性和性能。
autojsproå®ç¾ç ´è§£çï¼
Autojs微信èªå¨æä½å rootèæ¬æºç
æ们å¯ä»¥æ³ä¸ä¸åå ³å ¬ä¼å·çæ¥éª¤ï¼éæ©å ¬ä¼å·é¿æåæ¶ãæå¼å¾®ä¿¡è¿å ¥æåå页é¢æ§è¡èæ¬å°±å¯èªå¨ç¹èµãæå¼å¾®ä¿¡è¿å ¥è§é¢å·é¡µé¢å°±å¯èªå¨ç¹èµè¯è®ºã
ç®å讲就æ¯æ érootå°±å¯æ§è¡èæ¬å®ç°ææºèªå¨åæä½ãæå¼Autojsæ¥çå¸å±è·åç¹èµæ¡æ¶ä¿¡æ¯ï¼æ们å¯ä»¥çå°ç¹èµç©ºé´ç¹å»å±æ§ä½Falseè¿æ¶æ们å¯ä»¥æ¾ä»çç¶äº²æ¡æ¶è¿è¡æ¥çç´å°ç¹å»å±æ§ä½trueã
AutoJsææ°çæ¬apkç¹è²ï¼ç®åæç¨çèªå¨æä½å½æ°ï¼æ¬æµ®çªå½å¶åè¿è¡ï¼ä¸°å¯çææ¡£ãæç¨ä¸ç¤ºä¾ï¼æ´ä¸ä¸&强大çéæ©å¨APIï¼æä¾å¯¹å±å¹ä¸çæ§ä»¶ç寻æ¾ãéåãè·åä¿¡æ¯ãæä½çã
Autojsæ£æµå¹¶å¼å¯æ éç¢æå¡Auto.jsProåºäºæ§ä»¶çæä½ä¾èµäºæ éç¢æå¡ï¼å æ¤æ好å¨èæ¬è¿è¡å¼å§æ¶ï¼ç¡®ä¿æ éç¢æå¡å·²ç»å¯ç¨ãå¦æè¿è¡å°æ个éè¦æéçè¯å¥æ éç¢æå¡å¹¶æ²¡å¯å¨ï¼åä¼æåºå¼å¸¸å¹¶è·³è½¬å°æ éç¢æå¡çé¢ãè¿æ ·çç¨æ·ä½éªå¹¶ä¸å好ã
ä¸è¬å¤§é¨å软件é½ä¼ç´æ¥æ£ç´¢å¼å¯æ éç¢æå¡çåºç¨ä»èå¤å®ä½ æ¯å¦ä½¿ç¨èæ¬ã
å¨å®å设å¤ä¸å®è£ Auto.jsåºç¨ç¨åºãæå¼Auto.jsåºç¨ç¨åºï¼ç¹å»å·¦ä¸è§çèåæé®ï¼éæ©â设置âãå¨è®¾ç½®é¡µé¢ä¸ï¼æ¾å°âæ éç¢æå¡âé项ï¼ç¹å»è¿å ¥ãå¨æ éç¢æå¡é¡µé¢ä¸ï¼æ¾å°âAuto.jsâé项ï¼ç¹å»è¿å ¥ã
å¯ä»¥ãautojsæ¯å¯ä»¥ä¸å¼å¯æ éç¢æå¡è¿è¡çï¼æ¯ä¸æ¬¾æ°çææºèæ¬å¼åå·¥å ·ï¼å¼åè¯è¨æ¯JSï¼å¼åé¨æ§ä½ï¼åè¿ç½ç«å¼åçé½ä¼åJSã
autojsproæ¯ä»ä¹autojsproæ¯ä¸ä¸ªåèæ¬çä»è´¹è½¯ä»¶ã
AutoJSProå¨ææºä¸å¯ä»¥ä½¿ç¨File.save()å½æ°æ¥ä¿åæ件ï¼å¯ä»¥æå®æ件ååæ件å 容ï¼ä»¥åæ件çåå¨è·¯å¾ã
Auto.jsProåºäºæ§ä»¶çæä½ä¾èµäºæ éç¢æå¡ï¼å æ¤æ好å¨èæ¬è¿è¡å¼å§æ¶ï¼ç¡®ä¿æ éç¢æå¡å·²ç»å¯ç¨ãå¦æè¿è¡å°æ个éè¦æéçè¯å¥æ éç¢æå¡å¹¶æ²¡å¯å¨ï¼åä¼æåºå¼å¸¸å¹¶è·³è½¬å°æ éç¢æå¡çé¢ãè¿æ ·çç¨æ·ä½éªå¹¶ä¸å好ã
autosar E2E 源码解析
在多年的实践应用中,我们曾利用E2E技术来确保车速和转速信息的准确性,通过在报文里加入Check和RollingCounter信号,监测信号的完整性和一致性。虽然起初可能觉得这种额外的使用是资源浪费,但其实是对总线负载的有效管理。E2E的核心其实并不复杂,本质上是CRC校验和滚动计数器的结合,不同厂商可能在位序和配置上有所差异,但原理相通。
具体到源码操作,发送E2E报文的过程如下:首先从SWC获取E2E信号值,然后通过vector库进行处理,校验AppData的指针,配置报文,组织msg,更新E2E buffer,并进行CRC和滚动计数器的更新。最后,通过RTE接口发送信号。
接收E2E报文则与发送过程相反,包括准备接收缓冲区,调用库函数读取数据,验证数据和计数器,将接收到的数据结构赋值,检查接收和本地滚动计数器的匹配,以及校验CRC结果。整个过程旨在确保数据的完整性和正确性。