カテゴリ: C# 更新日: 2026/03/20

C#でJSON・XML操作を高速化!初心者向けパフォーマンス改善完全ガイド

C#のJSON・XML操作のパフォーマンス改善ポイント
C#のJSON・XML操作のパフォーマンス改善ポイント

先生と生徒の会話形式で理解しよう

生徒

「C#でデータを保存したり読み込んだりするとき、動作が重くなることがあるって聞いたのですが、本当ですか?」

先生

「はい、特にJSONやXMLという形式のデータを大量に扱うときは、やり方次第でパソコンの動きが遅くなってしまうことがあります。」

生徒

「初心者でも、プログラムを速く動かすコツは覚えられますか?」

先生

「もちろんです!まずは基本を押さえて、効率の良い書き方を学んでいきましょう。」

1. JSONとXMLの基本を知ろう

1. JSONとXMLの基本を知ろう
1. JSONとXMLの基本を知ろう

プログラミングの世界では、情報を整理して保存するために特定の形式を使います。その代表的なものがJSON(ジェイソン)XML(エックスエムエル)です。これらは、設定ファイルやインターネットを通じたデータのやり取りで非常によく使われます。

JSONは、JavaScript Object Notationの略で、人間が見ても分かりやすく、書きやすいのが特徴です。最近の主流はこのJSONです。一方でXMLは、Extensible Markup Languageの略で、タグを使ってデータを囲む形式です。少し古いシステムや、複雑な構造のデータを扱う際に使われます。

これらのデータを扱うとき、プログラムは「シリアル化(シリアライズ)」と「逆シリアル化(デシリアライズ)」という作業を行います。シリアル化とは、プログラム内のデータを保存できる文字の形に変換すること、逆シリアル化とはその逆で、文字からプログラムが使えるデータに戻すことを指します。この変換作業に時間がかかるため、工夫が必要になるのです。

2. パフォーマンスが悪くなる原因とは?

2. パフォーマンスが悪くなる原因とは?
2. パフォーマンスが悪くなる原因とは?

なぜデータの操作でパソコンが重くなるのでしょうか。大きな原因は「メモリーの使いすぎ」と「無駄な計算」です。パソコンには作業机のような役割を果たすメモリーという場所がありますが、大きなデータを一度に全部広げようとすると、机がいっぱいになって動きが止まってしまいます。

特に初心者の方がやってしまいがちなのが、小さなデータを何度も細かく保存したり、逆に巨大なデータを一つの塊として無理やり読み込もうとしたりすることです。また、古い道具(ライブラリ)を使っていることも原因の一つです。C#には標準で高速な道具が用意されているので、それを選ぶだけでも劇的に速くなります。

3. System.Text.Jsonを活用しよう

3. System.Text.Jsonを活用しよう
3. System.Text.Jsonを活用しよう

以前のC#では、Newtonsoft.Jsonという外部の道具が人気でしたが、現在はマイクロソフトが公式に提供しているSystem.Text.Jsonというライブラリを使うのが最も速いとされています。これは最初からC#に含まれているため、追加の準備も不要で、しかもメモリーを節約するように設計されています。

まずは、基本的なJSONの書き出しを見てみましょう。この方法を使うだけで、従来の古い方法よりも数倍速く動くことがあります。


using System.Text.Json;

// 保存したいデータ
var user = new { Name = "田中太郎", Age = 25 };

// データをJSONという形式の文字に変える(シリアル化)
string jsonString = JsonSerializer.Serialize(user);

Console.WriteLine(jsonString);

{"Name":"田中太郎","Age":25}

4. ストリームを使ってメモリーを節約する

4. ストリームを使ってメモリーを節約する
4. ストリームを使ってメモリーを節約する

大きなデータを扱うときの最強の武器がストリーム(Stream)です。ストリームとは、データを「川の流れ」のように少しずつ流して処理する仕組みのことです。バケツで大きなプールの水を一度に運ぼうとすると大変ですが、ホースを使って少しずつ流せば、小さな力で済みますよね。それと同じ考え方です。

文字列として一度変数に溜め込むのではなく、ファイルへ直接流し込むことで、大きなファイルでもメモリーをほとんど消費せずに処理できます。これはXMLでもJSONでも共通して使える非常に重要なテクニックです。


using System.IO;
using System.Text.Json;

// 非常に大きなリストを想定
var largeData = new List<int> { 1, 2, 3, 4, 5 }; 

// ファイルを作成して、そこに直接データを流し込む
using (FileStream fs = File.Create("data.json"))
{
    JsonSerializer.Serialize(fs, largeData);
}
Console.WriteLine("ファイルへの書き込みが完了しました。");

5. XML操作での高速化テクニック

5. XML操作での高速化テクニック
5. XML操作での高速化テクニック

XMLはJSONに比べて文字数が多くなりがちで、処理も重くなりがちです。XMLを扱う際に「XmlDocument」というクラスを使う方法がありますが、これはデータをすべてメモリーに乗せるため、大きなファイルには向きません。代わりにおすすめなのがXmlReaderXmlWriterです。

これらはストリームと同じように、上から順番に一行ずつ読み飛ばしたり書き込んだりするため、どんなに巨大なXMLファイルでもサクサク動作します。ただし、書き方が少し複雑になるので、まずは「必要な部分だけを狙い撃ちして読む」という意識を持つだけでも効果があります。


using System.Xml;
using System.Text;

// XMLを効率よく作成する設定
XmlWriterSettings settings = new XmlWriterSettings { Indent = true };

