C言語関数:unlink





C言語のページでは、次の内容を解説しております。
C言語の入門講座  C言語の文法を中心に、基本的な関数などの解説をしています。
C言語ケーススタディ  C言語での実践的なプログラミングについて解説をしています。
C言語の関数リファレンス  C言語で用意されている関数を解説しています。
C言語で3次元動画プログラム  C言語で3次元タートルグラフィックを使用した3次元の動画プログラムの作成例です。
C言語の検定試験  C言語の文法に関する検定試験を実施することができます。
C言語でゲーム作成  C言語を使用したゲームの作り方を解説したページも用意しております。



2014年10月より個人の方を対象に、Study C無料提供を開始しました。
C言語を勉強中の方は、学習・教育に最適なC言語インタープリタのStudy Cを使ってみてください(個人の方は無料です)。
大学・高専・高校などの教育機関での採用実績も多数あるロングセラー商品Study Cが、個人向けに無料提供を始めました。
インタープリタの手軽さに加え、ゲームや3Dタートルグラフィックで楽しく勉強したりと、C言語の学習を協力にサポートします。
ブロック崩しゲーム 3Dツリー クリスマスツリー
また、このようなボタンの用意されているページでは、掲載しているプログラムをStudy Cに直接ロードし実行したりすることができます。
Study Cにロードする Study Cにロードし編集する Study Cにロードし実行する
Study C無料利用についての詳細は、このページを参照してください。




■unlink
ファイルの削除

【分類】
ファイル操作関数

【書式】
int unlink(const char *filename);

【パラメータの型と説明】

パラメータ説明
const char *filenameファイル名(パス名)

【機能説明】
filenameで指定されたファイルを削除し、削除に成功したときは0を、失敗したときは-1を返します。
remove関数とunlink関数は同じ機能の関数です。
読み込み専用属性のついているファイルは削除できません。そのようなファイルを削除したいときは、chmod関数で読み込み専用属性を解除してからremove関数を使用します。

UNIX(現在ではLinuxも)では、removeとunlinkの別々のシステムコールが存在しています。 この関数は、unlinkシステムコールを呼び出すための関数でした。 MS-DOSではlink、unlink機能が無かったため、この頃のCコンパイラはunlink()関数もremove()関数と同じファイル削除関数として提供するのが一般的でした。 Windows用のコンパイラも、互換性のために同じファイル削除関数として提供されています。 unlinkシステムコールは、シンボリックリンクまたはハードリンクを削除(解除)するためのものです。 このシステムコールは純粋にファイルを削除する機能(remove)とは異なります。 特に理由が無ければ、一般的なファイル削除の用途にはremove()関数を使用しておいた方がよいと思います(移植性を考慮して)。

Study Cを使用している場合は、下記のようにコマンドラインから実行(exprコマンドを使用)して動作を確認することができます。

C:\StudyC\MyProg>echo 削除用ファイルを作成 >test.txt

C:\StudyC\MyProg>type test.txt
削除用ファイルを作成

C:\StudyC\MyProg>expr unlink("test.ttt")
<int>-1 0xffffffff

C:\StudyC\MyProg>expr unlink("test.txt")
<int>0 0x0

C:\StudyC\MyProg>type test.txt
ファイルが見つかりません.

※↑カーソルキーを押すと入力したコマンドが呼び出されるので文字を変更して試してみてください。
1番目はechoコマンドで削除するファイルを作成しています。
2番目はtypeコマンドで削除するファイルを確認しています。
3番目はunlink()関数でファイルを削除しようとしていますが、ファイル名が"test.ttt"のためエラーとなり-1を返します。
4番目はunlink()関数で"test.txt"ファイルを削除しています(削除に成功したので0を返します)。
5番目はtypeコマンドで削除されたファイルの内容を表示しようとしているのでエラーとなります。

通常のコンパイラを使用する場合の使用例は下記になります(もちろんStudy CでもOKです)。 あらかじめ、"test.txt"というファイルを作成しておきます。

#include <stdio.h>

main()
{
        printf("%d\n", unlink("test.ttt"));
        printf("%d\n", unlink("test.txt"));
}

実行結果は以下になります。

-1
0

【参照関数】
chmod
remove