Android c++ core guideline checker 应用

简介: Android c++ core guideline checker 应用

本文来源:支付宝体验科技


  背景


c++ core guideline(https://isocpp.github.io/CppCoreGuidelines/CppCoreGuidelines) 是 c++ 之父 BS 博士为了解决现代 c++ 中的安全性、效能问题,而做出来的一套指南。也是目前最权威、规范的一套现代 c++ 编程的最佳实践。如果说 Effective cpp/More Effective cpp 是在给你敲警钟你怎么写就不对,那么 c++ core guide 则是 c++ 现代版的正面实施指南。为什么说现代呢,一是 c++ core guideline 出来得更晚,从 c++ 各场景应用中接收了更多的反馈融入了更多好的经验;二是这些 guideline 面向更多现代化 c++ 语言版本(c++ 14 及以后),现代 c++ 和我们过去 vc 6.0 时代受过的 c++ 教育是截然不同的。


文档介绍:


https://isocpp.github.io/CppCoreGuidelines/CppCoreGuidelines(非常详细、全面,为实操快速指路)


Core guildeline 支持库(方便你改善、迁移老代码):


https://isocpp.github.io/CppCoreGuidelines/CppCoreGuidelines#gsl-guidelines-support-library


工具(checker):


现在 c++ core guideline check 在微软 visual studio 里也得到了很好的支持。


https://learn.microsoft.com/en-us/cpp/code-quality/using-the-cpp-core-guidelines-checkers?view=msvc-170#the-c-core-guidelines-project


正逢 mars native 需要重构、对外开放,改善代码品质,发现潜在编码问题、语言使用问题。我就去挖掘下,如何在 android c++ 工程中自动化应用 c++ core guilde 的方式。毕竟 c++ 语言使用本身涉及的知识汗牛充栋,侯捷老师靠介绍 c++ 知识可以著作等身,成为一门可以持续一辈子的职业。我并无这么大的知识储备,也无这么持续的注意力带宽。


只有一个办法:找一个成熟的 c++ core guideline 检查工具。


  怎么做


Clang-Tidy

clang-tidy 基于 clang/LLVM,是一个成熟、功能丰富的 c++ linter,非 visual studio 环境,目前调研了下,需要靠集成 clang-tidy 的方式来跑 c++ core guideline。且在 android 开发的 ndk-build/Android Studio cmake 工作流里都得到了很好的支持。

ndk-build

Enable application-wide with APP_CLANG_TIDY := true

Android Studio 3.3+

android studio 从 3.3+ 开始支持了 clang-tidy。使用方式很简单,我简单截图如下:

https://developer.android.com/studio/releases/past-releases/as-3-3-0-release-notes?hl=zh-cn#clang-tidy-support

1.启动 Clang-Tidy inspection

image.png

image.png

2.在检查面板里可以调整要应用哪些 check 项:

image.png

可以看到 check 规则数量非常多。


3.开始执行检查

image.png

4.检查后的处理

quick-fixes

点击小灯泡上的提示(quick-fixes),就能直接帮你重构/改良代码。而这正是 Intelli IDEA/Android Studio 的核心优势。


而这个 c++ 检查器的价值有多大呢,我给大家截图高亮下,发现了 1100 多个警告,0 Error。修复这些警告,可以避免较多临时对象的构造,还能用上更多运行时更有效率的“等效函数/等效写法”,编码风格统一,跟上最新最好实践。要人肉做到这一点,得需要多大精力和经验。


当你熟悉了各个 check 以及对应 quick-fix 是什么,认定它适合你的需要。你可以批量应用自动修改:(你可能会觉得我上边说的话比较滴水不漏,是不是暗示我有坑啊。我使用下来的经验是 quick-fix 质量比较高,值得信赖。大家睁大眼,放开胆。)

image.png

手工修改

有些 check,比如向窄数据类型转型

image.png

构建函数里有未初始化的字段

image.png

不太费精力地批量应用 quick-fixes 之后,成功实现了批量应用自动修改。改动概要信息如下:


commit db6625732e09156501f32f7be0f2e5515e44ea11 (HEAD -> cpp_core_guideline_warning_fix, origin/cpp_core_guideline_warning_fix)

Author: xide.wf

Date: Thu Aug 31 20:50:36 2023 +0800


通过 Clang-Tidy 做了基础的 cpp core guideline 校验,增加了相应的修改.


android/README.md | 11 ++++++++++-

core/filters/bloom_filter_define.cpp | 18 +++++++++---------

core/filters/delay_filter_define.cpp | 2 +-

core/filters/distortion_filter_define.cpp | 14 +++++++-------

core/filters/filter_utils.cpp | 11 +++++++----

core/filters/filter_utils.hpp | 4 ++--

core/filters/gaussian_filter_define.cpp | 4 +++-

core/include/mars_native_player.h | 2 +-

core/load/loader.cpp | 8 +++-----

core/math/camera.cpp | 14 ++++++--------

core/math/camera.hpp | 4 ++--

core/math/mat3.cpp | 4 +---

core/math/mat4.cpp | 8 +++-----

core/math/mat4.hpp | 2 +-

core/math/math_util.cpp | 4 ++--

core/math/math_util.hpp | 2 +-

core/math/mersenne_twister.cpp | 4 ++--

core/math/transform.cpp | 8 ++++----

core/math/transform.h | 4 ++--

core/math/value/bezier_value_getter.cpp | 2 --

core/math/value/curve_value_getter.cpp | 8 ++++----

core/math/value/gradient_value_getter.cpp | 1 -

core/math/value/line_segments_value_getter.cpp | 4 ++--

core/math/value/path_value_getter.cpp | 8 ++++----

core/math/value/random_value_getter.cpp | 6 ++----

core/math/value/static_value_getter.cpp | 2 +-

core/math/value/static_value_getter.hpp | 2 +-

core/math/value/value_getter_utils.cpp | 6 +++---

core/math/value/value_getter_utils.hpp | 6 +++---

core/math/vec2.cpp | 9 ++-------

core/math/vec3.cpp | 4 +---

core/math/vec4.cpp | 4 +---

core/model/model_plugin.cpp | 11 ++++-------

core/model/model_tree_plugin.cpp | 9 +++------

core/model/model_vfx_item.cpp | 14 +++++++-------

core/model/renderer/animation/interpolation_sampler.cpp | 38 +++++++++++++++-----------------------

core/model/renderer/animation/m_animation.cpp | 65 ++++++++++++++++++++++++++---------------------------------------

core/model/renderer/animation/m_animation.hpp | 16 ++++++++--------

core/model/renderer/animation/m_skin.cpp | 16 +++++++---------

core/model/renderer/animation/m_skin.hpp | 4 ++--

core/model/renderer/m_camera.cpp | 29 +++++++++++------------------

core/model/renderer/m_camera.hpp | 10 +++++-----

core/model/renderer/m_entity.cpp | 2 +- core/model/renderer/m_geometry.cpp | 10 ++++++----

core/model/renderer/m_light.cpp | 31 ++++++++++++-------------------

core/model/renderer/m_light.hpp | 10 +++++-----

core/model/renderer/m_mesh.cpp | 58 +++++++++++++++++++++++++++++-----------------------------

core/model/renderer/m_mesh.hpp | 12 ++++++------

core/model/renderer/m_scene_manager.cpp | 34 ++++++++++++++++------------------

core/model/renderer/m_scene_manager.hpp | 8 ++++----

core/model/renderer/m_skybox.cpp | 22 ++++++++++------------

core/model/renderer/m_skybox.hpp | 12 ++++++------

core/model/renderer/m_transform.cpp | 6 ++----

core/model/renderer/m_transform.hpp | 2 +-

core/model/renderer/material/m_material_base.cpp | 12 +++++-------

core/model/renderer/material/m_material_base.hpp | 2 +-

core/model/renderer/material/m_material_pbr.cpp | 20 +++++++++-----------

core/model/renderer/material/m_material_pbr.hpp | 2 +-

core/model/renderer/material/m_material_skybox.cpp | 4 +---

core/model/sceneData/data/model_data.cpp | 6 +++---

core/model/sceneData/data/model_data.h | 2 +-

core/model/sceneData/decoder/model_content_decoder.cpp | 45 +++++++++++++++++++++++----------------------

core/model/shader/shader_libs.cpp | 18 +++++++++---------

core/model/shader/shader_libs.hpp | 2 +-

core/model/utility/skybox_utils.cpp | 2 +-

core/model/utility/skybox_utils.hpp | 2 +-

core/platform/android/android_impl.cpp | 9 +++++----

core/platform/android/egl_pbuffer_context.cpp | 6 +++---

core/platform/android/egl_pbuffer_context.h | 8 ++++----

core/platform/android/egl_window_context.cpp | 16 ++++++++--------

core/platform/android/egl_window_context.h | 6 +++---

core/platform/android/jni_bridge.cpp | 8 ++++----

core/platform/android/mars_offscreen_surface.cpp | 2 +-

core/platform/android/mars_player_jni.cpp | 38 +++++++++++++++++++-------------------

core/platform/ios/ios_impl.mm | 2 +-

core/player/comp_vfx_item.cpp | 37 ++++++++++++++++++++-----------------

core/player/comp_vfx_item.h | 6 +++---

core/player/composition.cpp | 40 +++++++++++++++++++---------------------

core/player/composition.h | 18 +++++++++---------

core/player/mars_native_data.cpp | 12 ++++++------

core/player/mars_native_player.cpp | 10 +++++-----

core/player/mars_player.cpp | 16 ++++++++--------

core/player/mars_player.h | 2 +-

core/player/mars_player_mgr.cpp | 53 ++++++++++++++++++++++-------------------------------

core/player/plugin_system.cpp | 26 +++++++++++++-------------

core/player/vfx_item.cpp | 4 +++-

core/player/vfx_item.h | 2 +-

core/plugin/arTrack/ar_track_loader.cpp | 5 ++---

core/plugin/arTrack/ar_track_vfx_item.cpp | 14 +++++++-------

core/plugin/cal/calculate_group.cpp | 36 ++++++++++++++++--------------------

core/plugin/cal/calculate_group.h | 2 +-

core/plugin/cal/calculate_item.cpp | 2 +-

core/plugin/cal/calculate_item.h | 1 +

core/plugin/cal/calculate_loader.cpp | 59 ++++++++++++++++++++++++++++-------------------------------

core/plugin/cal/calculate_loader.h | 2 +-

core/plugin/cal/calculate_vfx_item.cpp | 3 +--

core/plugin/interact/interact_vfx_item.cpp | 3 +--

core/plugin/particle/link_chain.cpp | 14 +++++++-------

core/plugin/particle/link_chain.hpp | 4 ++--

core/plugin/particle/particle_loader.cpp | 8 +++-----

core/plugin/particle/particle_mesh.cpp | 120 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++------------------------------------------------------------

core/plugin/particle/particle_system.cpp | 10 +++++-----

core/plugin/particle/particle_system.hpp | 2 +- core/plugin/particle/particle_vfx_item.cpp | 10 ++++------

core/plugin/particle/shape/donut.cpp | 8 ++------

core/plugin/particle/shape/earcut.cpp | 14 +++++++-------

core/plugin/particle/shape/geometry_2d.cpp | 7 +++----

core/plugin/sprite/filter_sprite_vfx_item.cpp | 4 ++--

core/plugin/sprite/sprite_group.cpp | 84 ++++++++++++++++++++++++++++++++++++++----------------------------------------------

core/plugin/sprite/sprite_group.h | 10 +++++-----

core/plugin/sprite/sprite_item.cpp | 12 ++++++------

core/plugin/sprite/sprite_item.h | 4 ++--

core/plugin/sprite/sprite_loader.cpp | 19 ++++++++-----------

core/plugin/sprite/sprite_loader.h | 2 +-

core/plugin/sprite/sprite_mesh.cpp | 37 +++++++++++++++++--------------------

core/plugin/sprite/sprite_mesh.h | 8 ++++----

core/plugin/sprite/sprite_vfx_item.cpp | 5 ++---

core/plugin/tree/tree_item.cpp | 16 ++++++++--------

core/plugin/tree/tree_item.hpp | 4 ++--

core/plugin/tree/tree_vfx_item.cpp | 20 ++++++++------------

core/ri/backend/opengl/gl_frame_buffer.cpp | 32 +++++++++++++++++---------------

core/ri/backend/opengl/gl_frame_buffer.hpp | 4 ++--

core/ri/backend/opengl/gl_geometry.cpp | 4 +++-

core/ri/backend/opengl/gl_gpu_buffer.cpp | 4 ++--

core/ri/backend/opengl/gl_gpu_buffer.hpp | 2 +-

core/ri/backend/opengl/gl_gpu_capability.cpp | 6 +++---

core/ri/backend/opengl/gl_gpu_capability.hpp | 2 +-

core/ri/backend/opengl/gl_gpu_renderer.cpp | 7 ++++---

core/ri/backend/opengl/gl_gpu_renderer.hpp | 8 ++++----

core/ri/backend/opengl/gl_material.cpp | 62 +++++++++++++++++++++++++++++++-------------------------------

core/ri/backend/opengl/gl_material.hpp | 2 +-

core/ri/backend/opengl/gl_program.cpp | 6 +++---

core/ri/backend/opengl/gl_program.hpp | 8 ++++----

core/ri/backend/opengl/gl_render_buffer.cpp | 2 +-

core/ri/backend/opengl/gl_shader_library.cpp | 10 +++++-----

core/ri/backend/opengl/gl_shader_library.hpp | 8 ++++----

core/ri/backend/opengl/gl_state.cpp | 4 ++--

core/ri/backend/opengl/gl_state.hpp | 44 ++++++++++++++++++++++----------------------

core/ri/backend/opengl/gl_texture.cpp | 12 ++++++------

core/ri/backend/opengl/gl_material.cpp | 62 +++++++++++++++++++++++++++++++-------------------------------

core/ri/backend/opengl/gl_material.hpp | 2 +-

core/ri/backend/opengl/gl_program.cpp | 6 +++---

core/ri/backend/opengl/gl_program.hpp | 8 ++++----

core/ri/backend/opengl/gl_render_buffer.cpp | 2 +-

core/ri/backend/opengl/gl_shader_library.cpp | 10 +++++-----

core/ri/backend/opengl/gl_shader_library.hpp | 8 ++++----

core/ri/backend/opengl/gl_state.cpp | 4 ++--

core/ri/backend/opengl/gl_state.hpp | 44 ++++++++++++++++++++++----------------------

core/ri/backend/opengl/gl_texture.cpp | 12 ++++++------

core/ri/backend/opengl/gl_texture.hpp | 4 ++--

core/ri/render/mars_geometry.cpp | 12 ++++++------

core/ri/render/mars_geometry.hpp | 4 ++--

core/ri/render/mars_material.cpp | 22 ++++++++++++----------

core/ri/render/mars_material.hpp | 10 +++++-----

core/ri/render/mars_mesh.cpp | 20 ++++++++++++--------

core/ri/render/mars_mesh.hpp | 10 +++++-----

core/ri/render/mars_player_render_frame.cpp | 32 +++++++++++++++++---------------

core/ri/render/mars_player_render_frame.h | 16 ++++++++--------

core/ri/render/mars_renderer.cpp | 14 +++++++-------

core/ri/render/mars_renderer_ext.cpp | 4 ++--

core/ri/render/mars_renderer_ext.hpp | 2 +-

core/ri/render/mars_texture.cpp | 4 ++--

core/ri/render/render_frame.cpp | 14 ++++++++------

core/ri/render/render_frame.hpp | 8 ++++----

core/ri/render/render_frame_internal.cpp | 8 ++++----

core/ri/render/render_frame_internal.hpp | 8 ++++----

core/ri/render/render_pass.cpp | 42 +++++++++++++++++++++++-------------------

core/ri/render/render_pass.hpp | 18 +++++++++---------

core/ri/render/render_pass_color_attachment.cpp | 4 +++-

core/ri/render_base.cpp | 24 ++++++++++++++----------

core/ri/render_base.hpp | 4 ++--

core/sceneData/data/sprite_mesh_geometry.cpp | 24 +++++++++++-------------

core/sceneData/decoder/common_properties_decoder.cpp | 25 +++++++++++++------------

core/sceneData/decoder/composition_decoder.cpp | 6 +++---

core/sceneData/decoder/filter_content_decoder.cpp | 16 ++++++++--------

core/sceneData/decoder/interact_content_decoder.cpp | 8 ++++----

core/sceneData/decoder/item_decoder.cpp | 6 +++---

core/sceneData/decoder/particle_content_decoder.cpp | 9 +++++----

core/sceneData/decoder/plugin_content_decoder.cpp | 4 ++--

core/sceneData/decoder/sprite_content_decoder.cpp | 7 ++++---

core/sceneData/mars_data_base.cpp | 12 ++++++------

core/sceneData/mars_data_base.h | 2 +-

core/sceneData/scene_data_decoder.cpp | 58 ++++++++++++++++++++++++++++------------------------------

core/sceneData/scene_data_decoder_new.cpp | 30 +++++++++++++++---------------

core/util/color_utils.cpp | 15 ++++++++-------

core/util/mars_thread.cpp | 12 ++++++------

core/util/util.cpp | 12 ++++++------

core/util/vfx_value_getter.cpp | 28 ++++++++++++++--------------

core/util/vfx_value_getter.h | 2 +-

179 files changed, 1153 insertions(+), 1230 deletions(-)

改动这么大,仍然能通过编译,成功驱动 GPU 来雕花:

image.png


  JSON compilation database


JSON compilation database 是跨工具间分享构建参数和环境的一个通用格式,也顺带介绍给大家,做 c++ 工具/工作流的必备知识点。最常见的使用场景:vs code 里看 c++ 项目代码,也需要 compile_commands.json,那么如何获得它呢

Cmake

-DCMAKE_EXPORT_COMPILE_COMMANDS=ON,android cmake 构建流中默认被打开。

ndk-build

https://github.com/android/ndk/wiki/Changelog-r18

  • ndk-build can now generate a JSON Compilation Database
  • Generate with either ndk-build compile_commands.json (does not build) or ndk-build GEN_COMPILE_COMMANDS_DB=true (builds and generates database).


  对于 c++ 人才培养的启示


个人自己学习需要,或为团队项目需要,看过一些 c++ 的书,我稍微罗列下:


image.png

image.png

image.png


可见 c++ 人才达到既要视野广博、又能实战,培养/学习周期之长。同时有些历史包袱(以及过去不太好的 c++ 教育)被现代 c++ 给恰当解决了。而当下又恰逢普及现代 c++ 的十字路口,系统编程继续走现代 cpp(渐进式改良)或迁移到 Rust(彻底革新)的选型十字路口。若选型继续现代 c++ 路径,我们大可以把 cpp core guideline 的材料和工具当作抛弃包袱、培养现代 c++ 人才的一个契机。


以上都是人肉总结。


最后的最后,我们问问大模型怎么说:

智谱清言:


C++ Core Guidelines 是一组旨在帮助 C++ 开发者编写更可靠、可维护和高效代码的建议。它们是由 C++ 社区的专家制定的,经过广泛讨论和审查。遵循这些指南,对开发者有以下几个价值:


提高代码质量:遵循 Core Guidelines 可以帮助你编写更符合 C++ 语言特性和标准库的代码,从而提高代码的质量。这些指南覆盖了许多常见的编码问题,如资源管理、异常处理和现代 C++ 功能。


提高代码可维护性:遵循 Core Guidelines 可以帮助你编写更易于阅读、理解和维护的代码。这意味着你可以更容易地找到和修复代码中的错误,同时也使得新成员更易于加入项目。


提高代码可扩展性:遵循 Core Guidelines 可以帮助你编写更具有可扩展性的代码。这意味着你可以更容易地为代码添加新功能,而无需对现有代码进行大量的修改。


提高代码性能:遵循 Core Guidelines 可以帮助你编写更高效的代码。这些指南提供了关于如何优化代码性能的建议,如避免不必要的复制、使用合适的算法等。


促进团队协作:遵循 Core Guidelines 可以使你的代码与其他开发者的代码更容易地协同工作。这意味着团队成员可以更容易地理解、修改和扩展彼此的代码。


降低缺陷风险:遵循 Core Guidelines 可以降低你的代码中出现缺陷的风险。这些指南涵盖了许多常见的错误和陷阱,遵循它们可以帮助你避免这些问题。

总之,遵循 C++ Core Guidelines 可以帮助你编写更可靠、可维护、高效和易于扩展的代码,从而提高你的开发质量和工作效率。同时,这也有助于促进团队协作,降低项目风险,并提高代码的整体质量。


相关实践学习
部署Stable Diffusion玩转AI绘画(GPU云服务器)
本实验通过在ECS上从零开始部署Stable Diffusion来进行AI绘画创作,开启AIGC盲盒。
相关文章
|
16天前
|
前端开发 Java Shell
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
121 20
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
14天前
|
Dart 前端开发 Android开发
【09】flutter首页进行了完善-采用android studio 进行真机调试开发-增加了直播间列表和短视频人物列表-增加了用户中心-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【09】flutter首页进行了完善-采用android studio 进行真机调试开发-增加了直播间列表和短视频人物列表-增加了用户中心-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
37 4
【09】flutter首页进行了完善-采用android studio 进行真机调试开发-增加了直播间列表和短视频人物列表-增加了用户中心-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
1天前
|
算法 Serverless 数据处理
从集思录可转债数据探秘:Python与C++实现的移动平均算法应用
本文探讨了如何利用移动平均算法分析集思录提供的可转债数据,帮助投资者把握价格趋势。通过Python和C++两种编程语言实现简单移动平均(SMA),展示了数据处理的具体方法。Python代码借助`pandas`库轻松计算5日SMA,而C++代码则通过高效的数据处理展示了SMA的计算过程。集思录平台提供了详尽且及时的可转债数据,助力投资者结合算法与社区讨论,做出更明智的投资决策。掌握这些工具和技术,有助于在复杂多变的金融市场中挖掘更多价值。
22 12
|
1月前
|
编译器 数据安全/隐私保护 C++
【C++面向对象——继承与派生】派生类的应用(头歌实践教学平台习题)【合集】
本实验旨在学习类的继承关系、不同继承方式下的访问控制及利用虚基类解决二义性问题。主要内容包括: 1. **类的继承关系基础概念**:介绍继承的定义及声明派生类的语法。 2. **不同继承方式下对基类成员的访问控制**:详细说明`public`、`private`和`protected`继承方式对基类成员的访问权限影响。 3. **利用虚基类解决二义性问题**:解释多继承中可能出现的二义性及其解决方案——虚基类。 实验任务要求从`people`类派生出`student`、`teacher`、`graduate`和`TA`类,添加特定属性并测试这些类的功能。最终通过创建教师和助教实例,验证代码
54 5
|
2月前
|
JSON Java API
探索安卓开发:打造你的首个天气应用
在这篇技术指南中,我们将一起潜入安卓开发的海洋,学习如何从零开始构建一个简单的天气应用。通过这个实践项目,你将掌握安卓开发的核心概念、界面设计、网络编程以及数据解析等技能。无论你是初学者还是有一定基础的开发者,这篇文章都将为你提供一个清晰的路线图和实用的代码示例,帮助你在安卓开发的道路上迈出坚实的一步。让我们一起开始这段旅程,打造属于你自己的第一个安卓应用吧!
92 14
|
2月前
|
Java Linux 数据库
探索安卓开发:打造你的第一款应用
在数字时代的浪潮中,每个人都有机会成为创意的实现者。本文将带你走进安卓开发的奇妙世界,通过浅显易懂的语言和实际代码示例,引导你从零开始构建自己的第一款安卓应用。无论你是编程新手还是希望拓展技术的开发者,这篇文章都将为你打开一扇门,让你的创意和技术一起飞扬。
|
2月前
|
搜索推荐 前端开发 测试技术
打造个性化安卓应用:从设计到开发的全面指南
在这个数字时代,拥有一个定制的移动应用不仅是一种趋势,更是个人或企业品牌的重要延伸。本文将引导你通过一系列简单易懂的步骤,从构思你的应用理念开始,直至实现一个功能齐全的安卓应用。无论你是编程新手还是希望拓展技能的开发者,这篇文章都将为你提供必要的工具和知识,帮助你将创意转化为现实。
|
2月前
|
Java Android开发 开发者
探索安卓开发:构建你的第一个“Hello World”应用
在安卓开发的浩瀚海洋中,每个新手都渴望扬帆起航。本文将作为你的指南针,引领你通过创建一个简单的“Hello World”应用,迈出安卓开发的第一步。我们将一起搭建开发环境、了解基本概念,并编写第一行代码。就像印度圣雄甘地所说:“你必须成为你希望在世界上看到的改变。”让我们一起开始这段旅程,成为我们想要见到的开发者吧!
88 0
|
3月前
|
开发框架 前端开发 Android开发
安卓与iOS开发中的跨平台策略
在移动应用开发的战场上,安卓和iOS两大阵营各据一方。随着技术的演进,跨平台开发框架成为开发者的新宠,旨在实现一次编码、多平台部署的梦想。本文将探讨跨平台开发的优势与挑战,并分享实用的开发技巧,帮助开发者在安卓和iOS的世界中游刃有余。
|
4天前
|
JavaScript 搜索推荐 Android开发
【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
23 8
【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡

热门文章

最新文章

  • 1
    【01】噩梦终结flutter配安卓android鸿蒙harmonyOS 以及next调试环境配鸿蒙和ios真机调试环境-flutter项目安卓环境配置-gradle-agp-ndkVersion模拟器运行真机测试环境-本地环境搭建-如何快速搭建android本地运行环境-优雅草卓伊凡-很多人在这步就被难倒了
    14
  • 2
    Cellebrite UFED 4PC 7.71 (Windows) - Android 和 iOS 移动设备取证软件
    28
  • 3
    【03】仿站技术之python技术,看完学会再也不用去购买收费工具了-修改整体页面做好安卓下载发给客户-并且开始提交网站公安备案-作为APP下载落地页文娱产品一定要备案-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
    34
  • 4
    Android历史版本与APK文件结构
    121
  • 5
    【02】仿站技术之python技术,看完学会再也不用去购买收费工具了-本次找了小影-感觉页面很好看-本次是爬取vue需要用到Puppeteer库用node.js扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
    29
  • 6
    【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
    23
  • 7
    APP-国内主流安卓商店-应用市场-鸿蒙商店上架之必备前提·全国公安安全信息评估报告如何申请-需要安全评估报告的资料是哪些-优雅草卓伊凡全程操作
    60
  • 8
    【09】flutter首页进行了完善-采用android studio 进行真机调试开发-增加了直播间列表和短视频人物列表-增加了用户中心-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
    37
  • 9
    当flutter react native 等混开框架-并且用vscode-idea等编译器无法打包apk,打包安卓不成功怎么办-直接用android studio如何打包安卓apk -重要-优雅草卓伊凡
    73
  • 10
    【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
    121