<?xml version="1.0" encoding="UTF-8"?><rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>コーディング</title>
	<atom:link href="https://techgrowup.net/tag/%e3%82%b3%e3%83%bc%e3%83%87%e3%82%a3%e3%83%b3%e3%82%b0/feed/" rel="self" type="application/rss+xml" />
	<link>https://techgrowup.net</link>
	<description>エンジニアを強くする</description>
	<lastBuildDate>Thu, 30 Jan 2025 11:00:00 +0000</lastBuildDate>
	<language>ja</language>
	<sy:updatePeriod>
	hourly	</sy:updatePeriod>
	<sy:updateFrequency>
	1	</sy:updateFrequency>
	<generator>https://wordpress.org/?v=6.9.4</generator>

<image>
	<url>https://techgrowup.net/wp-content/uploads/2021/05/hp-icon-150x150.png</url>
	<title>コーディング</title>
	<link>https://techgrowup.net</link>
	<width>32</width>
	<height>32</height>
</image> 
	<item>
		<title>AIでコーディングを効率化！コード生成からバグ修正までの活用術と注意点を徹底解説</title>
		<link>https://techgrowup.net/prompt-engineering-coding/</link>
					<comments>https://techgrowup.net/prompt-engineering-coding/?noamp=mobile#respond</comments>
		
		<dc:creator><![CDATA[techgrowup]]></dc:creator>
		<pubDate>Thu, 30 Jan 2025 11:00:00 +0000</pubDate>
				<category><![CDATA[プロンプトエンジニアリング]]></category>
		<category><![CDATA[AI]]></category>
		<category><![CDATA[Chain of Thought]]></category>
		<category><![CDATA[コーディング]]></category>
		<category><![CDATA[コード生成]]></category>
		<category><![CDATA[バグ修正]]></category>
		<category><![CDATA[プログラミング]]></category>
		<category><![CDATA[リファクタリング]]></category>
		<category><![CDATA[大規模言語モデル]]></category>
		<guid isPermaLink="false">https://techgrowup.net/?p=2411</guid>

					<description><![CDATA[はじめに 近年、AI技術の急速な発展により、私たちの仕事や生活は大きく変化しつつあります。特に大規模言語モデル（LLM）をはじめとするAI技術は、プログラミングの分野にも大きな恩恵をもたらしています。「AIでコードを書く [&#8230;]]]></description>
										<content:encoded><![CDATA[
<h1 class="wp-block-heading">はじめに</h1>



<p>近年、AI技術の急速な発展により、私たちの仕事や生活は大きく変化しつつあります。特に大規模言語モデル（LLM）をはじめとするAI技術は、プログラミングの分野にも大きな恩恵をもたらしています。「AIでコードを書く」「AIでバグを修正する」といった光景は、もはやSFではなく、実務レベルで取り入れられる時代になりました。本記事では、AIを活用したプログラミング支援のメリットや具体的な使い方、注意点などを詳しく解説します。さらに、インターネット上のさまざまな知見を取り込みながら、プログラミング初心者から上級者まで役立つ情報をまとめました。プログラマの方はもちろん、これからプログラミングを学びたいという方も、ぜひ本記事を活用してみてください。</p>



<h2 class="wp-block-heading">AIがもたらすプログラミング革命とは？</h2>



<p>プログラミングとは、本来、専門家がプログラム言語を使ってロジックを記述し、コンピュータに命令を与える行為です。ところが、大規模言語モデル（LLM）をはじめとするAI技術が加わることで、このプロセスが<strong>飛躍的にシンプルかつ効率的</strong>になりつつあります。</p>



<ul class="wp-block-list">
<li><strong>コード生成</strong><br>AIが「どのような機能を実装したいか」を自然言語で理解して、必要なプログラムコードを出力してくれる。</li>



<li><strong>コード補完</strong><br>開発者が書きかけのコードに対して、AIが次の行や構文を提案してくれるため、生産性が向上。</li>



<li><strong>エラー検出・修正提案</strong><br>何らかのエラーやバグがあった場合に、AIがその原因と修正方法を指南してくれるケースも増えている。</li>
</ul>



<p>こうした流れは、あらゆるプログラミング言語・フレームワークにおいて進んでおり、「プログラマがゼロからコードをすべて書く」必要がなくなりつつあるとも言われています。もちろん、人間の創造力や論理力を完全に置き換えるわけではありませんが、<strong>開発速度や品質が大幅に向上</strong>するのは事実です。</p>



<h2 class="wp-block-heading">AIコード生成の基本的な仕組み</h2>



<p>AIが文章（自然言語）で記述された要望や仕様を読み取り、そこからプログラムコードを生成できるのは、いわゆる**大規模言語モデル（LLM）**の能力によるものです。LLMはインターネット上にある膨大なテキストデータを学習しており、その中にはプログラミング関連の情報（オープンソースコードやドキュメント等）も含まれています。</p>



<h3 class="wp-block-heading">自然言語理解とプログラム構造</h3>



<p>AIは自然言語で書かれた指示や質問を解析し、「どのようなプログラムを生成すればよいか」を内部的に推論します。これは以下のステップを経ると言われています。</p>



<ol class="wp-block-list">
<li><strong>トークナイズ</strong><br>入力文を単語やサブワードに分解。</li>



<li><strong>文脈理解</strong><br>文章全体から、何を実装すべきか、どんな言語・フレームワークが要求されているかを把握。</li>



<li><strong>コード出力</strong><br>言語モデルが「もっとも適切と考えられる」コード断片を順次生成。</li>
</ol>



<h3 class="wp-block-heading">制約や追加情報の取り扱い</h3>



<p>ユーザーが明示的に「Pythonを使って」「Node.jsで」など指定すると、AIはその指定に合った構文やライブラリを優先します。また、「データベースはMySQL」「APIはRESTfulで」といった制約を併記することで、より正確なコードが出力されやすくなります。</p>



<h2 class="wp-block-heading">なぜAIを使ったコーディングが注目されるのか</h2>



<h3 class="wp-block-heading">生産性向上</h3>



<p>AIがコードを自動生成・補完してくれるため、開発者はロジックの設計やUI/UXの検討などに時間を割けるようになります。<strong>単純な繰り返し作業</strong>や<strong>よくあるデザインパターン</strong>の実装はAIが得意とするところなので、そこにかかる工数を削減するのは大きな利点です。</p>



<h3 class="wp-block-heading">学習コストの低減</h3>



<p>特に初心者プログラマが新しい言語やフレームワークを学ぶ際、AIがリアルタイムでサンプルコードや構文を提示してくれると、習得がスムーズになるケースがあります。インターネットで断片的な情報を探すより、AIが一貫した文脈でヒントを与えるほうが効率的な場合もあります。</p>



<h3 class="wp-block-heading">チーム開発でのメンテナンス性向上</h3>



<p>コード補完機能やリファクタリング提案をAIがサポートすることで、チーム全体のコード品質が統一されやすくなります。<strong>可読性や命名規則</strong>をAIが守るように誘導すれば、メンテナンスや保守が楽になるという効果も期待できます。</p>



<h2 class="wp-block-heading">具体的なAIコーディングの応用例</h2>



<h3 class="wp-block-heading">コード補完・自動生成</h3>



<p>有名な例として、GitHubの「Copilot」はOpenAIの技術を活用しており、エディタ上で<strong>次の数行を推測して補完</strong>してくれます。また、ChatGPTなどの会話型AIに「こういう機能をPythonで書きたい」と相談すると、<strong>関数やクラスをまるごと出力</strong>してくれるケースも多いです。</p>



<h6 class="wp-block-heading">実例</h6>



<div class="wp-block-kevinbatdorf-code-block-pro" data-code-block-pro-font-family="Code-Pro-JetBrains-Mono" style="font-size:.875rem;font-family:Code-Pro-JetBrains-Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;line-height:1.25rem;--cbp-tab-width:2;tab-size:var(--cbp-tab-width, 2)"><span style="display:block;padding:16px 0 0 16px;margin-bottom:-1px;width:100%;text-align:left;background-color:#1E1E1E"><svg xmlns="http://www.w3.org/2000/svg" width="54" height="14" viewBox="0 0 54 14"><g fill="none" fill-rule="evenodd" transform="translate(1 1)"><circle cx="6" cy="6" r="6" fill="#FF5F56" stroke="#E0443E" stroke-width=".5"></circle><circle cx="26" cy="6" r="6" fill="#FFBD2E" stroke="#DEA123" stroke-width=".5"></circle><circle cx="46" cy="6" r="6" fill="#27C93F" stroke="#1AAB29" stroke-width=".5"></circle></g></svg></span><span role="button" tabindex="0" data-code="ユーザー: 「10個の整数をリストで受け取り、その平均値を返すPythonコードを書いて」
AI: (Pythonコードを生成)" style="color:#D4D4D4;display:none" aria-label="Copy" class="code-block-pro-copy-button"><svg xmlns="http://www.w3.org/2000/svg" style="width:24px;height:24px" fill="none" viewBox="0 0 24 24" stroke="currentColor" stroke-width="2"><path class="with-check" stroke-linecap="round" stroke-linejoin="round" d="M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2m-6 9l2 2 4-4"></path><path class="without-check" stroke-linecap="round" stroke-linejoin="round" d="M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2"></path></svg></span><pre class="shiki dark-plus" style="background-color: #1E1E1E" tabindex="0"><code><span class="line"><span style="color: #DCDCAA">ユーザー</span><span style="color: #D4D4D4">: 「10個の整数をリストで受け取り、その平均値を返すPythonコードを書いて」</span></span>
<span class="line"><span style="color: #DCDCAA">AI</span><span style="color: #D4D4D4">: (Pythonコードを生成)</span></span></code></pre></div>



<h3 class="wp-block-heading">バグ検出と修正アシスト</h3>



<p>AIにエラーメッセージや不具合が起きている部分のコードを入力すると、<strong>バグの原因を推測し、修正案を提示</strong>してくれます。もちろん完璧ではありませんが、ヒントとして役立つ場合が多いです。</p>



<h6 class="wp-block-heading">実例</h6>



<div class="wp-block-kevinbatdorf-code-block-pro" data-code-block-pro-font-family="Code-Pro-JetBrains-Mono" style="font-size:.875rem;font-family:Code-Pro-JetBrains-Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;line-height:1.25rem;--cbp-tab-width:2;tab-size:var(--cbp-tab-width, 2)"><span style="display:block;padding:16px 0 0 16px;margin-bottom:-1px;width:100%;text-align:left;background-color:#1E1E1E"><svg xmlns="http://www.w3.org/2000/svg" width="54" height="14" viewBox="0 0 54 14"><g fill="none" fill-rule="evenodd" transform="translate(1 1)"><circle cx="6" cy="6" r="6" fill="#FF5F56" stroke="#E0443E" stroke-width=".5"></circle><circle cx="26" cy="6" r="6" fill="#FFBD2E" stroke="#DEA123" stroke-width=".5"></circle><circle cx="46" cy="6" r="6" fill="#27C93F" stroke="#1AAB29" stroke-width=".5"></circle></g></svg></span><span role="button" tabindex="0" data-code="ユーザー: 「このコードを実行するとNullPointerExceptionが出ます。原因と対処法を教えてください。コードは...」
AI: 「恐らく○○行目の△△がnullになっています。対策としては...」" style="color:#D4D4D4;display:none" aria-label="Copy" class="code-block-pro-copy-button"><svg xmlns="http://www.w3.org/2000/svg" style="width:24px;height:24px" fill="none" viewBox="0 0 24 24" stroke="currentColor" stroke-width="2"><path class="with-check" stroke-linecap="round" stroke-linejoin="round" d="M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2m-6 9l2 2 4-4"></path><path class="without-check" stroke-linecap="round" stroke-linejoin="round" d="M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2"></path></svg></span><pre class="shiki dark-plus" style="background-color: #1E1E1E" tabindex="0"><code><span class="line"><span style="color: #DCDCAA">ユーザー</span><span style="color: #D4D4D4">: 「このコードを実行するとNullPointerExceptionが出ます。原因と対処法を教えてください。コードは...」</span></span>
<span class="line"><span style="color: #DCDCAA">AI</span><span style="color: #D4D4D4">: 「恐らく○○行目の△△がnullになっています。対策としては...」</span></span></code></pre></div>



<h3 class="wp-block-heading">リファクタリング支援</h3>



<p>書き散らかしたコードを整形・最適化する作業は、プログラマにとって負担が大きいものです。AIに対して「このコードをもう少し短く書いて」「オブジェクト指向的な設計にリファクタリングして」と頼むと、<strong>より洗練されたバージョン</strong>を提示してくれることがあります。</p>



<h3 class="wp-block-heading">ドキュメント生成</h3>



<p>コードだけでなく、その<strong>解説文やAPI仕様</strong>などを自動生成する用途も注目されています。特に大規模プロジェクトでは、「関数やクラス単位でコメントや使用例をまとめる」タスクが大変ですが、AIに草案を作らせることで工数を削減可能です。</p>



<h2 class="wp-block-heading">プロンプトエンジニアリングの重要性</h2>



<p>AIに「コーディングして」と言うだけでは、思ったとおりのコードが出ないこともしばしば。そこで必要になるのが、<strong>プロンプトエンジニアリング</strong>です。具体的には、</p>



<ol class="wp-block-list">
<li><strong>言語や環境の指定</strong>: Python, JavaScript, Javaなど</li>



<li><strong>バージョンやライブラリの指定</strong>: Python 3.9以上, Flask, Spring Bootなど</li>



<li><strong>目標とする機能</strong>: 例）「ファイルを読み込み、行数をカウントする」「REST APIを立ち上げる」</li>



<li><strong>出力形式</strong>: 単一ファイルか複数ファイルか、追加コメントを入れるかどうか など</li>
</ol>



<p>加えて、<strong>過度に抽象的な指示</strong>はAIが解釈を誤るリスクが高いので、<strong>要件をできるだけ細かく箇条書き</strong>するのが成功のコツです。大規模言語モデルの強みは「膨大な知識の中から最適解を推定する」点にあるので、入力を具体化すればするほど精度が上がると言えます。</p>



<h2 class="wp-block-heading">AIコーディングのステップ-by-ステップ事例</h2>



<h3 class="wp-block-heading">小規模スクリプトの生成</h3>



<p><strong>ケース</strong>: システム管理者が、特定フォルダ内のファイルを一覧表示しつつ、拡張子ごとに数をカウントするスクリプトが欲しい。</p>



<p><strong>プロンプト例</strong>:</p>



<div class="wp-block-kevinbatdorf-code-block-pro" data-code-block-pro-font-family="Code-Pro-JetBrains-Mono" style="font-size:.875rem;font-family:Code-Pro-JetBrains-Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;line-height:1.25rem;--cbp-tab-width:2;tab-size:var(--cbp-tab-width, 2)"><span style="display:block;padding:16px 0 0 16px;margin-bottom:-1px;width:100%;text-align:left;background-color:#1E1E1E"><svg xmlns="http://www.w3.org/2000/svg" width="54" height="14" viewBox="0 0 54 14"><g fill="none" fill-rule="evenodd" transform="translate(1 1)"><circle cx="6" cy="6" r="6" fill="#FF5F56" stroke="#E0443E" stroke-width=".5"></circle><circle cx="26" cy="6" r="6" fill="#FFBD2E" stroke="#DEA123" stroke-width=".5"></circle><circle cx="46" cy="6" r="6" fill="#27C93F" stroke="#1AAB29" stroke-width=".5"></circle></g></svg></span><span role="button" tabindex="0" data-code="「Python3を使って、フォルダ内のファイルを走査し、拡張子別にファイル数をカウントして表示するスクリプトを書いてください。
条件:
- フォルダパスはコマンドライン引数から受け取る
- 存在しないフォルダの場合はエラーメッセージを表示
- 結果は「拡張子: ファイル数」という形式で出力」" style="color:#D4D4D4;display:none" aria-label="Copy" class="code-block-pro-copy-button"><svg xmlns="http://www.w3.org/2000/svg" style="width:24px;height:24px" fill="none" viewBox="0 0 24 24" stroke="currentColor" stroke-width="2"><path class="with-check" stroke-linecap="round" stroke-linejoin="round" d="M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2m-6 9l2 2 4-4"></path><path class="without-check" stroke-linecap="round" stroke-linejoin="round" d="M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2"></path></svg></span><pre class="shiki dark-plus" style="background-color: #1E1E1E" tabindex="0"><code><span class="line"><span style="color: #D4D4D4">「Python3を使って、フォルダ内のファイルを走査し、拡張子別にファイル数をカウントして表示するスクリプトを書いてください。</span></span>
<span class="line"><span style="color: #D4D4D4">条件:</span></span>
<span class="line"><span style="color: #CE9178">- フォルダパスはコマンドライン引数から受け取る</span></span>
<span class="line"><span style="color: #CE9178">- 存在しないフォルダの場合はエラーメッセージを表示</span></span>
<span class="line"><span style="color: #CE9178">- 結果は「拡張子: ファイル数」という形式で出力」</span></span></code></pre></div>



<p>AIはこの指示を読み取り、Pythonでの実装を提案するでしょう。ユーザーは出力されたコードをコピペし、動作を確認しながら問題なければ完成、となります。</p>



<h3 class="wp-block-heading">複数ファイル構成のプロジェクト</h3>



<p><strong>ケース</strong>: Webアプリケーションをフロントエンド（React）とバックエンド（Express.js）に分割して作りたい。</p>



<p><strong>プロンプト例</strong>:</p>



<div class="wp-block-kevinbatdorf-code-block-pro" data-code-block-pro-font-family="Code-Pro-JetBrains-Mono" style="font-size:.875rem;font-family:Code-Pro-JetBrains-Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;line-height:1.25rem;--cbp-tab-width:2;tab-size:var(--cbp-tab-width, 2)"><span style="display:block;padding:16px 0 0 16px;margin-bottom:-1px;width:100%;text-align:left;background-color:#1E1E1E"><svg xmlns="http://www.w3.org/2000/svg" width="54" height="14" viewBox="0 0 54 14"><g fill="none" fill-rule="evenodd" transform="translate(1 1)"><circle cx="6" cy="6" r="6" fill="#FF5F56" stroke="#E0443E" stroke-width=".5"></circle><circle cx="26" cy="6" r="6" fill="#FFBD2E" stroke="#DEA123" stroke-width=".5"></circle><circle cx="46" cy="6" r="6" fill="#27C93F" stroke="#1AAB29" stroke-width=".5"></circle></g></svg></span><span role="button" tabindex="0" data-code="「ReactとExpress.jsを使った簡単なWebアプリのサンプルコードを作ってください。
- フロントエンド: npm create-react-appで生成された構成を基にしてほしい
- バックエンド: Express.jsでAPIエンドポイント /api/data を作り、JSONを返す
- それぞれのディレクトリ構造や主要なファイル（index.js, App.jsなど）をわかりやすく例示して」" style="color:#D4D4D4;display:none" aria-label="Copy" class="code-block-pro-copy-button"><svg xmlns="http://www.w3.org/2000/svg" style="width:24px;height:24px" fill="none" viewBox="0 0 24 24" stroke="currentColor" stroke-width="2"><path class="with-check" stroke-linecap="round" stroke-linejoin="round" d="M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2m-6 9l2 2 4-4"></path><path class="without-check" stroke-linecap="round" stroke-linejoin="round" d="M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2"></path></svg></span><pre class="shiki dark-plus" style="background-color: #1E1E1E" tabindex="0"><code><span class="line"><span style="color: #D4D4D4">「ReactとExpress.jsを使った簡単なWebアプリのサンプルコードを作ってください。</span></span>
<span class="line"><span style="color: #CE9178">- フロントエンド: npm create-react-appで生成された構成を基にしてほしい</span></span>
<span class="line"><span style="color: #CE9178">- バックエンド: Express.jsでAPIエンドポイント /api/data を作り、JSONを返す</span></span>
<span class="line"><span style="color: #CE9178">- それぞれのディレクトリ構造や主要なファイル（index.js, App.jsなど）をわかりやすく例示して」</span></span></code></pre></div>



<p>AIはフロントエンドとバックエンドのフォルダ構成や主要ファイルの内容を示すことができます。もちろん、細部はユーザーが調整する必要がありますが、大まかなプロジェクトの骨組みを素早く得られるのは大きなメリットです。</p>



<h3 class="wp-block-heading">API連携サンプルコード</h3>



<p><strong>ケース</strong>: 外部サービスのREST APIを呼び出し、JSONを取得して整形表示するコードが欲しい。</p>



<p><strong>プロンプト例</strong>:</p>



<div class="wp-block-kevinbatdorf-code-block-pro" data-code-block-pro-font-family="Code-Pro-JetBrains-Mono" style="font-size:.875rem;font-family:Code-Pro-JetBrains-Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;line-height:1.25rem;--cbp-tab-width:2;tab-size:var(--cbp-tab-width, 2)"><span style="display:block;padding:16px 0 0 16px;margin-bottom:-1px;width:100%;text-align:left;background-color:#1E1E1E"><svg xmlns="http://www.w3.org/2000/svg" width="54" height="14" viewBox="0 0 54 14"><g fill="none" fill-rule="evenodd" transform="translate(1 1)"><circle cx="6" cy="6" r="6" fill="#FF5F56" stroke="#E0443E" stroke-width=".5"></circle><circle cx="26" cy="6" r="6" fill="#FFBD2E" stroke="#DEA123" stroke-width=".5"></circle><circle cx="46" cy="6" r="6" fill="#27C93F" stroke="#1AAB29" stroke-width=".5"></circle></g></svg></span><span role="button" tabindex="0" data-code="「外部の天気APIを呼び出すためのサンプルコードをGo言語で書いてください。
- HTTP GETリクエストで取得
- JSONパースして、温度と天気概況をコンソールに出力
- APIキーを環境変数から読み込む設計で」" style="color:#D4D4D4;display:none" aria-label="Copy" class="code-block-pro-copy-button"><svg xmlns="http://www.w3.org/2000/svg" style="width:24px;height:24px" fill="none" viewBox="0 0 24 24" stroke="currentColor" stroke-width="2"><path class="with-check" stroke-linecap="round" stroke-linejoin="round" d="M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2m-6 9l2 2 4-4"></path><path class="without-check" stroke-linecap="round" stroke-linejoin="round" d="M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2"></path></svg></span><pre class="shiki dark-plus" style="background-color: #1E1E1E" tabindex="0"><code><span class="line"><span style="color: #D4D4D4">「外部の天気APIを呼び出すためのサンプルコードをGo言語で書いてください。</span></span>
<span class="line"><span style="color: #CE9178">- HTTP GETリクエストで取得</span></span>
<span class="line"><span style="color: #CE9178">- JSONパースして、温度と天気概況をコンソールに出力</span></span>
<span class="line"><span style="color: #CE9178">- APIキーを環境変数から読み込む設計で」</span></span></code></pre></div>



<p>このように環境変数の扱いなど具体的な要件を明記すれば、AIはそれに沿ったコードを提示してくれます。ユーザーは適宜APIキーやURLを修正すれば、即座に動くサンプルが完成するはずです。</p>



<h2 class="wp-block-heading">注意点とリスク管理</h2>



<h3 class="wp-block-heading">著作権やライセンスへの配慮</h3>



<p>AIが生成したコードの中には、学習データ由来の既存コードの一部が含まれる可能性があります。ライセンス的に問題のない範囲で使うよう、<strong>オープンソースのルール</strong>や企業のコンプライアンスを確認することが重要です。</p>



<h3 class="wp-block-heading">セキュリティホールのリスク</h3>



<p>AIが生成したコードが必ずしもセキュアとは限りません。SQLインジェクションやXSSなどの脆弱性が混在している可能性もあるため、<strong>セキュリティ対策は従来通り専門知識を持った人間が検証</strong>すべきです。</p>



<h3 class="wp-block-heading">バグや構文エラーの可能性</h3>



<p>AIが出力したコードがコンパイルエラーやランタイムエラーを起こすケースもあり得ます。初心者は一見“正しそう”に見えるコードを鵜呑みにしがちなので、必ず実行テストやレビューを行いましょう。</p>



<h2 class="wp-block-heading">AIコーディングの効率をさらに高めるヒント</h2>



<h3 class="wp-block-heading">Chain of Thought（思考プロセス）の活用</h3>



<p>大規模言語モデルに対して、推論過程を出力させると、コードを生成する際のロジックが透けて見えます。これにより、<strong>どのようにしてAIが解答に至ったかを理解しやすくなり、デバッグ時の参考になる</strong>場合があります。ただし、情報量が増えるため、必要な場合に限り利用するとよいでしょう。</p>



<figure class="wp-block-embed is-type-wp-embed is-provider-techgrowup wp-block-embed-techgrowup"><div class="wp-block-embed__wrapper">

<a target="_self" href="https://techgrowup.net/prompt-engineering-chain-of-thought" title="Chain of ThoughtでAIの思考を可視化！途中経過もわかるプロンプト設計の潮流" class="blogcard-wrap internal-blogcard-wrap a-wrap cf"><div class="blogcard internal-blogcard ib-left cf"><div class="blogcard-label internal-blogcard-label"><span class="fa"></span></div><figure class="blogcard-thumbnail internal-blogcard-thumbnail"><img decoding="async" width="160" height="90" src="https://techgrowup.net/wp-content/uploads/2025/01/prompt-engineering-chain-of-thought-160x90.webp" class="blogcard-thumb-image internal-blogcard-thumb-image wp-post-image" alt="" srcset="https://techgrowup.net/wp-content/uploads/2025/01/prompt-engineering-chain-of-thought-160x90.webp 160w, https://techgrowup.net/wp-content/uploads/2025/01/prompt-engineering-chain-of-thought-1024x585.webp 1024w, https://techgrowup.net/wp-content/uploads/2025/01/prompt-engineering-chain-of-thought-768x439.webp 768w, https://techgrowup.net/wp-content/uploads/2025/01/prompt-engineering-chain-of-thought-120x68.webp 120w, https://techgrowup.net/wp-content/uploads/2025/01/prompt-engineering-chain-of-thought-320x180.webp 320w, https://techgrowup.net/wp-content/uploads/2025/01/prompt-engineering-chain-of-thought-376x212.webp 376w, https://techgrowup.net/wp-content/uploads/2025/01/prompt-engineering-chain-of-thought.webp 1200w" sizes="(max-width: 160px) 100vw, 160px" /></figure><div class="blogcard-content internal-blogcard-content"><div class="blogcard-title internal-blogcard-title">Chain of ThoughtでAIの思考を可視化！途中経過もわかるプロンプト設計の潮流</div><div class="blogcard-snippet internal-blogcard-snippet">大規模言語モデルが計算や推論の「途中経過」を出力することで、回答の正確性や理解度を高める手法が「Chain of Thought」です。本記事では、その仕組みやメリット・デメリット、具体的な活用例やベストプラクティスを分かりやすく解説します。</div></div><div class="blogcard-footer internal-blogcard-footer cf"><div class="blogcard-site internal-blogcard-site"><div class="blogcard-favicon internal-blogcard-favicon"><img decoding="async" src="https://www.google.com/s2/favicons?domain=https://techgrowup.net" alt="" class="blogcard-favicon-image internal-blogcard-favicon-image" width="16" height="16" /></div><div class="blogcard-domain internal-blogcard-domain">techgrowup.net</div></div><div class="blogcard-date internal-blogcard-date"><div class="blogcard-post-date internal-blogcard-post-date">2025.01.23</div></div></div></div></a>
</div></figure>



<h3 class="wp-block-heading">Iterative Prompting（反復指示）で精度アップ</h3>



<p>AIが最初に出したコードが不完全であっても、「ここを修正」「もう少し高パフォーマンスに」「テストコードも追加」と再度指示すれば、より完成度の高いバージョンを生成してくれます。<strong>段階的にブラッシュアップ</strong>するアプローチが特に複雑なプロジェクトでは有効です。</p>



<h3 class="wp-block-heading">人間の審査（Human in the Loop）</h3>



<p>最終的にコードをリリースする前に、必ず人間が品質チェックやテストを実施するプロセスを入れるのが理想です。<strong>AIは推論のエラーやバイアスを完全には回避できない</strong>ため、リリース直前に専門家の目でレビューを行うことで、トラブルを大幅に減らせます。</p>



<h2 class="wp-block-heading">今後の展望とまとめ</h2>



<p>AIを使ったコーディングは、すでに多くの現場で採用が進んでいますが、これからは<strong>マルチモーダルAI</strong>が登場し、画像や音声との連動による新たな開発手法も実現するかもしれません。開発者がコードを書く時間を短縮し、ビジネスロジックやクリエイティブな部分に注力できるというメリットは計り知れません。しかし、セキュリティ対策やライセンス問題など、人間がコントロールすべき領域も依然として多く存在します。</p>



<p>まとめると、<strong>AIコーディングの最大の強みは「短時間で高品質のコード案を得られる」点にあります。</strong> 使いこなすためにはプロンプトエンジニアリングのスキルが必須ですが、慣れてくればリファクタリング、テスト生成、ドキュメント化など幅広い作業を効率化できるでしょう。初学者にとっても、学習コストを下げるサポートツールとして大きな価値があります。今後、テック業界のみならずあらゆる産業分野でAIがコーディング支援の姿勢を深めていく中、私たちは「どのようにAIと協力し、責任をもって開発を行うか」を常に意識していくことが大切です。</p>
]]></content:encoded>
					
					<wfw:commentRss>https://techgrowup.net/prompt-engineering-coding/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
	</channel>
</rss>

<!--
Performance optimized by W3 Total Cache. Learn more: https://www.boldgrid.com/w3-total-cache/?utm_source=w3tc&utm_medium=footer_comment&utm_campaign=free_plugin

Disk: Enhanced  を使用したページ キャッシュ

Served from: techgrowup.net @ 2026-04-30 11:54:16 by W3 Total Cache
-->