カテゴリ: Swift 更新日: 2026/01/11

Swift NSErrorブリッジング|Objective-Cエラーとの連携を徹底解説

Swift NSErrorブリッジング|Objective-Cエラーとの連携
Swift NSErrorブリッジング|Objective-Cエラーとの連携

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

生徒

「Swiftでエラーを扱うときに、Objective-CのNSErrorというものが出てきました。これは何なんですか?」

先生

「NSErrorはObjective-Cでよく使われていたエラー表現です。Swiftでもブリッジという仕組みを通して、NSErrorとSwiftのエラーをやり取りできるんです。」

生徒

「SwiftのError型とNSErrorは別物ですよね?どうやって一緒に使うんですか?」

先生

「その通りです。SwiftではErrorプロトコルを使いますが、内部的にNSErrorへ変換(ブリッジ)できるようになっています。具体例を見ながら学んでいきましょう。」

1. NSErrorとは?

1. NSErrorとは?
1. NSErrorとは?

NSErrorはAppleが提供するObjective-Cのエラー表現クラスです。エラーの種類やエラーが起きた領域をわかりやすく整理するために作られており、ドメイン(domain)コード(code)ユーザー情報(userInfo)といった情報を持ちます。

例えば、ファイルが存在しないときやネットワークに接続できないときなど、NSErrorは詳細な原因を開発者に伝える役割を果たします。

2. SwiftのError型との違い

2. SwiftのError型との違い
2. SwiftのError型との違い

SwiftではエラーをErrorプロトコルに準拠した型で表現します。これは列挙型(enum)で作られることが多く、コードが読みやすく安全です。一方で、古いObjective-CのAPIやフレームワークはNSErrorを返すため、Swiftとの橋渡し(ブリッジング)が必要になります。

3. SwiftからObjective-CのNSErrorを扱う方法

3. SwiftからObjective-CのNSErrorを扱う方法
3. SwiftからObjective-CのNSErrorを扱う方法

SwiftでObjective-Cのメソッドを呼び出すとき、エラーがNSErrorPointer(NSErrorの参照)として渡されます。これにより、Swift側ではdo-catch構文を使って自然に扱えるようになります。


import Foundation

enum MyError: Error {
    case somethingWentWrong
}

func throwSwiftError() throws {
    throw MyError.somethingWentWrong
}

do {
    try throwSwiftError()
} catch let error as NSError {
    print("NSErrorにブリッジ: ドメイン=\(error.domain), コード=\(error.code)")
}

NSErrorにブリッジ: ドメイン=YourApp.MyError, コード=1

このように、Swiftのエラーは自動的にNSErrorへ変換されるため、Objective-Cの世界と連携できます。

4. NSErrorのプロパティ

4. NSErrorのプロパティ
4. NSErrorのプロパティ

NSErrorには主に次のプロパティがあります。

  • domain:エラーの分類を表す文字列。例えば「NSURLErrorDomain」など。
  • code:エラーの数値コード。原因を識別するために使います。
  • userInfo:追加情報を格納する辞書。エラーメッセージや回復方法などが含まれることもあります。

これらを利用すれば、ユーザーにエラー内容をわかりやすく伝えたり、デバッグの際に役立ちます。

5. Objective-CのNSErrorをSwiftで使う

5. Objective-CのNSErrorをSwiftで使う
5. Objective-CのNSErrorをSwiftで使う

例えば、ファイルの読み込みメソッドはObjective-C由来のNSErrorを利用しています。Swift側ではtry構文を使って簡潔に扱えます。


let fileManager = FileManager.default
let path = "/path/to/file.txt"

do {
    let contents = try String(contentsOfFile: path, encoding: .utf8)
    print(contents)
} catch let error as NSError {
    print("エラー: \(error.domain) - \(error.code)")
}

このようにSwiftのdo-catchで書くと、内部的にはNSErrorをうまく橋渡ししてくれる仕組みになっています。

6. NSErrorを自分で作成する

6. NSErrorを自分で作成する
6. NSErrorを自分で作成する

場合によっては、開発者自身がNSErrorを作って他の処理に渡すこともあります。


let error = NSError(
    domain: "com.example.app",
    code: 1001,
    userInfo: [NSLocalizedDescriptionKey: "予期しないエラーが発生しました"]
)
print(error.localizedDescription)

予期しないエラーが発生しました

このように作成したNSErrorをObjective-Cのライブラリに渡すことで、互換性を保ちながらエラーハンドリングができます。

