Tech

生成AIプログラミング事始め

投稿日:

はじめに

生成AIが注目され始めてから大分時間が立ちましたが、私の周りでも生成AIの活用が活発になり、いよいよ本格的に取り組まないといけないなと危機感を覚えています。

今はまだ、IDE上でGitHub Copilotを使うくらいしか活用できていないので、そもそも生成AIプログラミングとはなんぞや、というところから学んでいきたいと思います。

生成AIプログラミング

まず初めに、生成AIプログラミングの概要とメリット、注意点について書いていきます。

生成AIプログラミングとは

生成AIプログラミングとは、AIを活用してコードを自動生成する手法や技術を指します。

開発者はAIに対して、自然言語(我々が普段やり取りするようなメッセージ)で指示(プロンプト)を与え、AIにコードを生成してもらいます。

生成AIプログラミングのメリット

生成AIプログラミングを導入することのメリットとしてまず挙げられるのが、大幅な生産性の向上です。

生成AIが処理するのに適した内容であれば、指示を与えてから数秒から数十秒程度で実装が完了します。適した内容というのはたとえば、よくある処理(Get系のAPIとか)やunit testなどが思い浮かびます。

その他のメリットとしては、コードの品質の向上、統一などが期待できます。

生成AIプログラミングの流れ

生成AIプログラミングにおける実装の流れの一例は以下のとおりです。

  1. 規約や学習のためのデータを読み込ませる
  2. 生成AIに対してプロンプトを与える
  3. 出力された結果(コード)を確認し、修正指示を出す
  4. 2を何度か繰り返したり、必要に応じて手動で書き直す
  5. 学習データを整備して、AIの精度を高める

生成AIプログラミングにおける注意点

生成AIプログラミングにおける注意点としては、まず、ハルシネーションが挙げられます。

これは、AIが誤った成果をアウトプットしてしまう現象のことで、コードに限らずAIが生成するあらゆる成果物に対して起こり得る問題です。

そのため、生成されたコードが正しいかの確認(ファクトチェック)が欠かせません。

また、生成させる内容によっては、指示を何度も与えても期待する結果が得られない場合があります。

生成AIプログラミングのためのツール

ここでは、生成AIプログラミングを行うためのツールをいくつか紹介します。

GitHub Copilot

GitHub Copilotは、GitHubが提供しているツールで、すでに多くの方が活用されていると思います。

開発者が入力を行うとSuggestionが行われ、行単位やある程度のコードブロックを瞬時に生成することができます。

Copliotの効果的な活用のためのTipsは様々あり、関連するファイルを開いていたり、適切なコメントをいれることで精度をたかめることができます。

その他にも、Copilot Chatで質問できたり、スラッシュコマンドを実行できたりするようです。

Amazon Q Developer

Amazon Q Developerは、コードの自動生成やレビュー、AWSサービスの最適化やサポートや問い合わせ、運用上のインシデントの調査、ワークロードの変換など、コードの生成のみならずAWSのサービスに関する様々な機能を提供しているようです。

VS Codeのプラグインの他に、MacやLinux向けのコマンドラインツールも提供しています。

Cursor

Cursorは、VS Codeベースに作られたAI機能を搭載したコードエディタです。

VS Codeの機能の他に、AIによるコード補完やチャットによるAIへの質問、指示といった機能があります。

Cursor自体がAIモデル(LLM)を搭載しているわけではなく、外部のLLMと連携する仕組みを持っているので、様々なAIモデルと連携することができます。

Cline

Clineは、VS Codeの拡張機能として提供されているオープンソースのAIエージェントです。

コードの自動生成の他に、ターミナルを操作して依存パッケージをインストールしたり、エラーが出た際にログ解析を行い、修正案を提案、実行することまでやってくれます。

こちらも、様々なLLMを選択することができます。

Claude Code

Claude Codeは、ターミナル上で動作するエージェント型のコーディングツールです。

コード生成に加えて、ファイルの編集、テストの実行、Gitの操作などを自然言語で指示できます。

他にも、ターミナル上で動作するのでスクリプト化できたり、APIの提供やAWS、GCPなどでホストすることもできます。

Devin

Devinは、自立型AIソフトウェアエンジニアとのことで、コーディングのサポートのみならず、実装からバグの修正まで開発プロセス全体をエンドツーエンドで自律的に処理する能力をもっており、既存のAIエージェントとは一線を画す存在のようです。

SlackやGitHubなどと連携したうえで、自然言語での指示に基づき、コードの設計、実装、デバッグ、テストなどに加え、Web上の情報を検索して情報収集を行い、ソフトウェア開発タスクを自律的に遂行します。

費用は月額$500となかなかに高額ですが、それだけの価値はあるようです。

さいごに

生成AIプログラミングについてざっくりとさわり、ツールについてもいくつか紹介しました。

普段使っているCoplitですらまだまだ使いこなせていないなと感じているので、まずはここからもっと活用できるようにしていき、Clineなどや、いずれはDevinについても実際に使ってみたいと思います。

おすすめ書籍

Amazon Bedrock 生成AIアプリ開発入門 [AWS深掘りガイド] 生成AIアプリケーション開発入門:基礎から応用まで学べるエンジニア向け実践ガイド

blog-page_footer_336




blog-page_footer_336




-Tech

執筆者:

免責事項

このブログは、記事上部に記載のある投稿日時点の一般的な情報を提供するものであり、投資等の勧誘・法的・税務上の助言を提供するものではありません。仮想通貨の投資・損益計算は複雑であり、個々の取引状況や法律の変更によって異なる可能性があります。ブログに記載された情報は参考程度のものであり、特定の状況に基づいた行動の決定には専門家の助言を求めることをお勧めします。当ブログの情報に基づいた行動に関連して生じた損失やリスクについて、筆者は責任を負いかねます。最新の法律や税務情報を確認し、必要に応じて専門家に相談することをお勧めします。


comment

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

CAPTCHA


関連記事

【iOS14】App Groups を使用して WidgetKit にデータ共有

1 はじめに2 App Groupsの準備2.1 App Groupsの許可2.2 App Groupsの使い方3 WidgetKitにデータ共有4 さいごに5 おすすめ書籍 はじめに 今回はアプリ側 ...

react-icon

【React初心者】改めて主要なhookの使い方

1 はじめに2 useState3 useEffect3.1 useLayoutEffect4 useCallback5 useContext6 さいごに7 おすすめ書籍 はじめに 今回はReactで ...

ReactNative画面遷移

1 はじめに2 React Navigation3 React Navigationのインストール4 実装5 さいごに6 おすすめ書籍 はじめに こんにちはnukkyです。 ブログを書きながらアプリを ...

ReactNative入門

1 はじめに2 そもそもReact Nativeとは3 JSXとは3.1 JSXに値を埋め込む3.2 属性の値を設定する3.3 関数でJSXを作る4 コンポーネントとは4.1 再利用性4.2 新規コン ...

[C#]Genericsの使い方をまとめてみた。その2

1 はじめに2 Genericsの構文3 型パラメーター4 制約条件5 規定値6 さいごに7 おすすめ書籍 はじめに こんにちはsuzukiです。ブログを書いているときAndroid10が発表され、ア ...

フォロー

blog-page_side_responsive

2025年8月
 12
3456789
10111213141516
17181920212223
24252627282930
31  

アプリ情報

私たちは無料アプリもリリースしています、ぜひご覧ください。 下記のアイコンから無料でダウンロードできます。