<>简介

在过去几周里,我进行了一项令人大开眼界的实验,将 Chat-GPT(我使用的是 Bing Chat,它在后台使用了
GPT-4,并且可以免费使用)融入到我的日常 Android 开发工作流程中,以探索它是否能够提高我的工作效率。这实在是一个令人兴奋的实验!

几天以后,我对它加速我的开发工作流程的能力感到震撼!我能够以更快的速度完成更多任务!通过一段时间的尝试,我对其中的主要用例有了深入的了解,Chat-GPT
能够在您的开发工作中节省大量时间。因此,我将在本文中与大家分享这些内容。

请注意:我将在整篇文章中使用 Chat-GPT 来指代 Bing Chat,因为它们本质上是同一个工具。

适用于新手 Android 开发者的提示
首先,如果您是 Android 开发的新手,那么本文可能不太适合您。这篇文章更适合中级和高级的 Android 开发人员。

其次,不要仅仅依赖 Chat-GPT 这样的大型语言模型来盲目复制粘贴代码,而不去理解代码的作用。了解 Android
开发是一项比仅仅复制粘贴代码更有价值的技能。很多人可能没有意识到这一点,但是当您对 Android
开发的基础知识有了扎实的掌握后,您就能以更高效的方式利用语言模型,从而大大提升您的工作效率。

<>ChatGPT在哪些方面可提高Android开发者工作效率

<>生成文档

让我们从一个非常简单的用例开始。编写文档是您作为开发人员要做的最重要的事情之一。它不仅可以帮助其他人了解您的代码的作用,还可以帮助您提醒自己,当您在很长一段时间后回来重新访问时,您编写的代码正在执行什么操作。

传统上,它一直是许多程序员的祸根,因为它占用了宝贵的时间,无法实际编码您要构建的东西。在这里,Chat-GPT
可以节省大量时间!只需让它为您生成文档即可。但是,如果它没有传达您的想法,请确保校对和修改它生成的文档。这是一个超级有用的用例,它为我节省了大量时间!这是一个例子
// The function which needs to be documented suspend fun
getPlacesSuggestionsForQuery( @Query("q") query: String, @Query("session_token")
sessionToken: String, @Query("limit") @IntRange(1, 10) limit: Int = 10 ):
Response<SuggestionsResponse>
提示:为以下方法生成 KDOC kotlin 文档 — “…”

<>生成映射函数

这是一个简单但非常有用的用例。如果您通过应用一些干净的架构原则来编写您的应用程序,您可能会编写很多映射器函数。在大多数情况下,这些是您必须编写的样板代码,以便将一个架构层中使用的对象转换为不同架构层中使用的对象。

同样,Chat-GPT
可以使编写所有这些映射器函数的工作变得轻而易举!只需添加两个类的定义,并要求它编写一个映射器函数即可。就这么简单!只需确保验证它生成的代码是正确的。这是一个例子。
// Class 1 data class WeatherDetails( val nameOfLocation: String, val
temperature: Temperature, val wind: Wind, val weatherCondition: WeatherCondition
, val humidity: String, val pressure: String ) { data class Temperature( val
currentTemp: String, val minTemperature: String, val maxTemperature: String, )
data class Wind(val speed: String, val direction: String) data class
WeatherCondition( val oneWordDescription: String, @DrawableRes val
currentWeatherConditionIcon: Int, ) } // Class 2 data class BriefWeatherDetails(
val nameOfLocation: String, val currentTemperature: String, val shortDescription
: String, @DrawableRes val shortDescriptionIcon: Int, )
提示:为以下两个类编写一个映射器函数——“…”和“…”

但是,我希望映射器函数成为该类的扩展WeatherDetails。因此,我要求将其作为扩展功能。

提示:将其作为 WeatherDetails 类的扩展函数

<>用样本数据填充数据类

作为一名开发人员,您肯定遇到过这样一种情况:您需要创建一个带有样本数据的模型数据类的实例,以一时兴起来测试一些东西。好吧,这是 Chat-GPT
的完美用例。假设我想填充此类的所有属性以快速测试可组合函数。
data class BriefWeatherDetails( val nameOfLocation: String, val
currentTemperature: String, val shortDescription: String, @DrawableRes val
shortDescriptionIcon: Int ) @Preview @Composable private fun Preview(){ . .
CompactWeatherCard( modifier = Modifier.padding(horizontal = 16.dp),
briefWeatherDetails:BriefWeatherDetails = //need a fake instance here, onClick =
{ /*TODO*/ } ) . . }
我可以简单地要求 Chat-GPT 生成一个类的实例,其中填充了样本数据。

提示:使用样本数据创建此类的一个实例——“……”

除了需要更改图标的资源 ID 之外,我还得到了一个充满示例数据的实例,我可以立即使用它!如果我提到了资源 ID,它可能也会正确添加它!

<>生成 composable previews

如果您使用 Jetpack Compose,那么这就是为您准备的!设置可组合预览可能是一项相对耗时的任务。您必须创建一个新的私有函数,用
注释它@Preview,用您的主题可组合项包围可组合项,并用示例数据填充可组合项的参数。光是查看可组合项的预览就需要做大量工作!

不用担心!你可能已经猜到了!Chat-GPT 支持您!只需让它为您完成所有工作!这是一个例子。
// Here's an overload of the previous composable that doesn't depend on any //
domain object. Let's ask Chat-GPT to generate a preview for us. fun
CompactWeatherCard( nameOfLocation: String, shortDescription: String,
@DrawableRes shortDescriptionIcon: Int, weatherInDegrees: String, onClick: () ->
Unit, modifier: Modifier = Modifier ) {...}
提示:为以下可组合项创建一个预览可组合项 — “…”

它甚至自己用示例数据填充了可组合项的参数.
现在,我想用CompactWeatherCard一个主题可组合项和一个表面可组合项包围可组合项。所以,我要求它也这样做。

提示:使用名为 WeatherAppThemeComposable 的可组合项和 Surface 可组合项包裹预览中的可组合项

我注意到主题可组合项具有后缀“Composable”,因为我在之前的提示中犯了一个错误。让我们纠正它。

提示:将 WeatherAppThemeComposable 重命名为 WeatherAppTheme

<>结论

这篇博文到此结束 ,这些只是我发现 Chat-GPT 非常有用的几个用例。我相信我会发现更多,我使用它的次数越多。我会确保在找到它们时分享它们。

技术
下载桌面版
GitHub
Gitee
SourceForge
百度网盘(提取码:draw)
云服务器优惠
华为云优惠券
腾讯云优惠券
阿里云优惠券
Vultr优惠券
站点信息
问题反馈
邮箱:[email protected]
吐槽一下
QQ群:766591547
关注微信