Swiftを基礎から実践レベルまで学びたい人や、 iOSアプリ開発を本格的に始めたい人には、 定番の入門+実践書がこちらです。

Swift実践入門をAmazonで見る

※ Amazon広告リンク

7. NSErrorブリッジングの活用場面

7. NSErrorブリッジングの活用場面
7. NSErrorブリッジングの活用場面

NSErrorブリッジングは、特に以下のような場面で役立ちます。

  • 古いObjective-CライブラリをSwiftから利用するとき
  • iOS SDKの一部APIでNSErrorが使われているとき
  • SwiftとObjective-Cが混在するプロジェクトで統一的にエラーを扱いたいとき

初心者にとってはやや複雑に感じるかもしれませんが、SwiftとObjective-Cの架け橋になる大事な仕組みです。

関連セミナーのご案内

Windowsで始めるiPhoneアプリ開発入門|Swiftの基本と仕組みを1時間で攻略

Windowsで始めるiPhoneアプリ開発入門|Swiftの基本と仕組みを1時間で攻略

「iPhoneアプリを作りたいけれど、Macを持っていないから諦めている」そんな方のための画期的な入門講座です。実は、プログラミングの本質を学ぶのに高価な機材は必要ありません。本講座では、Windowsパソコンを使用し、クラウド環境を活用してAppleの最新言語Swift(スウィフト)の基礎を最短距離でマスターします。

Windowsで実現する開発環境

【つくるもの】
ブラウザ上で動作する「スマート・計算ツール」や「データ判定プログラム」をゼロから作成します。変数の扱いや条件分岐など、iPhoneアプリの内部で動くロジックを自分の手で構築する感動を体験してください。

【開発環境】
ブラウザだけでSwiftが動くプロ仕様のオンラインエディタ(Replit等)を使用します。面倒な設定は一切不要。今あるWindows PCで、プロのエンジニアと同じコードを書き始められます。

この60分で得られる3つの理解

1. WindowsでのSwift実行環境の作り方

OSの壁を越え、クラウドを活用してスマートに学習を開始する「現代的な開発スタイル」を習得します。

2. Swiftの基本構造(変数・型・定数)

iPhoneアプリ特有のデータの扱い方や、Appleが推奨する「安全で美しいコード」の書き方を学びます。

3. アプリエンジニアとしてのロードマップ

将来的にiOSエンジニアとして副業・転職するために必要な準備や、Mac選びのポイントを伝授します。

※本講座は、将来的にiPhoneアプリ開発で収益化や転職を目指したい未経験者のためのエントリー講座です。マンツーマン形式により、Windows環境ならではの疑問にもその場でお答えし、あなたの理解度に合わせて進行します。

セミナー画像

Windowsで始めるiPhoneアプリ開発入門

カテゴリの一覧へ
新着記事
New1
Swift
Swiftのnilとは?Optionalとの関係や初期化について初心者向けにやさしく解説!
New2
Go言語
Go言語のinit関数の役割と使い方!プログラム起動時の初期化処理
New3
Go言語
Go言語のマップの順序保証がない理由と扱い方の工夫をやさしく解説!初心者でもわかる基本知識
New4
Kotlin
Kotlinのforループの基本!範囲・配列・コレクションの繰り返し処理
人気記事
No.1
Java&Spring記事人気No1
Kotlin
Kotlinのsettings.gradleファイルを完全解説!初心者でもわかるプロジェクト設定の基本
No.2
Java&Spring記事人気No2
Go言語
Swiftの配列(Array)の使い方を完全ガイド!初心者でもわかるデータのまとめ方
No.3
Java&Spring記事人気No3
Go言語
Go言語のSQLインジェクション対策を完全解説!初心者でも安全なデータベース操作がわかる
No.4
Java&Spring記事人気No4
Go言語
Swiftの文字列操作を完全ガイド!初心者でもわかるStringの基本
No.5
Java&Spring記事人気No5
Swift
Swiftの高階関数map・filter・reduceを完全解説!初心者でもわかる配列操作の基本
No.6
Java&Spring記事人気No6
Kotlin
KotlinのRoomで複雑なクエリを使いこなす!初心者でもわかる応用テクニック
No.7
Java&Spring記事人気No7
Go言語
Go言語のgo installコマンドの役割とインストール先の仕組みを徹底解説!
No.8
Java&Spring記事人気No8
Swift
Swift Playgroundの使い方を完全解説!初心者に最適な学習環境の始め方