readlinux函數
1. linux 下read()函數讀文本文件問題
那是因為vim自動給你加上換行符了'\n',即0x0a,你可以用ls -l word.txt看一下,文件大小是不是兩個字元。
2. linux下系統調用函數read()
open系統調用
open函數的三個參數:
(1)path是已經存在的文件的路徑;
(2)oflags參數:若值為 O_RDONLY ,就以只讀方式打開文件;
若值為 O_WDONLY,就以只寫方式打開文件;
若值為 O_RDWR,就以讀寫方式打開文件;
(3)參數mode:文件的許可權,對於一個已經存在的文件,參數mode是沒有用的,通常將其省略,因此這種情況下open調用只需兩個參數。
創建新文件:
前面已經說到,當文件不存在時,open會創建一個新文件(僅能是普通文件),我們只需要用 or操作向open的 oflags參數中加入標志O_CREAT即可。這樣可以創建一個新的只讀文件,但是這沒有任何意義,因為所創建的新文件沒有任何可讀內容。因此一般需要 O_CREAT與 O_WRONLY或 O_RDWR一起使用,此時就需要mode參數了。
例如:
int fd = open("/home/LY/newfile",O_RDWR | O_CREAT,MODE_FILE)
參數mode僅在創建新文件時有效,對於一個已經存在的文件,它沒有任何作用。
關於open的flags參數:
除了以上介紹的 open標志外,open還有許多標志,具體的如下表所示:
標志
解釋
O_RDONLY
只讀方式打開
O_WRONLY
只寫方式打開
O_RDWR
讀寫方式打開
O_APPEND
每次寫都追加到文件的尾端
O_CREAT
若文件不存在則創建文件
O_DSYNC
設置同步I/O方式
O_EXCL
如果文件已存在,則出錯;必須與O_CREAT一起使用
O_NOCTTY
不將此設備作為控制終端
O_NONBLOCK
不等待命名管道或特殊文件准備好
O_RSYNC
設置同步I/O方式
O_SYNC
設置同步I/O方式
O_TRUNC
將其長度截短為0
write系統調用
write函數的三個參數:
(1)fildes: 文件描述符
(2)buf:指定寫入數據的數據緩沖區
(3)nbytes:指定寫入的位元組數
函數返回值:
成功:已寫的位元組數
-1 :出錯
0:未寫入任何數據
例子:
運行結果:
read系統調用
read函數的三個參數:
(1)fildes:文件描述符
(2)buf:指定讀入數據的數據緩沖區
(3)nbytes:指定讀入的位元組數
函數返回值:
成功:已讀的位元組數
0:未讀入任何數據
-1:出錯
例子:
運行結果:
close系統調用
通過對 close進行分析,我們會發現close並沒有做什麼實質工作,它沒有刷新任何內核緩沖區,而僅僅是使文件描述符可以重用。
3. linux 中$,read分別是什麼意思
樓上的都有理,$這個代表的是普通用戶的意思,我覺得你應該問的是shell裡面的意思,shell裡面就是提取變數。read 讀取鍵盤的輸入作為程序往下執行的開始。
4. linux 中 read 命令是什麼意思
read命令用於讀取終端輸入。
類似於c語言中的scanf()函數.
5. linux下的read函數、write函數是屬於直接I/O,為什麼函數原型的第二項就是要將數據放到輸入緩沖區內呢
函數原型第二項是一個形參,不是你理解的那樣子哦,在read的時候,這個參數相當於一個容器,用來存放你從磁碟文件中讀到的數據;在write的時候,這個參數存放我們要寫入到磁碟文件中的數據。有了這個參數我們才能在自己寫的程序中對它處理,比如列印顯示。還有read、write屬於系統調用函數,跟printf這種c庫函數不同,它們是直接跟內核打交道的沒錯。
6. linux下c語言編程read()函數的問題
返回-1的時候,要根據錯誤碼來判斷原因,請看下面的函數說明:
表頭文件 #include<unistd.h>
定義函數 ssize_t read(int fd,void * buf ,size_t count);
函數說明 read()會把參數fd 所指的文件傳送count個位元組到buf指針所指的內存中。若參數count為0,則read()不會有作用並返回0。返回值為實際讀取到的位元組數,如果返回0,表示已到達文件尾或是無可讀取的數據,此外文件讀寫位置會隨讀取到的位元組移動。
附加說明 如果順利read()會返回實際讀到的位元組數,最好能將返回值與參數count 作比較,若返回的位元組數比要求讀取的位元組數少,則有可能讀到了文件尾、從管道(pipe)或終端機讀取,或者是read()被信號中斷了讀取動作。當有錯誤發生時則返回-1,錯誤代碼存入errno中,而文件讀寫位置則無法預期。
錯誤代碼 EINTR 此調用被信號所中斷。 EAGAIN 當使用不可阻斷I/O 時(O_NONBLOCK),若無數據可讀取則返回此值。 EBADF 參數fd 非有效的文件描述詞,或該文件已關閉。
7. Linux下read函數默認到底是阻塞的還是非阻塞的
不知題主的read是指socket的read還是文件的read。
默認情況下,socket的read是阻塞的;
對文件進行read,要看內核態的read介面是注冊為同步介面還是非同步介面(可參見file_operations結構體)
8. linux中read,write和recv,send的區別
Linux的recv、send函數和read、write函數都可以用於套接字編程。
區別:
1、recv、send只用於套接字通信;
2、read、write是底層系統調用,只要是文件操作就都可以用, 比如套接字操作,套接字描述符屬於是文件描述符的一種,套接字本身在Linux上就叫做套接字文件。
所以read、write函數不光可以用於套接字編程,也可以用於讀取其他各種文件,比如用於文件編程讀寫普通文件。
9. 關於linux下read函數問題
if((((((((from_fd=open(argv[1],O_RDONLY|O_NONBLOCK))))))))==-1)
你的那個if永遠都是成功open,最重要的是把from_id的值刷成xxxx了。
注意使用 if時候 ==的級別。
提醒下程序結尾沒有return值。