using (XmlWriter writer = XmlWriter.Create("sample.xml", settings))
{
    writer.WriteStartElement("Root");
    writer.WriteElementString("Item", "パソコン");
    writer.WriteElementString("Price", "100000");
    writer.WriteEndElement();
}
Console.WriteLine("効率的な方法でXMLを作成しました。");

<Root>
  <Item>パソコン</Item>
  <Price>100000</Price>
</Root>

6. 非同期処理でユーザーを待たせない

6. 非同期処理でユーザーを待たせない
6. 非同期処理でユーザーを待たせない

データの読み書きはどうしても時間がかかります。その間、アプリの画面が固まって操作できなくなると、ユーザーは「壊れたかな?」と不安になってしまいます。これを防ぐのが非同期処理(Async/Await)という技術です。これは、重い作業を「裏側」でやっておいて、その間も別の作業ができるようにする魔法のような仕組みです。

C#の最新のJSON操作機能には、この非同期処理が標準で組み込まれています。これを使うことで、アプリ全体の体感速度が大きく向上します。パソコンが固まるストレスをゼロにしましょう。


using System.IO;
using System.Text.Json;
using System.Threading.Tasks;

public async Task SaveDataAsync()
{
    var data = new { Message = "こんにちは!" };
    
    // 非同期(Async)でファイルに保存する
    using (FileStream fs = File.Create("async_data.json"))
    {
        await JsonSerializer.SerializeAsync(fs, data);
    }
    Console.WriteLine("裏側で保存が終わりました。");
}

7. 文字列の連結を避ける工夫

7. 文字列の連結を避ける工夫
7. 文字列の連結を避ける工夫

初心者がよくやってしまうのが、JSONやXMLの文字を「+」記号でつなげて作ろうとすることです。例えば、「"{ " + "name" + ":" + "tanaka" + " }"」のように書く方法です。実はこれ、プログラム内部では非常に効率が悪く、つなげるたびに新しい文字の塊をメモリーに作ってしまいます。何万回も繰り返すと、それだけでパソコンが悲鳴を上げます。

基本的には専用のライブラリ(System.Text.Jsonなど)に任せるべきですが、どうしても自分で文字を組み立てる必要がある場合は、StringBuilderというクラスを使いましょう。これは文字の継ぎ足しが得意な道具で、無駄なメモリー消費を抑えてくれます。

8. 無駄なプロパティを読み込まない

8. 無駄なプロパティを読み込まない
8. 無駄なプロパティを読み込まない

読み込むデータが100項目あっても、実際にアプリで使うのが「名前」と「年齢」の2つだけなら、残りの98項目を無視する設定にしましょう。これを部分的なデシリアライズと呼びます。全部を丁寧に解析するのをやめるだけで、処理時間は大幅に短縮されます。

また、JSONの項目名がプログラムの変数名と少し違っていても、無理に文字を書き換える必要はありません。属性(Attribute)という印をつけることで、スムーズに関連付けが可能です。これにより、名前の変換にかかる無駄な計算を省くことができます。こうした小さな積み重ねが、プロ級の高速なプログラムを作る鍵となります。

9. コンパイラの力を借りるソース生成

9. コンパイラの力を借りるソース生成
9. コンパイラの力を借りるソース生成

最新のC#ではソースジェネレーターという画期的な機能が登場しました。通常、JSONの変換はプログラムを動かしている最中に「どうやって変換しようかな?」と考えながら行われます。しかしソース生成を使うと、プログラムを作る段階であらかじめ変換の手順を確定させておけます。動いている最中に考える必要がなくなるため、驚異的なスピードを実現できます。

これは少し高度な設定が必要ですが、スマホアプリや動作が制限された環境では非常に有効な手段です。パフォーマンスを極限まで高めたいときは、このキーワードを思い出してください。最初は難しく感じるかもしれませんが、「事前に準備しておくことで速くなる」という理屈さえ分かっていれば大丈夫です。

カテゴリの一覧へ
新着記事
New1
COBOL
JCLの条件実行(CONDパラメータ)の基礎をやさしく解説!初心者でも分かる実行制御の仕組み
New2
C#
C#のインストール方法まとめ!Windows・Mac・Linux別にステップ解説
New3
C#
C#でJSON・XML操作をマスター!初心者向けデータ保存・読み込み完全ガイド
New4
C#
C#のsealedクラス・sealedメソッドとは?継承制限の方法を解説
人気記事
No.1
Java&Spring記事人気No1
COBOL
COBOLのCOPY句の使い方を完全ガイド!初心者でもわかる共通部品の再利用方法
No.2
Java&Spring記事人気No2
C#
C#のLINQでOrderByを使った並び替えを完全ガイド!初心者でもわかるソート方法
No.3
Java&Spring記事人気No3
C#
C#のpartialクラスとは?初心者でも理解できるクラス分割の基本
No.4
Java&Spring記事人気No4
COBOL
COBOLのIF文と条件分岐を徹底解説!複雑化を防ぐコーディング規約
No.5
Java&Spring記事人気No5
COBOL
COBOLの数値データ型「PIC 9」の使い方と注意点をやさしく解説!
No.6
Java&Spring記事人気No6
COBOL
COBOLのコンパイラと開発環境を徹底解説!初心者にもわかりやすい入門ガイド
No.7
Java&Spring記事人気No7
C#
C#のstaticクラスとstaticメソッドの基本と使い方をやさしく解説!
No.8
Java&Spring記事人気No8
C#
C#のLINQでFirstとFirstOrDefaultの違いと使い方を完全解説!初心者向けガイド