CH 10
CH 10
CH 10
File-System Interface
Chapter 10: File-System Interface
File Concept
Access Methods
Directory Structure
File-System Mounting
File Sharing
Protection
Objectives
character
binary
Program (executable)
File Structure
None - sequence of words, bytes
Simple record structure
Lines
Fixed length
Variable length
Complex Structures
Formatted document
Relocatable load file
Can simulate last two with first method by
inserting appropriate control characters
Who decides:
Operating system
Program
File Attributes
Name – only information kept in human-
readable form
Identifier – unique tag (number) identifies file
within file system
Type – needed for systems that support
different types
Location – pointer to file location on device
Size – current file size
Protection – controls who can do reading,
writing, executing
Time, date, and user identification – data for
protection, security, and usage monitoring
Information about files are kept in the
File Operations
File is an abstract data type
Create
Write
Read
Reposition within file (seek)
Delete
Truncate
Open(Fi) – search the directory structure
on disk for entry Fi, and move the content
of entry to memory
Close (Fi) – move the content of entry Fi in
memory to directory structure on disk
Open Files
Several pieces of data are needed to
manage open files:
File pointer: pointer to last read/write
location, per process that has the file
open
File-open count: counter of number of
times a file is open – to allow removal of
data from open-file table when last
processes closes it
Disk location of the file: cache of data
access information
Access rights: per-process access mode
information
Open File Locking
Provided by some operating systems and
file systems
Mediates access to a file
Mandatory or advisory:
Mandatory – access is denied depending
on locks held and requested
Advisory – processes can find status of
locks and decide what to do
File Locking Example – Java API
import java.io.*;
import java.nio.channels.*;
public class LockingExample {
public static final boolean EXCLUSIVE = false;
public static final boolean SHARED = true;
public static void main(String arsg[]) throws IOException {
FileLock sharedLock = null;
FileLock exclusiveLock = null;
try {
RandomAccessFile raf = new
RandomAccessFile("file.txt", "rw");
// get the channel for the file
FileChannel ch = raf.getChannel();
// this locks the first half of the file - exclusive
exclusiveLock = ch.lock(0, raf.length()/2,
EXCLUSIVE);
/** Now modify the data . . . */
// release the lock
exclusiveLock.release();
File Locking Example –
Java API (Cont.)
Directory
Files F1 F2 F3 F4
Fn
Naming problem
Grouping problem
Two-Level Directory
Separate directory for each user
Path name
Can have the same file name for
different user
Efficient searching
No grouping capability
Tree-Structured Directories
Tree-Structured Directories (Cont.)
Efficient searching
Grouping Capability
Current directory (working
directory)
cd /spell/mail/prog
type list
Tree-Structured Directories (Cont)
Absolute or relative path name
Creating a new file is done in current directory
Delete a file
rm <file-name>
Creating a new subdirectory is done in current
directory
mkdir <dir-name>
Example: if in current directory /mail
mkdir count
mail