linux系统调用文件函数write()怎么往文件里写入换行
发布网友
发布时间:2022-04-22 12:19
我来回答
共5个回答
热心网友
时间:2022-05-14 05:07
展开3全部
参考一下吧,
strcat(buf,"\n");
将你要写的数据放在buf中,利用strcat函数在后面拼接上换行符\n
int fd=open("/home/wang/time.log",O_CREAT|O_RDWR,0666);
打开(创建)你要操作的文件
write(fd,buf,sizeof(buf));
向文件中写入数据
下面是我创建的守护进程打印的日志文件信息,文件为time.log。内容时每两秒向文件中写入当前时间
热心网友
时间:2022-05-14 06:25
Linux和Unix系统的换行是"\n",而Windows的换行并不是直接的"n",是"\r\n"。所以out.write("\n")只能得到一个黑框,因为Windows不认为这是个“换行”。 直接从记事本输入的话,Windows自动输入了"\r\n",所以从从文本文件中读出来的也是"\r\n",可以正常显示。
那么这是为什么呢?稍微学过正则表达式的朋友都知道:\r是回车符,而\n是换行符。Windows默认\n在文档中显示的是一个空格或者小黑框。所以,要先回车,再换行。
热心网友
时间:2022-05-14 08:00
你确定write()能往文件里写入数据?
你可以写入"\n"或者写入0A和0D这两个字节的数据也行
热心网友
时间:2022-05-14 09:51
linux系统的换行符"\n"
加这个就行了
不过有系统write()函数么。。。
热心网友
时间:2022-05-14 11:59
write
函数向打开的设备或文件中写数据。
#include <unistd.h> ssize_t write(int fd, const void *buf, size_t count); 返回值:成功返回写入的字节数,出错返回-1并设置errno
写常规文件时,
write
的返回值通常等于请求写的字节数
count
,而向终端设备或网络写则不一定。
读常规文件是不会阻塞的,不管读多少字节,
read
一定会在有限的时间内返回。从终端设备或网络读则不一定,如果从终端输入的数据没有换行符,调用
read
读终端设备就会阻塞,如果网络上没有接收到数据包,调用
read
从网络读就会阻塞,至于会阻塞多长时间也是不确定的,如果一直没有数据到达就一直阻塞在那里。同样,写常规文件是不会阻塞的,而向终端设备或网络写则不一定。
现在明确一下阻塞(Block)这个概念。当进程调用一个阻塞的系统函数时,该进程被置于睡眠(Sleep)状态,这时内核调度其它进程运行,直到该进程等待的事件发生了(比如网络上接收到数据包,或者调用
sleep
指定的睡眠时间到了)它才有可能继续运行。与睡眠状态相对的是运行(Running)状态,在Linux内核中,处于运行状态的进程分为两种情况:
正在被调度执行。CPU处于该进程的上下文环境中,程序计数器(
eip
)里保存着该进程的指令地址,通用寄存器里保存着该进程运算过程的中间结果,正在执行该进程的指令,正在读写该进程的地址空间。
就绪状态。该进程不需要等待什么事件发生,随时都可以执行,但CPU暂时还在执行另一个进程,所以该进程在一个就绪队列中等待被内核调度。系统中可能同时有多个就绪的进程,那么该调度谁执行呢?内核的调度算法是基于优先级和时间片的,而且会根据每个进程的运行情况动态调整它的优先级和时间片,让每个进程都能比较公平地得到机会执行,同时要兼顾用户体验,不能让和用户交互的进程响应太慢。