1.前端开发Lua篇——LuaJIT
2.androidå¼åç¨ä»ä¹è¯è¨ï¼
3.androidå¼åè¯è¨ï¼
4.什么是源码跨终端
前端开发Lua篇——LuaJIT
三十六计手游采用LuaJIT实现游戏逻辑,但在特定场景下禁用了JIT模式。源码具体操作步骤如下:
1. 首先,源码从LuaJIT官网获取与cocos2dx引擎版本一致的源码库文件。例如,源码针对cocos2dx版本号3.,源码json动画源码需确保lua和jit的源码版本信息与库文件相匹配,避免因版本不一致而导致"cannot load incompatible bytecode"错误。源码
2. 利用命令行工具进行编译。源码在mac操作系统中,源码直接执行"make"即可完成编译;对于win用户,源码需先配置VSCommandPrompt,源码执行参数为"/k \"C:\\Program Files (x)\\Microsoft Visual Studio .0\\Common7\\Tools\\VsDevCmd.bat\"",源码然后进入jit源代码目录并运行"msvcbuild.bat"进行编译。源码
3. 使用"luajit -b"命令生成bytecode,源码此步骤生成的bytecode在runtime中通过interpreter模式运行。值得注意的是,jit bytecode生成后,行号钩子失效,可能影响基于行号的debug或profile操作,需要进行相应的调整。
考虑到不同平台对JIT模式的处理,ios系统默认关闭JIT,而android则需通过"jit.off()"进行手动关闭。在游戏开发中,对JIT模式的使用需谨慎考虑,以避免可能的性能损耗。
在禁用JIT模式后,游戏开发者可能会考虑使用luac而非jit的bytecode。然而,nginx源码源码针对iOS禁用JIT、Android主动关闭JIT,以及可能面临其他平台不稳定情况,仍选择使用jit的bytecode具有以下优势:
1. 减少体积,提高包体、内存、转化率和热更文件大小的效率。相较于luac,jit的bytecode体积减少了约%。
2. 加速require代码时的load过程,性能提升达倍。在禁用JIT的环境下,性能特性与luac保持一致,无需对代码进行额外优化。
androidå¼åç¨ä»ä¹è¯è¨ï¼
æ³å¦ä¹ å®åç³»ç»çå¼åéè¦å¦ä¹ ä»ä¹ç¼ç¨è¯è¨_å®åå¼åç¨ä»ä¹ç¼ç¨è¯è¨
éè¦å¦ä¹ 以ä¸ä¸¤ç§ç¼ç¨è¯è¨ï¼åå«æ¯ï¼
Javaè¯è¨
Androidåºç¨ç¨åºå¼åæ¯ä»¥Javaè¯è¨ä¸ºåºç¡çï¼æ以没æåå®çJavaåºç¡å¸¸è¯ï¼åªæ¯æºæ¢°çç §æä»äººç代ç ï¼æ¯æ²¡æä»»ä½å«ä¹çãå 为å¨Androidä½ç³»çæ¡æ¶å±å½ä¸ï¼ä½¿ç¨äºå¾å¤ç设计形å¼ï¼åå¦æ²¡æè¿ä¸ªæ¹é¢ç常è¯ï¼å ³äºAndroidçäºè§£å°±ä¼å¤§æææ£ãè§åå½¢å¼çç§ç±»ååä¹å¤ï¼ä¸ä¸ªä¸ä¸ªçå ¨é¨ææ¡ï¼æ¯ä¸ç°å®çï¼æè¡ç¢§æå¿ è¦é¦å ææ¡é¢å对象çåºç¡è®¾è®¡ååï¼æäºè¿äºåºç¡ååçæ¯æï¼å°±å¯ä»¥è§¦ç±»æéã
C/Cè¯è¨
Cè¯è¨æ¯ä¸ç§ç»æåè¯è¨ãå®å±æ¬¡æ¸ æ°ï¼ä¾¿äºæ §å¯æ模ååæ¹æ³å®æç¨åºï¼æäºè°è¯åä¿æ¤ãCè¯è¨çä½ç°æè½è£¤ç¾¡åå¤çæè½æ强ãå®ä¸åªå ·æ丰ççè¿ç®ç¬¦åæ°æ®ç±»åï¼ä¾¿äºå®æåç±»æä¹±çæ°æ®ç»æãCè¯è¨æ¯å½ä»æçè¡çç¨åºè®¾è®¡è¯è¨ä¹ä¸ï¼å®çåç¨ä¸°çã表达å强ãè¿ç¨æ´»ç»ä¾¿å½ãè¿ç¨é¢å¹¿ãæ¿çç¨åºé«ãå¯æ¤å ¥æ§å¥½ï¼æ¢æé«çº§è¯è¨çç¹å¾ï¼åæä½çº§è¯è¨ç许å¤ç¹å¾ï¼éå®ä½ä¸ºç³»ç»æç»è¯è¨ï¼æ¢è½å¤ç¨æ¥ç¼åç³»ç»è½¯ä»¶ï¼ä¹è½å¤ç¨æ¥ç¼åè¿ç¨è½¯ä»¶ã
androidæ¯ç¨ä»ä¹è¯è¨å¼åç_androidææºappå¼åè¯è¨androidæ¯åºäºlinuxçå¼æºæä½ç³»ç»ã
linuxæ¯ä½¿ç¨æ åCè¯è¨å¼åçæä½ç³»ç»ã
androidåºå±é©±å¨ä»¥åæä½ç³»ç»å æ ¸ä½¿æ亩ç¨Cè¯è¨ä»¥åæ±ç¼å¼åã
androidæä½ç³»ç»æ¬èº«æ¯ä½¿ç¨Javaå¼åï¼å¹¶ä½¿ç¨JNIè°ç¨æ¬å°çCè¯è¨åºï¼å®ç°æä½ç³»ç»åºå±è°åº¦ã
androidåºç¨æ¯ä½¿çè¿ æ£®ç¨Javaå¼åï¼åæ¶ä¹å¯ä»¥ä½¿ç¨C/Cnativeå¼åï¼ä½æ¯å¤æ°æ¶åä¸ææ¿ç¨ç¨å°Cãæ以åºæ¬ä¸å°±æ¯Java为æ åå¼åè¯è¨ã
android使ç¨äºä¿®æ¹è¿çJVMï¼Javaèææºï¼å«ådalvikèææºï¼å ¶æ¬è´¨è¿æ¯Javaèææºã
æ以对åºæ¯ä¸ä¸ªAPPé½ä¼å建个dalvikèææºï¼ä¹å°±æ¯ä¸ä¸ªlinuxè¿ç¨ã
说å¤æäºï¼å ¶å®å°±æ¯åºäºlinuxä¸çä¿®æ¹çJavaèææºï¼è¿è¡javaç¨åºã
å¸æè½å¤å¸®å°ä½ ï¼
Androidå¼åé½éè¦ä½¿ç¨ä»ä¹è¯è¨ï¼
Androidå¼åé½éè¦ä½¿ç¨ä»ä¹è¯è¨ï¼
Androidæ¯ä»¥Linuxä¸ºæ ¸å¿çææºæä½å¹³å°ï¼ä½ä¸ºä¸æ¬¾å¼æ¾å¼çæä½ç³»ç»ï¼éçAndroidçå¿«éåå±ï¼å¦ä»å·²å 许å¼åè 使ç¨å¤ç§ç¼ç¨è¯è¨æ¥å¼åAndroidåºç¨ç¨åºï¼èä¸åæ¯ä»¥ååªè½ä½¿ç¨Javaå¼åAndroidåºç¨ç¨åºçåä¸å±é¢ãé£ä¹ï¼Androidç³»ç»é½è½ä½¿ç¨åªäºè¯è¨æ¥å¼åå¢ï¼
å¨Androidä¸ï¼å¼åè å¯ä»¥ä½¿ç¨Javaä½ä¸ºç¼ç¨è¯è¨æ¥å¼ååºç¨ç¨åºï¼ä¹å¯ä»¥éè¿AndroidNDK使ç¨C/C++ä½ä¸ºç¼ç¨è¯è¨æ¥å¼ååºç¨ç¨åºï¼ä¹å¯ä½¿ç¨SL4Aæ¥ä½¿ç¨å ¶ä»åç§èæ¬è¯è¨è¿è¡ç¼ç¨
ï¼å¦ï¼pythonãluaãtclãphpççï¼ã
è¿æå ¶ä»è¯¸å¦ï¼Qtï¼qtforandroidï¼ãMonoï¼monoforandroidï¼çä¸äºèåç¼ç¨æ¡æ¶ä¹å¼å§æ¯æAndroidç¼ç¨ï¼çè³éè¿MonoDroidï¼å¼åè è¿å¯ä»¥ä½¿ç¨C#ä½ä¸ºç¼ç¨è¯è¨æ¥å¼ååºç¨ç¨åºã
å¦å¤ï¼è°·æè¿å¨å¹´ç¹å«åå¸äºé对åå¦è çAndroidSimpleè¯è¨ï¼è¯¥è¯è¨ç±»ä¼¼Basicè¯è¨ãèå¨ç½é¡µç¼ç¨è¯è¨æ¹é¢ï¼JavaScriptï¼ajaxï¼HTML5ï¼jqueryãsenchaãdojoãmoblãPhoneGapççé½å·²ç»æ¯æAndroidå¼åã
æ¤å¤ï¼è°·æå ¬å¸è¿æ¨åºäºGoogleAppInventorå¼åå·¥å ·ï¼è¯¥å¼åå·¥å ·å¯ä»¥å¿«éå°æ建åºç¨ç¨åºï¼æ¹ä¾¿æ°æå¼åè ã
freeswitchéè¦ä½¿ç¨ä»ä¹è¯è¨
FreeSWITCHæ¯ä¸ä¸ªå¼æºççµè¯è½¯äº¤æ¢å¹³å°ï¼ä¸»è¦å¼åè¯è¨æ¯Cï¼æäºæ¨¡åä¸ä½¿ç¨äºC++ï¼ä»¥MPL1.1åå¸ã
androidå¼åä¸ï¼è¿æ¥wifiéè¦ä½¿ç¨åªä¸ªå½æ°ï¼
å°±æ¯ç¨wifimanagerç对象ç´æ¥setWifiEnableå°±ç´æ¥å¼å ³äº~åæ°æ¯booleanå
ä½ æ²¡æ¾å°ä¼°è®¡æ¯ä½ 对象没æ¾å¯¹
ç¨WifiManagerwifi=(WifiManager)getSystemService(WIFI_SERVICE);
ä¹åwifi对象éåç§æ¥å£é½ææ¯å¦ç¶æçgetWifiState(),è¿æ¥ä¿¡æ¯çgetConnectionInfo()ï¼é便ç¨ï¼èªå·±ççå°±è¡äº~~æ¥ä¸æ¥æä¹ç¨å°±ä¸ç¨è¯´äºå§~~~
使ç¨vuejså¼åç¬ç«appandroidios端éè¦ä½¿ç¨ä»ä¹æ¡æ¶
MV*å æ¬MVCãMVPãMVVM
MVVMæ¡æ¶ç±ModelãViewãViewModelææã
Modelæçæ¯æ°æ®ï¼å¨å端对åºçæ¯JavaScript对象ã
Viewæçæ¯è§å¾ï¼å¨æ¸£æ¡å端对åºçæ¯DOM
ViewModelè§å¯ModelåViewçååæ¥åæ´æ°ï¼å®ç°äºæ°æ®çååç»å®ã
å端MVVMæ¡æ¶ä¸»è¦å æ¬ï¼angularJSãreactJSãVueJS
Androidå¼åä¸å¨åªäºåºåä¸ä¼éè¦ä½¿ç¨AIDL
ä¸¥æ ¼æ¥è¯´ï¼çº¿ç¨æ¯å ±äº«èµæºçï¼æ以线ç¨ä¹é´æ¯ä¸åå¨éä¿¡çï¼Androidéé¢çHandleæ¯ç¨æ¥è§£å³å¼æ¥è°ç¨çï¼è¿ä¸ªè§å¿µå¾éè¦ï¼æ³æç½äºï¼ä»£ç ä¹å°±åçæ´åçäºã
è¿ç¨ä¹é´å åçèµæºæ¯é离çï¼èAIDLï¼æ¯Androidæä¾çè·¨è¿ç¨éä¿¡IPCå·¥å ·Binderçå ·ä½ä½¿ç¨æ¹æ³ï¼è·å ¶ä»Linuxè·¨è¿ç¨éä¿¡ï¼socketï¼ç®¡éï¼è½åå ±äº«çï¼å¨æ¦å¿µä¸æ²¡å¥å·®ãæ以è¦å®ç°è·¨è¿ç¨çå å访é®ï¼æ¯å¦æ°æ®ä¼ è¾ï¼å½æ°è·¨è¿ç¨åæ¥è°ç¨çï¼å°±éè¦äºAIDLäºï¼å½ç¶äºAIDL并ä¸æ¯Androidä¸è·¨è¿ç¨éä¿¡çå¯ä¸éæ©ï¼socketï¼systemServerè¿ç¨ä¸zygoteè¿ç¨ï¼pkmsè°ç¨installè¿ç¨ï¼MountServiceä¸voldè¿ç¨éä¿¡é½æ¯éè¿socketï¼ï¼å ±äº«å åï¼sqlite3æ¥è¯¢å°±ç¨äºï¼ä»åçé½å¯ä»¥ç¨çï¼ä½æ¯æ²¡æBinderéè¿AIDL好ç¨ç½¢äºã
ä¸è¬é½ç¨å¨éè¦æ¯è¾å¤æçè·¨è¿å¦æåºç¨/线ç¨éä¿¡åºåãæ¯å¦èªå·±çç¨åºéè¦ç¨ä¸ä¸ªServiceå»å¤çåç§äºå¡ï¼èåéè¦è·Serviceè½ç¸äºè°ç¨çåºåã
è¦æ³¨æçæ¯AIDLä¸æ¯çº¿ç¨å®å ¨çï¼å¦æè¿æ¹é¢éè¦çè¯å°±è¦èªå·±å¤ç好临çæ åµã
请é®ecshopææºå®¢æ·ç«¯appåºç¨å¼åéè¦ä½¿ç¨ä»ä¹è¯è¨ï¼
ç¨javaå°±å¯ä»¥å¼åäºãå¦æä½ è¯´è¦å¼åä¸ä¸ªå®æ´ç客æ·ç«¯ï¼ä¸æ¯ä¸æ¥ä¸¤æ¥å¯ä»¥è¯´æ¸ æ¥ï¼å¯ä»¥èèæ¾ä¸ä¸åææºå¼åçå ¬å¸å¢éç»ä½ æå¡
å¦ä¹ androidå¼åé½éè¦åªäºåºç¡
ç°å¨å¤§å¦éé¢å计ç®æºç¸å ³çä¸ä¸çè³ç工类ä¸ä¸ä¸è¬é½ä¼å¼è®¾Cè¯è¨è¯¾ç¨ï¼åªæ¯å¾å¤åå¦å¨å¤§å¦æé´å¹¶æ²¡æ好好å¦ä¹ ï¼å¦æ对å®ææ¡çä¸å¤ªå¥½æè å¾ä¹ 没ç¨äºï¼å»ºè®®å ä»å°å ¶å¥½å¥½å¤ä¹ ä¸ä¸ï¼å°å ¶åºæ¬çè¯æ³å好好å顾ä¸ä¸ï¼æ好è½æ建ä¸ä¸ªç¯å¢æ¥è¿è¡ãè°è¯å®ãå¦æ没æå¦è¿ï¼ä¸å¦¨ä¹æåå¦ä¹ ä¸ä¸ãå¦ææ¯æ³å¦ä¹ Androidåºç¨å¼åï¼å°±å»å ·å¤ä¸å®çjavaåºç¡ãå 为Androidä¸çåºç¨å¤§å¤æ¯ç¨javaç¼åçï¼å¦ææ³ç¼åææºæ¸¸æååºç¨ï¼å°±éè¦å¦ä¹ javaãAndroidåºç¨ç¨åºå¼åæ¯ä»¥Javaè¯è¨ä¸ºåºç¡çï¼æ以没ææå®çJavaåºç¡ç¥è¯ï¼åªæ¯æºæ¢°çç §æå«äººç代ç ï¼æ¯æ²¡æä»»ä½æä¹çã建议å¨å®å课ç¨åæçjavaå¦ä¹ é¶æ®µä¸ï¼éè¦ç¨å¿çå¦å¥½ã
androidå¼åä»ä¹ç±»åç软件è¦ä½¿ç¨å°webService
ä¸è¬æ¯snsç±»çï¼webserviceå°±æ¯webæå¡æä¾ï¼éè¿restæä¸äºsoapapiæ¥è·åç¸å ³çæä¾åçå 容
微信å¼åºé½éè¦ä½¿ç¨ä»ä¹å·¥å ·ï¼
æèµå¾®ååï¼æä¸å®çææ¯ä¼å¿ï¼ä¸è¿ç°å¨ä¹æé对线ä¸å®ä½é¨åºçå·¥å ·ãåºæ¬ä¸ææç移å¨ç«¯æ¹é¢çè¥éå·¥å ·é½å¯ä»¥è¿ç¨çä¸ï¼å¯¹äºå¼æµæ¯å¾æ¾èç
å¼åAndroidAPP使ç¨çæ¯ä»ä¹è¯è¨ï¼å¼åAndroidAPPå¯ä»¥ä½¿ç¨Javaè¯è¨åCè¯è¨ã
Javaæ¯ä¸ç§ç¼ç¨è¯è¨ï¼è¢«ç¹æ设计ç¨äºäºèç½çåå¸å¼ç¯å¢ãJavaå ·æ类似äºC++è¯è¨çâå½¢å¼åæè§âï¼ä½å®è¦æ¯C++è¯è¨æ´æäºä½¿ç¨ï¼èä¸å¨ç¼ç¨æ¶å½»åºéç¨äºä¸ç§â以对象为导åâçæ¹å¼ã
使ç¨Javaç¼åçåºç¨ç¨åºï¼æ¢å¯ä»¥å¨ä¸å°åç¬ççµèä¸è¿è¡ï¼ä¹å¯ä»¥è¢«åå¸å¨ä¸ä¸ªç½ç»çæå¡å·æ»å¨ç«¯å客æ·ç«¯è¿è¡ãå¦å¤ï¼Javaè¿å¯ä»¥è¢«ç¨æ¥ç¼å容éå¾å°çåºç¨ç¨åºæ¨¡åæè appletï¼å为ç½æ迹渣页çä¸é¨å使ç¨ãappletå¯ä½¿ç½é¡µä½¿ç¨è åç½é¡µä¹é´è¿è¡äº¤äºå¼æä½ã
Cè¯è¨æ¯ä¸é¨éç¨è®¡ç®æºç¼ç¨è¯è¨ï¼å¹¿æ³åºç¨äºåºå±å¼åãCè¯è¨ç设计ç®æ æ¯æä¾ä¸ç§è½ä»¥ç®æçæ¹å¼ç¼è¯ãé«æå¤çä½çº§åå¨å¨ã产çå°éçæºå¨ç 以åä¸éè¦ä»»ä½è¿è¡ç¯å¢æ¯æ便è½è¿è¡çç¼ç¨è¯è¨ã
尽管Cè¯è¨æä¾äºè®¸å¤ä½çº§å¤ççåè½ï¼ä½ä»ç¶ä¿æçè¯å¥½è·¨å¹³å°çç¹æ§ï¼ä»¥ä¸ä¸ªæ åè§æ ¼ååºçCè¯è¨ç¨åºå¯å¨è®¸å¤çµèå¹³å°ä¸è¿è¡ç¼è¯ï¼çè³å å«ä¸äºåµå ¥å¼å¤çå¨ï¼åçæºæ称MCUï¼ä»¥åè¶ çº§çµèçä½ä¸å¹³å°ã
ææºä¸çå®åæä½ç³»ç»æ¯ä»ä¹è¯è¨ç¼ç¨_å®åç³»ç»æ¯ç¨ä»ä¹è¯è¨ç¼åç1ï¼Androidç³»ç»æ¡æ¶å±æ¬¡ãAndroidç³»ç»å æ ¸æ¯åºäºLinuxç³»ç»å¼åèæ¥çï¼æéé«åº¦èªç±ï¼çææºä»£ç å®å ¨å¼æ¾ï¼æ¯ä¸ç§æå±æ§é常强çæä½ç³»ç»ï¼å è´¹å¼æºï¼å¯å®å¶ï¼è¿ä¹æ¯è¿ éé£é¡å ¨ççåå å§ï¼ä¸»è¦ä½¿ç¨å¯¹è±¡æ¯ç§»å¨è®¾å¤ï¼ç±Googleåå¼æ¾ææºèçé¢å¯¼åå¼åãå ¶å æ ¸ç¼ç¨è¯è¨æ¯c/cãandroid使ç¨dalvikèææºå¶ï¼æ¬è´¨ä¸å®æ¯ä¸ä¸ªJavaèææºãèä¸å¯¹äºæ¯ä¸ä¸ªAPPé½ä¼å建个dalvikèææºï¼ä¹å°±æ¯ä¸ä¸ªlinuxè¿ç¨ã
2ï¼åæ©æ¶²androidåºå±é©±å¨ï¼ä»¥åæä½ç³»ç»å ¨é¨å æ ¸é½æ¯ä½¿ç¨Cè¯è¨åæ±ç¼è¯è¨ç¼ç¨å¼åãä½æ¯androidæä½ç³»ç»æ¬èº«æ¯ä½¿ç¨Javaå¼åï¼ä½¿ç¨JNIè°ç¨æ¬å°çCè¯è¨åºï¼ç±æä½ç³»ç»å®ç°å¯¹åºå±è°ç¨ã
3ï¼androidåºç¨å¼åï¼å³ææºappå¼åï¼ä½¿ç¨çæ¯Javaè¯è¨ï¼ä¸è¬ä¸ä¼ç¨å°c/cè¯è¨ãå æ¤ï¼æ³æ身ææºåºç¨å¼åçå°ä¼ä¼´ä»¬å·§ç©ï¼å¯ä»¥ç´æ¥é»ç Javaè¯è¨å³å¯ã
æ»ç»æ¥è¯´ï¼å®åç³»ç»ä¹åªä¸è¿æ¯åºäºlinuxç³»ç»å æ ¸å¼åçä¸ä¸ªJavaèææºï¼ç¶åå¨èææºéè¿è¡javaç¨åºãå°±åæ们å¨windowsçµèéå®è£ ä¸ä¸ªèææºï¼è¿è¡å ¶å®æä½ç³»ç»è¿è¡è½¯ä»¶æµè¯ä¸æ ·ï¼è¿ä¸ªå ¶å®çæä½ç³»ç»å°±ç¸å½äºå®åï¼ç¶å大家å¼åçææ软件ï¼å¨è¿ä¸ªèææºé使ç¨ã
å¸æå¯ä»¥å¸®å°æ¨ï¼è°¢è°¢ï¼
å®åç¨çæ¯ä»ä¹è¯è¨å¼åçå®åå®æ¹å¼åè¯è¨ï¼Kotlinåæ¢
Kotlinæ¯ä¸ç§å¨Javaèææºä¸æ§è¡çéæåå«ç¼ç¨è¯è¨ï¼ç±è´ºå¼JetBrainså¼åå¢éæå¼åã该è¯è¨æå 个ä¼å¿ã
å®å¤§å¤§åå°éè¦è¯æè´ºåçæ ·æ¿ä»£ç çæ°éãé¿å 空æéå¼å¸¸çæ´ä¸ªç±»çé误ãæ建æå¡å¨ç«¯ç¨åºãAndroidåºç¨ç¨åºæè å¨æµè§å¨ä¸è¿è¡çå端ç¨åºãéè¿%Javaäºæä½æ§ï¼å©ç¨JVMæ¢ææ¡æ¶ååºã
å¨Kotlinä¸åé声ææ两ç§ç±»åï¼val修饰åéæ¯åªè¯»åéå³åªè½èµå¼ä¸æ¬¡ï¼å次èµå¼æ¶å°±ä¼ç¼è¯é误ï¼å¦æéè¦å¤æ¬¡ä¿®æ¹å¼å°±éè¦ä½¿ç¨varã
æ©å±èµæï¼
TheIntelliJKotlinæ件æ©å±äºJavaç¼è¯å¨ä½¿å¾Kotlin代ç è½å¤å¾ä»¥ç¼åãç¼è¯åè°è¯ãé¤æ¤ä¹å¤ï¼å ³äºåºæ¬çJavaéåï¼å·²ç»æç¼å好ç帮å©å½æ°ï¼å¯ä»¥æ´é¡ºç å°è¡æ¥å°å¨Java8ä¸åºç°çéåæ©å±ã
Kotlinï¼ç±»ä¼¼Xtendä¸æ ·ï¼æ¨å¨æä¾ä¸ç§æ´å¥½çJavaèéé建æ´ä¸ªæ°å¹³å°ãè¿ä¸¤ç§è¯è¨é½åä¸ç¼è¯ä¸ºåèç ï¼è½ç¶Xtendæ¯é¦å 转æ¢æç¸åºçJava代ç ï¼å让Javaç¼è¯å¨å®æç¹æ°æ´¾éçå·¥ä½ï¼ï¼èä¸ä¸¤è é½å¼å ¥äºå½æ°åæ©å±å½æ°ï¼å¨æ个æéèå´å éæå°å¢å ä¸ä¸ªæ°æ¹æ³å°æ个已æç±»åçè½åï¼ã
åèèµææ¥æºï¼ç¾åº¦ç¾ç§-Kotlin
androidå¼åè¯è¨ï¼
å¦æä½ æ³å¼åä¸ä¸ªAndroidåºç¨ç¨åºï¼ä½ å¯è½æ³å©ç¨javaãKotlinãC++ãCè¯è¨æLuaæ¥ç»ä½ çåºç¨ç¨åºå¸¦æ¥æåçæä½³æºä¼ã1.JAVA
JAVA被è§ä¸ºå®æ¹çAndroidå¼åç¼ç¨è¯è¨ãç±äºå ç½®çå¼æ¾æºç åºå¯ä¾ç¨æ·éæ©ï¼JAVAæäºå¤çï¼å¹¶æä¾äºæä½³çææ¡£å社åºæ¯æãå ¶ä¸°å¯çåè½è®©æ¨å¯ä»¥èªç±å¼åæä½³ç跨平å°åºç¨ç¨åºãAndroidåºç¨ç¨åºã游æãæå¡å¨åºç¨ç¨åºãåµå ¥å¼ç©ºé´ãç½ç«çã
å æ¤ï¼JAVAä¹æ¯ä½¿ç¨æ广æ³çè¯è¨ã许å¤PlayStoreåºç¨ç¨åºé½æ¯ç¨JAVAæ建çï¼å®ä¹æ¯Googleææ¯æçè¯è¨ãJAVAè¿æä¾äºä¸ä¸ªå¾å¥½çå¨çº¿ç¤¾åºï¼å¨åºç°ä»»ä½é®é¢æ¶æä¾æ¯æã
ç¶èï¼JAVA对äºåå¦è æ¥è¯´æ¯ä¸ç§å¤æçè¯è¨ï¼å 为å®å å«å¤æç主é¢ï¼å¦æé å½æ°ã空æéå¼å¸¸ã并åæ§ãæ è®°å¼å¸¸çãæ¤å¤ï¼Android软件å¼åå·¥å ·å ï¼SDKï¼å°å¤ææ§æåå°äºä¸ä¸ªæ°çæ°´å¹³ã
æ»çæ¥è¯´ï¼JAVAæ¯ä½éªAndroidåºç¨ç¨åºå¼åææä¹è¶£çç»ä½³è¯è¨ã
2.Kotlin
æ®è¯´Kotlinæ¯Javaçé«çº§çæ¬ï¼æ¯ä¸ç§ç¨äºå¼åç°ä»£Androidåºç¨ç¨åºçç»è®¡ç¼åçç¼ç¨è¯è¨ãKotlinä¹è¢«è®¤ä¸ºæ¯åºç¨ç¨åºçæä½³è¯è¨ãKotlinæå¯è½å½±åå ¶ä»ç¼ç¨è¯è¨ï¼å¦JAVAï¼ä»¥å建å¥å£®åé«æ§è½çåºç¨ç¨åºãKotlinå ç½®çä¸äºæµè¡åºç¨ç¨åºæCourseraãTrelloãEvernoteçã
JavaåKotlinä¹é´å¯ä¸æ¾èçåºå«æ¯Kotlinå é¤äºå¤ä½çJavaç¹æ§ï¼ä¾å¦ç©ºæéå¼å¸¸ãç®åå°è¯´ï¼ä»ç¨åºåçè§åº¦æ¥çï¼Kotlinæ¯Javaæ´å®¹æ让åå¦è è¿è¡æµè¯ï¼ä¹å¯ä»¥ä½ä¸ºAndroidåºç¨ç¨åºå¼åçâå ¥å£ç¹âã
3.C++
C++æ¯è®¸å¤é¡¶çº§ç§»å¨åºç¨å¼åå ¬å¸çé¦éãå®æ¯ä¸ç§éç¨çãé¢å对象çè¯è¨ï¼å ·æéç¨æ§åä½çº§å«å åæä½çç¹æ§ã
ç¨äºAndroidåºç¨ç¨åºå¼ååæ¬å°åºç¨ç¨åºï¼C++å¯ä»¥å¼å游æãåºäºGUIçåºç¨ç¨åºãå®æ¶æ°å¦æ¨¡æãé¶è¡åºç¨ç¨åºççãC++å¨äºè®¡ç®åºç¨ä¸å¾å欢è¿ï¼å 为å®å¯ä»¥å¾å¿«éåºç¡¬ä»¶æçæç³»ç»çååã
C++å¯ä»¥ç¨äºAndroidåºç¨ç¨åºå¼åï¼ä½¿ç¨åçAndroidå¼åå·¥å ·å ï¼NDKï¼ãä½æ¯ï¼åºç¨ç¨åºä¸è½å®å ¨ä½¿ç¨C++æ¥å建ï¼NDKç¨äºå®ç°æ¬å°C++代ç ä¸åºç¨ç¨åºçé¨åãå®æå©äºå¨éè¦æ¶ä½¿ç¨C++代ç åºä½ä¸ºåºç¨ç¨åºã
è½ç¶C++å¨æäºæ åµä¸å¯¹Androidåºç¨ç¨åºå¼åå¾æç¨ï¼ä½æ¯é ç½®æ´é¾ï¼çµæ´»æ§ä¹å°±å·®å¾å¤ãç±äºå¤ææ§çå¢å ï¼å®è¿å¯è½äº§çæ´å¤çé误ãå æ¤ï¼æ好使ç¨javaä¸C++ç¸æ¯ï¼å 为å®ä¸è½æä¾è¶³å¤çå¢çæ¥å¼¥è¡¥æéçåªåã
4.C#
C#ä¸Javaé常ç¸ä¼¼ï¼é常éåAndroidåºç¨ç¨åºå¼åãä¸Javaä¸æ ·ï¼C#ä¹å®ç°åå¾æ¶éï¼å æ¤å åæ³æ¼çå¯è½æ§è¾å°ãC#è¿ææ´ç®æ´çè¯æ³ï¼è¿ä½¿å¾ç¼ç ç¸å¯¹å®¹æã
以åï¼C#æ大ç缺ç¹æ¯å®åªè½å¨Windowsç³»ç»ä¸è¿è¡ï¼å 为å®ä½¿ç¨.NETæ¡æ¶ãç¶èï¼è¿ä¸ªé®é¢æ¯ç±Xamarinå¤ççï¼Xamarinæ¯å ¬å ±è¯è¨åºç¡è®¾æ½ç跨平å°å®ç°ãç°å¨ï¼Xamarin.Androidå·¥å ·å¯ä»¥ç¨æ¥ç¼ååçAndroidåºç¨ç¨åºï¼å¹¶è·¨å¤ä¸ªå¹³å°å ±äº«ä»£ç ã
C#被称为âC-sharpâï¼ä½ä¸ºä¸ç§å¹¿æ³ç¨äºç§»å¨å¼åï¼ä¸»è¦ç¨äºWindows跨平å°åºç¨ç¨åºå¼åï¼çéç¨ãé¢å对象ç¼ç¨è¯è¨ï¼å¨å¸åºä¸å ææ¾èå°ä½ã
å¦ææ¨è®¡åå¼åé«æ§è½å交äºå¼æ¸¸æåºç¨ç¨åºï¼è¿æ¯æ好çè¯è¨ã
5.Lua
Luaæ¯ä¸ç§è·¨å¹³å°çå¤èå¼ç¼ç¨è¯è¨ãå®æ¯ä¸ç§ééè½»ã移å¨ç¬¬ä¸çä¼ä¸é信解å³æ¹æ¡ãLua为ä¼ä¸å ç½®çæ¶æ¯ä¼ éæä¾äºå¼ºå¤§çæ¯æï¼å®æ¯å³æ¶çãå®å ¨çï¼å¹¶ä½¿å¼å人åå¯¹å ¶è´è´£ã
ç±äºå®æ¶å®å ¨æ¶æ¯ãåæ仪表æ¿ãè½»æ¾çæä»¶å ±äº«åå触å¼çµè¯ä¼è®®ï¼è¿ç§è¯è¨åå¾æµè¡èµ·æ¥ãå¦ææ¨å¸ææé«åºç¨ç¨åºçå¯ç§»æ¤æ§ãé度ãå¯é æ§åå¯æ©å±æ§ï¼Luaæ¯ä¸ä¸ªå®ç¾çéæ©ã
使ç¨ä¸è¿°ç¼ç¨è¯è¨å¯ä»¥å建许å¤åºç¨ç¨åºï¼å¦è天信使ãé³ä¹ææ¾å¨ã游æã计ç®å¨çãæ£å¦ä½ æç¥ï¼æ²¡æä¸ç§è¯è¨å¯ä»¥è¢«ç§°ä¸ºâæ£ç¡®çè¯è¨â
å æ¤ï¼æ ¹æ®æ¯ä¸ªé¡¹ç®çç®æ åå好ï¼éæ©æ£ç¡®çè¯è¨åå³äºæ¨èªå·±ãä¸åéçAndroidåºç¨ç¨åºå¼åå ¬å¸åå¾èç³»ï¼ä¸ºæ¨çä¼ä¸å¸¦æ¥æåç礼ç©ã
什么是跨终端
链接:/post/
鉴于很多人对跨端技术感觉很神秘,虽然我实际上还没有写过一个从0到1的跨端框架,但是我曾经用Yoga(布局引擎Yoga(React-Native)做过一些简单的跨端的事情,后来用了Weex。研究跨端有一段时间了,想科普一下。
科普之前,首先你要知道,为什么需要跨端技术?我们通常会把Weex和React-Native(本文统称为RN)说成是跨端技术吗(Flutter没有单独提到)?
其实不是,好像Android/iOS本来是两个人的,但最终变成了一个人。我的人力减少了一半!
但前提是这个人力需要懂Android,iOS,JavaScript,源码家源码更懂,不然出了问题,怎么修?
所以在中国的互联网环境下,很难招到这样的人。大家都在研究PPT架构技术,职场生存理论,岁如何解脱财富。我们如何有时间扩展我们的技术堆栈?
端上开发很惨,总有崩溃(使用崩溃,闪退)而且没有办法远程修复。只能等下一个版本给使用市场推一个修复bug的新版本。
但如果推送新版本,用户可能不会升级。因此,许多公司研究了各种热修复框架,尤其是在Android平台上。有很多热修复框架,主要是由DexClassLoader来完成。
但是,最早的时候,WebView有一个很大的问题,尤其是Android。而且加载网页肯定要花时间,过程中屏幕会一片空白等等。所以很多人围绕这些做了很多优化。我个人觉得最有用的其实是线下套餐。同时,每一代WebView也在更新升级。然后一些有实力的源码网页源码公司开发了自己的所谓浏览器内核,各种黑科技,如何提速,支持各种特性等等。但是好像没有开源:dog:
不算。这只是跨安卓和iOS,不把我的PC当目的?
其实浏览器是跨端的,每个平台都可以用Chrome(其他浏览器主要是想做不做)!但是它也有自己的问题,因为各家都有自己的浏览器,内核不同,划分越来越大。chrome(Blink)/Safari(WebKit)/Firefox(Gecko?)等等,尤其是对css的支持。
Developer.mozilla.org/zh-CN/docs/.这个网站可以检查一些浏览器的兼容性。例如,边框宽度的兼容性如下:
其实也不是不可以,但是这样做相当于直接为OpenGL或者其他图形引擎编程,而且要自下而上的搭建一套渲染机制,打包各种基础UI组件给开发者使用,或者留下很多漏洞让开发者自定义自己的UI,非常复杂。但其实Flutter就是这么做的,所以Flutter2.0又开始向桌面端发展了,而且不局限于Android/iOS,但不知道能走多远。还有的是搞React-Native-Skia的,所以用js代码直接调Skia(2D图形渲染引擎)?(具体没看过)
你写的JavaScript代码为什么能运行?这取决于JavaScript引擎。
扔给它一段js代码(实际上是一个文本字符串),它就能帮你计算结果,c 源码源码处理逻辑。
常见的Weex、RN、Hippy也依赖于此(MLN使用Lua)进行逻辑处理。
这个时候会有很多概念。
有些人喜欢把JavaScript引擎称为JavaScriptCore(不知道为什么,可能是因为iOS开发者才是研究这些比较深入的人,因为苹果的JavaScript引擎叫JavaScriptCore。苹果的这个JavaScriptCore呢?很多人喜欢称之为JSCore或者JSC)。所以,后来看到这些名词,我总是把它们带入语境中去感受他想说的是JavaScript引擎还是苹果的JavaScript引擎 JavaScript Core (JSCore/JSC)。
先说JavaScript引擎。
是的,有这么多!当然还有JavaScriptCore(不在图中)。
最后一行是跑分,越多越好。有JIT的V8在3w挂所有东西。其中QuikJS极小,得分很高。估计很多人会用QuikJS做跨端JavaScript引擎吧?赫尔墨斯是由脸书创造的。看来Android目前在RN中使用的JavaScript引擎已经取代了之前使用的JavaScriptCore。RN为什么一直不用V8?这个我也不知道.
但是很多人都在搞Android的V8项目,Github上也有一些开源项目。其次,iOS不支持JIT,有自己的JavaScriptCore,没有JIT改V8似乎意义不大。
一个正常的跨端框架最简单的情况如下(后面会讨论问题,逐步丰富):
用一个
简单的例子看
假设我的 js 文件中就是要 展示一个红色的 div 方块 。那么首先,端会把这个文本传给 JavaScript Runtime,它解析完后形成一个约定的格式,比如如下的 JSON 格式(里面的值用来描述是一个*红色方块,我随便定义的)
{ "name":"div", "width":"", "height":"", "background":"red"}
通过 JavaScript Runtime 和 端(Android/iOS) 通信,把这个消息传回去。
端拿到了消息,发现要创建一个 * 的叫做 div 的东西,没有 div 啊!这就需要端上提前埋好代码,比如 Android 里有 FrameLayout,那么就有类似的注册代码
// 伪代码register("div", FrameLayout.class);
然后端就知道了,oh!我需要创建一个长宽的正方形。
首先,这是框架设计提前思考好的,究竟要支持哪些基础组件,比如 image 、text 等等。而且一般这里都会开个口子,让开发者可以自己扩展组件,比如你需要一个横滑列表,没提供怎么办?看看 div 怎么注册的,按照它的过程注册一个列表就好了。这也可以 PPT 吹成: 扩展跨端框架 ,其实 门槛比自定义 View 还要低 。
前面说了 JavaScript Engine,这里咋又来了个 Runtime?
JavaScript Engine 能做什么?
什么都做不了,只能解析执行 js 代码
那么问题来了,我怎么去 描述 我写的 js 代码代表的 视图 呢?其实不用描述,js 代码只要在 内存中 维护好一个树形结构就好了,就是一个 Object,因为实体在具体的端上,怎么理解呢?
左边只要在内存中维护好这样一个树形结构就好了,传递给客户端时,转为
{ "name":"div", "children":[ { "name":"image" }, { "name":"div", "children":[] } // 等等 ]}
端上拿到消息,创建视图为右图中的结构即可。
如何维护好这个模型呢?调用什么 js 的方法发送消息呢?怎么给这些个 div 加上 css 来描述它的大小形状呢?等等更复杂的一系列的前端问题,都需要 写代码 来实现。
所以一般都会有个 core.js 或者 framework.js 类似的一堆 js 代码,就是用来处理这些事情,而这些代码同样依靠 JavaScript Engine 来执行。
从而所谓的 JavaScript Runtime ,我觉得可以单纯的理解为 JavaScript Engine 自身的代码跑起来后的环境,也可以理解为 core.js 等被跨端框架所需要的、包含了各种逻辑的前端代码被加载运行后的环境。
当你用这些跨端框架的时候,你会发现他们只支持 css 子集 ,而且布局方式基本都是 flexbox(一种布局模型) 。
那么比如你写了一个横着容纳了三个小方块的大方块,你的前端 css 代码肯定要写成, flex-diretion:row ,那么抛给端上的消息可能如下:
{ "name":"div", "attribute":{ // 使用布局 "flex-diretion":"row" }, "children":[ { "name":"div" }, { "name":"div" }, { "name":"div" } ]}
端上拿到这个消息,都不知道 flex-direction 是什么。当然,你可以自己写一个解析库来解,但是 Yoga 帮你做了这件事!
所以 RN 使用的是 Yoga 布局引擎(支持 flexbox,也是 Facebook 搞的)。
Weex 似乎一开始是用的 Yoga,后来自己写了一套?
这个地方就出现了一个名词 Layout Engine ,它就是帮我们处理各种布局参数的,然后帮我们算好每个视图的坐标,然后端上拿到坐标后设置对应的视图的坐标,一个井井有条的视图便展示了出来。如果你觉得你写的布局解析算法超越了 Yoga 等等,那么你完全可以自己写一套。
比如从 JavaScript Runtime 处理完各种属性了,要渲染视图了!传了一段 JSON 给端。
端上手指点了一下这个视图,那也要封装成一个消息传递给 JavaScript Runtime,然后触发你之前写的 js 的监听代码,比如点击后弹一个弹窗,那就又要封装一个调用弹窗方法的消息给端。
就是这样来来回回。
所以两边都有自己的消息队列。
而且当你做动画还想监听动画过程的时候,肯定在短时间内发送了大量消息,这些过程肯定是 需要优化 的。
并且!据我个人用 Weex 的经验,有的 flexbox 属性两端都不统一(可能是 Weex 的 Bug,毕竟 KPI 项目,都不维护了)
我记得当时还开玩笑说,用了 Weex 终于领悟了跨端的真谛:
if(platform === 'Andoird') { // 差异化逻辑} else if(platform === 'iOS') { // 差异化逻辑}
跨端的代价就是,你 本以为 真的可以一套代码两端跑,后来发现真的有点做梦了(连 H5 有时候 Andoird/iOS 都不一致,因为用的内核都不是一个),代码里有不少的 if-else。
所以经过上面的一系列科普,一个跨端框架成了这样:
这其中一般是需要一个客户端、一个前端、一个懂 JavaScript Engine 会 C/C 的来分别开发。
我虽然没开发过,但是感觉会有很多问题。
比如 JavaScript Runtime 在另一个进程的话,跨进程通信?
比如消息通信过于频繁是不是就会有各种连锁反应,掉帧啊、事件响应不及时、动画不流畅啊,怎么优化?
其实我本身一直自诩喜欢研究原理,但是直至今日我也没真的一行行看过跨端框架的源码,我知道的这些也未必是对的,只是之前做过 Weex 的一些工作稍微研究了一下,还是挺惭愧的。
既然你自称喜欢研究原理,为什么不看呢?
链接:/post/
相关问答:相关问答:手机端和电脑端各是什么?
电脑端和手机端,实际上说的就是平台问题。
当我们使用电脑的时候,电脑基本使用的操作平台是windows,或者苹果等常用操作系统。
而手机上用的平台,如安卓,苹果的IOS,当年诺基亚的塞班,黑莓的系统,都叫做手机端。
那么怎么定义手机端和电脑端呢,我们可以这么理解,如果用电脑操作系统的设备,即便是平板电脑,你也可以理解成是电脑端。
如微软平板电脑surface,他的定位是平板也是电脑,
我们很多的平板,多数使用的是安卓系统,苹果的当然就是IOS,但是平板使用基本使用的移动平台,也就可以看成是手机端。
但是,如果这个移动设备的平台使用的是电脑的操作系统的时候,他所使用的平台,也就成了电脑端。