intTypePromotion=1
zunia.vn Tuyển sinh 2024 dành cho Gen-Z zunia.vn zunia.vn
ADSENSE

Chương 8: Files và Streams

Chia sẻ: | Ngày: | Loại File: PPT | Số trang:105

150
lượt xem
9
download
 
  Download Vui lòng tải xuống để xem tài liệu đầy đủ

Cung cấp khả năng khởi tạo, đọc, viết và khả năng cập nhật File. Hiểu được luồng thông tin (Stream) trong C#. Có thể sử dụng lớp File và thư mục. Có thể sử dụng được các lớp FileStream và lớp BinaryFormatter để đọc và viết các đối tượng vào trong các File. Nắm vững việc xử lý các File truy xuất tuần tự và File truy xuất ngẫu nhiên.

Chủ đề:
Lưu

Nội dung Text: Chương 8: Files và Streams

  1. Chương 8 . Files và Streams  Outline 8.1. Files và Streams 8.2. Lớp File và lớp Directory 8.3. File truy xuất tuần tự 8.4. File truy xuất ngẫu nhiên
  2. 8.1. Files và Streams Mục đích của nghiên cứu phần này:  Cung cấp khả năng khởi tạo, đọc, viết và khả năng cập nhật File.  Hiểu được luồng thông tin (Stream) trong C#.  Có thể sử dụng lớp File và thư mục.  Có thể sử dụng được các lớp FileStream và lớp BinaryFormatter để đọc và viết các đối tượng vào trong các File.  Nắm vững việc xử lý các File truy xuất tuần tự và File truy xu ất ngẫu nhiên.
  3. Files ?  File được sử dụng như bộ nhớ ngoài để lưu trữ với số lượng lớn dữ liệu,và có thể giữ lại dữ liệu thậm chí sau khi ch ương trình k ết thúc.  Mỗi File kết thúc với một kí tự đánh dấu kết thúc File ho ặc m ột số Byte xác định được ghi trong hệ thống lưu trữ qu ản lý cấu trúc dữ liệu. Phần tử cuối  Dấu hiệu  Phần tử đầu  (thứ n) của  kết thúc  tiên của File File File
  4. Cấu tạo của File trong lưu trữ
  5. Stream ?  Stream (luồng) là luồng của thông tin, ch ứa thông tin s ẽ đ ược chuyển qua, còn tập tin thì để lưu trữ thông tin.
  6. 8.1. Files và Streams Khi một File được mở ra:  C# sẽ tạo một đối tượng.  Nối luồng thông tin với đối tượng này. Có 3 đối tượng stream:  Console.In : trả về một đối tượng stream vào chuẩn.  Console.Out: trả về một đối tượng stream ra chuẩn.  Console.Error: trả về một đối tượng stream thông báo lỗi chuẩn.
  7. 8.1. Files và Streams BinaryFormatter sử dụng 2 phương thức Serialize và Deserialize để viết và đọc đối tượng từ trong luồng:  Serialize:chuyển đổi một đối tượng sang một định dạng, và có thể được viết vào File mà không mất dữ liệu.  Deserialize: đọc dữ liệu đã định dạng từ một File và chuyển nó về dạng ban đầu. System.IO.Stream cho phép thể hiện dưới dạng bit của stream:  FileStream: đọc và viết từ File truy xuất trình tự và ngẫu nhiên:  MemoryStream: chuyển đổi dữ liệu trực tiếp với bộ nhớ.  BufferedStream: sử dụng bộ nhớ đệm để chuyển dữ liệu.
  8. 8.2. Lớp File và lớp Directory  Thông tin được lưu trữ trên các files  Files được tổ chức thành các thư mục  Lớp Directory dùng để thao tác các thư mục  Lớp File dùng để thao tác trên các files  Chỉ có phương thức tĩnh,không thể khởi tạo đối tượng File
  9. 8.2. Lớp File và lớp Directory static M etho d   De sc rip tio n  AppendText Trả lại một StreamWriter nối tiếp vào file đã tồn tại hoặc tạo một file nếu nó chưa có . Copy Copy một file vào file mớ i. Create Tạo một file và trả l ại FileStream tươ ng ứ ng của nó. CreateText Tạo một file text và trả lại StreamWriter tươ ng ứ ng của nó . Delete Xoá một file. GetCreationTime Trả lại đối tượ ng DateTime tượ ng trư ng cho thời gian mà file đượ c tạo ra . GetLastAccessTime Trả lại đối tượ ng DateTime đại diện cho thời gian file đượ c truy cập lần cuối GetLastWriteTime Trả lại đối tượ ng DateTime đại diện cho thời gian file đượ c thay đổi lần cuối Move Di chuyển một file đến m ột vị trí xác định nào đó Open Trả lại FileStream kết hợp vớ i một file xác định và trang bị cho nó quyền đọc/ghi . OpenRead Trả lại read-only FileStream gắn với một file nào đó xác định. OpenText Trả lại một StreamReader gắn vớ i một file xác định. OpenWrite Trả lại read/write FileStream gắn với một file xác định. Hình 8.2  c á c  p hươ ng  thức  c ủa  lớp  File . 
  10. 8.2. Lớp File và lớp Directory
  11. 1 // FileTest.cs 2 // Using classes File and Directory. 3 4 using System; FileTest.cs 5 using System.Drawing; 6 using System.Collections; 7 using System.ComponentModel; 8 using System.Windows.Forms; 9 using System.Data; 10 using System.IO; 11 12 // displays contents of files and directories 13 public class FileTestForm : System.Windows.Forms.Form 14 { 15 private System.Windows.Forms.Label directionsLabel; 16 17 private System.Windows.Forms.TextBox outputTextBox; Textbox để nhập 18 private System.Windows.Forms.TextBox inputTextBox; đường dẫn file và thư 19 mục 20 private System.ComponentModel.Container components = null; 21 22 [STAThread] 23 static void Main() 24 { 25 Application.Run( new FileTestForm() ); 26 } 27 28 // Visual Studio .NET generated code Kiểm soát việc 29 30 // invoked when user presses key gõ phím enter 31 private void inputTextBox_KeyDown( 32 object sender, System.Windows.Forms.KeyEventArgs e ) 33 {
  12. 34 // determine whether user pressed Enter key 35 if ( e.KeyCode == Keys.Enter ) Kiểm tra nếu 36 { phím được nhấn 37 string fileName; // name of file or directory là enter FileTest.cs 38 39 // get user-specified file or directory 40 fileName = inputTextBox.Text; Đặt filename do 41 người dùng nhập 42 // determine whether fileName is a file 43 if ( File.Exists( fileName ) ) 44 { Kiểm tra sự tồn 45 // get file's creation date, tại file fileName 46 // modification date, etc. 47 outputTextBox.Text = GetInformation( fileName ); Nếu file tồn tại,lấy 48 và đưa ra thông tin 49 // display file contents through StreamReader 50 try 51 { 52 // obtain reader and file contents 53 StreamReader stream = new StreamReader( fileName ); 54 outputTextBox.Text += stream.ReadToEnd(); Tạo StreamReader 55 } để đọc text từ file 56 // handle exception if StreamReader is unavailable 57 catch( IOException ) Gọi method 58 { ReadToEnd 59 MessageBox.Show( "File Error", "File Error", 60 MessageBoxButtons.OK, MessageBoxIcon.Error ); 61 } 62 } 63 64 // determine whether fileName is a directory Kiểm tra sự tồn tại 65 else if ( Directory.Exists( fileName ) ) của thư mục 66 { 67 // array for directories fileName 68 string[] directoryList;
  13. 69 70 // get directory's creation date, 71 // modification date, etc. 72 outputTextBox.Text = GetInformation( fileName ); Nếu tồn tại,lấy và đưa FileTest.cs 73 74 // obtain file/directory list of specified directory ra thông tin thư mục 75 directoryList = Directory.GetDirectories( fileName ); 76 Lấy các thư 77 outputTextBox.Text += 78 "\r\n\r\nDirectory contents:\r\n"; mục con 79 Đưa ra các thư mục 80 // output directoryList contents con 81 for ( int i = 0; i < directoryList.Length; i++ ) 82 outputTextBox.Text += directoryList[ i ] + "\r\n"; 83 } 84 else 85 { 86 // notify user that neither file nor directory exists 87 MessageBox.Show( inputTextBox.Text + Báo lỗi nếu không tồn 88 " does not exist", "File Error", 89 MessageBoxButtons.OK, MessageBoxIcon.Error ); tại file có tên được 90 } nhập 91 } // end if 92 93 } // end method inputTextBox_KeyDown 94 95 // get information on file or directory 96 private string GetInformation( string fileName ) 97 { Thông báo sự tồn 98 // output that file or directory exists tại của file với 99 string information = fileName + " exists\r\n\r\n"; 100 người nhập 101 // output when file or directory was created Lấy thông tin về 102 information += "Created: " + việc tạo file 103 File.GetCreationTime( fileName ) + "\r\n";
  14. 104 FileTest.cs 105 // output when file or directory was last modified 106 information += "Last modified: " + Lần cuối cùng  107 108 File.GetLastWriteTime( fileName ) + "\r\n"; thay đổi file 109 // output when file or directory was last accessed 110 information += "Last accessed: " + 111 File.GetLastAccessTime( fileName ) + "\r\n" + "\r\n"; 112 113 return information; Lần cuối truy cập file 114 115 } // end method GetInformation Trả lại thông tin file 116 117 } // end class FileTestForm
  15. FileTest.cs Program Output    
  16. 8.3. File truy xuất tuần tự  C# không có áp đặt nào lên File. Do vậy,ta ph ải xây d ựng đ ịnh d ạng dữ liệu cho File (sử dụng các bản ghi).  Để lấy dữ liệu từ File này,chương trình thường bắt đầu từ điểm đầu tiên (0),tìm và đọc tuần tự cho đến khi dữ liệu được tìm thấy.  File dạng này khả năng đáp ứng không cao.  Lớp BinaryFormatter kết hợp với một đối tượng Stream để thực hiện ở đầu vào/ra của đối tượng.
  17. Các không gian tên 8.3.1 Tạo File truy xuất tuần tựcần thiết Tạo một đối tượng của luồng BinaryFormatter Luồng cần thiết choMở một File đã tồn việc tạo File tại hoặc tạo File mới Ghi dữ liệu Record là một vào File Struct nào đó cần ghi vào File Phương thức để ghi dữ liệu vào File Tạo khả năng truy Nhớ là phải cập File(viết vào đóng File vào File)
  18. 1 // BankUI.cs 2 // A reusable windows form for the examples in this chapter. 3 4 using System; BankUI.cs 5 using System.Drawing; 6 using System.Collections; 7 using System.ComponentModel; 8 using System.Windows.Forms; 9 using System.Data; 10 11 public class BankUIForm : System.Windows.Forms.Form 12 { 13 private System.ComponentModel.Container components = null; 14 15 public System.Windows.Forms.Label accountLabel; 16 public System.Windows.Forms.TextBox accountTextBox; 17 18 public System.Windows.Forms.Label firstNameLabel; Textboxes 19 public System.Windows.Forms.TextBox firstNameTextBox; 20 21 public System.Windows.Forms.Label lastNameLabel; Labels 22 public System.Windows.Forms.TextBox lastNameTextBox; 23 24 public System.Windows.Forms.Label balanceLabel; 25 public System.Windows.Forms.TextBox balanceTextBox; 26 27 // number of TextBoxes on Form' 28 protected int TextBoxCount = 4; 29
  19. 30 // enumeration constants specify TextBox indices 31 public enum TextBoxIndices 32 { 33 ACCOUNT, BankUI.cs 34 FIRST, 35 LAST, 36 BALANCE 37 38 } // end enum 39 40 [STAThread] 41 static void Main() 42 { 43 Application.Run( new BankUIForm() ); 44 } 45 46 // Visual Studio .NET generated code 47 48 // clear all TextBoxes Phương thức để xoá 49 public void ClearTextBoxes() 50 { textboxes 51 // iterate through every Control on form 52 for ( int i = 0; i < Controls.Count; i++ ) 53 { 54 Control myControl = Controls[ i ]; // get control 55 56 // determine whether Control is TextBox 57 if ( myControl is TextBox ) 58 { 59 // clear Text property (set to empty strng) 60 myControl.Text = ""; 61 } 62 } 63 64 } // end method ClearTextBoxes
  20. 65 66 // set text box values to string array values 67 public void SetTextBoxValues( string[] values ) Phương thức để 68 { thiết lập giá trị củaBankUI.cs 69 textboxes // determine whether string array has correct length 70 if ( values.Length != TextBoxCount ) 71 { 72 // throw exception if not correct length 73 throw( new ArgumentException( "There must be " + 74 (TextBoxCount + 1) + " strings in the array" ) ); 75 } 76 77 // set array values if array has correct length 78 else 79 { 80 // set array values to text box values 81 accountTextBox.Text = 82 values[ ( int )TextBoxIndices.ACCOUNT ]; 83 firstNameTextBox.Text = 84 values[ ( int )TextBoxIndices.FIRST ]; 85 lastNameTextBox.Text = 86 values[ ( int )TextBoxIndices.LAST ]; 87 balanceTextBox.Text = 88 values[ ( int )TextBoxIndices.BALANCE ]; 89 } 90 91 } // end method SetTextBoxValues 92 Phương thức để 93 // return text box values as string array 94 public string[] GetTextBoxValues() lấy giá trị của 95 { textboxes 96 string[] values = new string[ TextBoxCount ]; 97
ADSENSE

CÓ THỂ BẠN MUỐN DOWNLOAD

 

Đồng bộ tài khoản
2=>2