LINUX学习小知识

上传人:痛*** 文档编号:147109862 上传时间:2022-09-01 格式:DOC 页数:59 大小:804KB
收藏 版权申诉 举报 下载
LINUX学习小知识_第1页
第1页 / 共59页
LINUX学习小知识_第2页
第2页 / 共59页
LINUX学习小知识_第3页
第3页 / 共59页
资源描述:

《LINUX学习小知识》由会员分享,可在线阅读,更多相关《LINUX学习小知识(59页珍藏版)》请在装配图网上搜索。

1、小知识20120614王小彬1、在linux终端下,执行:mount udisk /mnt 可以将U盘挂载到/mnt文件夹下。之后要读取U盘的内容就很容易了。:):)(*)2、 arm板上linux自动挂载U盘(详解将友善之臂的root_qtopia根文件的/etc/mdev.conf 和 /bin/hotplug.sh这两个文件)mini2440开发板Linux系统自动挂载U盘与SD卡失败的解决方法对于有些U盘和SD卡,mini2440开发板自带的Linux系统不能有效的自动挂载在文件系统里面,这是因为mini2440的/etc/mdev.conf 和 /bin/hotplug.sh这两个文

2、件写的不太完善,我经过测试,发现其中的内容需要改进,在/etc/mdev.conf文件中,只需将以下内容写至末尾即可:mmcblk0-9 0:0 0666 =sdcard * /bin/hotplug.sh sda-z0-9 0:0 0666 =udisk * /bin/hotplug.sh在/bin/hotplug.sh文件中则需要把以下内容加在 “case $MDEV in” 的后面:sda-z1-9)DEVNAME=udiskMOUNTPOINT=/udisk;mmcblk0-9p0-9) DEVNAME=sdcard MOUNTPOINT=/sdcard ;mmcblk0-9)DEVN

3、AME=sdcardMOUNTPOINT=/sdcard;这样再重启系统就可以自动挂载任何了!本篇文章来源于 Linux公社网站() 原文链接:3、 Qt中文显示设置#include 02#include 03#include mainwindow.h 0405int main(int argc, char *argv) 06 0708QApplication a(argc, argv); 09/ 以下部分解决中文乱码 10QTextCodec:setCodecForTr(QTextCodec:codecForName(UTF8); 11QTextCodec:setCodecForLocale

4、(QTextCodec:codecForName(UTF8); 12QTextCodec:setCodecForCStrings(QTextCodec:codecForName(UTF8); 13/ 以上部分解决中文乱码 14MainWindow w; 1516w.show(); 1718return a.exec(); 4、Fedora 14 以root身份登录GUI界面设置进入到/etc/pam.d/目录下:cd /etc/pam.d/切换到root权限:su root用vim打开gdm和gdm-password两个文件分别用“#”注释掉 auth required pam_succeee

5、d_if.so user!=root quite 一行。重新回到登录界面即可用root登录到图形界面。5、Fedora安装新内核将内核解压到根文件下,进入内核,执行:#! /bin/shmake menuconfigmake make modulesmake modules_installmake install将/boot/grub下的grub.conf打开将上面的timeout=0改为5,即延时5s作为选择内核版本的缓冲时间,当然想要设得更长或更短都可以,结果如下重启后在BISO自检之后,按ESC键,进入Grub引导菜单,选择相应的内核。6、 Ubuntu下安装qwt且使用在终端执行:sv

6、n co qwt 获取qwt的源码,然后进入该文件夹下的qwt-6.0文件夹,执行:qmakemakemake install编译完的代码自动安装到/usr/local下,形成一个名为qwt-6.0.2-svn的文件夹。进入该文件夹下的example是,执行:qmake make进入该文件夹下的bin,在终端执行:./bode qws&,即可运行一个示例程序。接下来是将qwt集成到qt Creator里。将qwt-6.0.2-svn文件下/plugins/designer里的libqwt_designer_plugin.so复制到/usr/share/qt4/plugins/designer/

7、下面。将qwt-6.0.2-svn文件下的include文件夹里的内容复制到/usr/local/include/qwtx86下将qwt-6.0.2-svn文件下的lib文件夹里的内容复制到/usr/local/include/lib下添加环境变量(不是必须的)#vi /etc/profile打开后,在最后输入:export LD_LIBRARY_PATH=/usr/local/qwt-6.0.2-svn/lib:$LD_LIBRARY_PATHqwt的使用使用时需要在工程文件里添加如下两句INCLUDEPATH += /usr/local /include/qwtx86/LIBS += -L

8、/usr/local/lib/qwtx86/ lqwt编译arm版的qwt,需借助qt Creator。参考以下的博客内容:qwt移植到s3c6410 分类: Qt s3c6410芯片与系统 2012-02-17 10:00 643人阅读 评论(7) 收藏 举报 昨天在一群里有一哥们问到关于qwt移植的问题,我就自己动手做了一下,发现还是比较容易的,示例程序也编译通过了,现在将移植的过程记录一下。 首先要说明一点的是在这之前,我的Qt-4.7.3已经移植成功了,这里做的就是移植qwt并且在板子上测试示例程序。 第一步:下载最新的qwt源码,主页是 第二步:解压源码,进入源码目录,我们来看看里面

9、的文件,主要是两个一个是README和INSTALL,其中前者是关于这个项目的一些介绍,后者是针对不同平台编译安装的方法,里面有这样一句:The easiest way to build Qwt is from the command line - but you insist onusing an IDE dont forget the make install step.就是说如果你用IDE(例如Qt Creator)来编译的话,编译成功后不要忘了在终端进入源码目录执行$ make install命令进行安装。当然,如果你也可以一直在终端编译和安装不必借助IDE。 第三步:我们这里借助ID

10、E编译,打开Qt Creator后打开qwt的工程,要编译ARM版本的,那么你就必须在Qt Creator中进行相关的设置,也就是添加一个工具链,如果有需要的话请留言,我可以截图写出具体的设置步骤。 第四步:我们来进行编译,点击 Build ALL,编译的过程中会报错,是关于一些Designer的头文件找不到,因为qwt自定义了一些designer的插件,方便我们进行开发,所以需要一些Qt Designer的头文件,由于我有qt源码,所以这个还是比较好添加进去的,可是到最后又报错:说是不能连接到Designer库,我到我电脑上安装的qt目录下找了一下,发现X86版本的Qt的lib目录下是有这些

11、库文件的,而在电脑上安装的ARM版本的Qt里面lib目录下并没有这些库文件,这就无奈了,刚好我要的就是ARM版本的阿。后来我仔细一想,源于Qt Designer的插件应该只是在电脑上用来做开发的,而不是在板子上运行的,也就是说这部分内容在板子上压根就不需要,所以,我打开qwtconfig目录下的qwtconfig.pri配置文件,想屏蔽designer的编译。在qwtconfig.pri文件的第102行,有这条语句:html view plaincopyprint?QWT_CONFIG+=QwtDesigner这就是我要屏幕的内容,呵呵加“#”注释掉。然后再编译就通过了,接着进入到终端下执行m

12、ake install就可以发现已经安装了,默认的安装目录在哪里呢,还是看一下qwtconfig.pri配置文件,在第22行有: html view plaincopyprint?QWT_INSTALL_PREFIX=/usr/local/qwt-$QWT_VERSION这就是默认的安装目录,可以自行修改,但是建议修改之后重新进行编译再安装。安装好了之后进入安装目录发现示例程序并没有编译,我们再次看看配置文件,发现在第108行有: html view plaincopyprint?#QWT_CONFIG+=QwtExamples这就是说工程默认是不编译示例程序的,要编译的话,就去掉注释,OK,

13、编译完后会在qwt-6.0.1/examples目录下生成bin目录,下面就都是示例程序。 接下来,我们在板子上测试,只需要将安装目录下的lib子目录下的几个库文件拷贝到板子文件系统的Qt的默认库路径下,然后将编译出来的示例程序也拷贝下去。 我们烧写新的文件系统,开机,运行程序,一切OK,无图无真相,这里我就上几个图: 呵呵,移植工作到这里就完成了。 但是我们如果要在电脑上利用qwt来开发的话也必须有相应的库文件,所以我们要编译出一个qwt的X86版本,这个版本不必注释designer部分,直接编译就会通过,然后将生成的库文件拷到电脑上Qt库文件目录下,将生成的designer的插件拷贝到$(

14、QTDIR)/plugins/designer目录下,启动designer就可以看到qwt的插件了,截图如下:也可以编译出X86的示例程序,运行如下: 好了,今天就到这吧!自学的话,比如学Qt,那看Qt下的范例最能够提高技术,当然要现有一定的水平去看懂。7、使用top可以查看linux进程的内存及cpu使用情况8、学习方法总结之一,学习一项新技术,如果该技术有提供帮助文档、范例(examples),那查看他们是最好的学习之路。9、学习方法总结之二,遇到问题,要先把那个问题单独拿出来解决。比如Qt编程中QGraphicsItem不懂得使用,单独编一个item的类拿来学学,认识透,这样,同样的问题

15、下次应该不会再犯了。10、Qt中对于view、scene、item的mouse事件进行重载时要注意对象,不同对象的重载结果不同,作用的范围也不同,比如要处理item的坐标事件,那需需在view或scene中,但不能是在widget中,这样会比较好。11、产生随机数,qrand()%10可以产生0-9之间的随机数。要想产生100以内的随机数就%100。以此类推。12、linux驱动程序编程中遇到错误:隐式声明函数kmalloc或错误:隐式声明函数kfree解决办法是:2.6内核下的kmalloc函数定义,对比2.4的内核,该函数被移到了linux/slab.h头文件中作为一个static inl

16、ine函数实现,所以在调用该函数时,一定要包含linux/slab.h. kmalloc是基于slab实现的,分配的内存不能超过128k, 并且实际上每次分配的内存大小都是2的幂次.即:添加#include头文件13、在/dev下创建设备节点设备节点的自动创建使用手动创建mknod/dev/device_namecmajorminordevice_name: 指设备名,c: 表述创建字符设备节点(同理b 表示创建块设备文件节点)major: 主设备号minor: 次设备号在做测试时候这样做事可以理解的,而在作为一个模块要发行时候,这样就太不方面了,要先查看设备是否成功创建,查看注册设备的主设备

17、号,输入命令创建文件节点14、一个QGraphicsView滚动条问题滚动条设置到最左边和最上边可以用centerOn(0,0)来设定 15、Qt外部库编译将QT编译成库文件 - 风fworld的日志 - 网易博客2010-12-30 15:03:43|分类: 默认分类 |标签: |字号大中小订阅 将QT编译成库文件最主要是写个.pro文件,下面给出其样例文件:qtserial.prosingleprocess:singleprocess=trueTEMPLATE= libCONFIG= qt warn_on releaseHEADERS= posix_qtserialport.h qtser

18、ialbase.hSOURCES= posix_qtserialport.cpp qtserialbase.cpp TARGET = qtserialDESTDIR = ./libVERSION = 1.0.0 INTERFACES= 对此文件应该不用解释了吧,哦对了,注意一点,在然后在此目录下建立一个lib目录以备放置生成后的库文件接下来用命令qmake -o Makefile qtserial.pro生成所需的Makefile文件,make,你就可以在lib目录下生成:libqtserial.so,libqtserial.so.1;libqtserial.so.1.0;libqtseria

19、l.so.1.0.0然后把此几个文件拷贝到$QTEDIR/lib目录下,把头文件:posix_qtserialport.h,qtserialbase.h拷贝到$QTEDIR/include目录下,当然也可以你自己指定的目录,最后是测试程序,你在测试程序中就可以像使用一般的库文件那样使用了,对了,当然,在makefile中的LIBS变量上加-lqtserial;eg:LIBS=$(SUBLIBS) -L$(QTDIR)/lib -lm -lqte -lqtserial相关文章16、Qt无规则窗口制作setGeometry(0,0,120,120);pixmap=new QPixmap("

20、;/doc/test/a/tmp.png");bitmap=new QBitmap("/doc/test/a/mask.png");QPalette palette;palette.setBrush(backgroundRole(), QBrush(*pixmap);setPalette(palette);setMask(*bitmap);17、虚拟机里的Ubuntu串口设置串口名为:ttyS1;18、有两块板独自都可以和电脑正确通信,而两块板之间却通信错误,此时可以查看一下两块板间的TX、Rx是否接对,很可能两者之间是以TX-TX、Rx-Rx连接的。19、lin

21、ux内核编译安装需要的工具:build-essential基本的编程库(gcc,make等)kernel-packagelibncurses5-dev(mekemenuconfig要调用的)libqt3-headers(makexconfig要调用的)其他工具在升级过程中可以按提示安装20、查看linux内核信息 2011-03-28 18:06 348人阅读 评论(0) 收藏 举报 关键词环形缓冲区printkklogdsyslogddmesg在头文件 中定义了 【8种可用的日志级别字符串】 KERN_EMERG 用于紧急事件消息,它们一般是系统崩溃之前提示的消息。KERN_ALERT 用于

22、需要立即采取动作的情况。KERN_CRIT 临界状态,通常涉及严重的硬件或软件操作失败。KERN_ERR 用于报告错误状态;设备驱动程序会经常使用KERN_ERR来报告来自硬件的问题。KERN_WARNING 对可能出现问题的情况进行警告,这类情况通常不会对系统造成严重问题。KERN_NOTICE 有必要进行提示的正常情形。许多与安全相关的状况用这个级别进行汇报。KERN_INFO 提示性信息。很多驱动程序在启动的时候,以这个级别打印出它们找到的硬件信息。KERN_DEBUG 用于调试信息。 dmesg是从kernel的ring buffer(环缓冲区)中读取信息的.那什么是ring buff

23、er呢? 在LINUX中,所有的系统信息(包内核信息)都会传送到ring buffer中.而内核产生的信息由printk()打印出来。 系统启动时所看到的信息都是由该函数打印到屏幕中。 printk()打出的信息往往以 . 这的数字表明消息的重要级别。高于一定的优先级别会打印到屏幕上,否则只会保留在系统的缓冲区中(ring buffer)。 至于dmesg具体是如何从ring buffer中读取的,大家可以看dmesg.c源代码.很短,比较容易读懂. 是syslogd这个守护进程根据/etc/syslog.conf,将不同的服务产生的Log记录到不同的文件中. LINUX系统启动后,由/etc

24、/init.d/sysklogd先后启动klogd,syslogd两个守护进程。 其中klogd会通过syslog()系统调用或者读取proc文件系统来从系统缓冲区(ring buffer)中得到由内核printk()发出的信息.而syslogd是通过klogd来读取系统内核信息. 1 所有系统信息是输出到ring buffer中去的.dmesg所显示的内容也是从ring buffer中读取的. 2 LINUX系统中/etc/init.d/sysklogd会启动2个守护进程:Klogd, Syslogd 3 klogd是负责读取内核信息的,有2种方式: syslog()系统调用(这个函数用法比

25、较全,大家去MAN一下看看)直接的对/proc/kmsg进行读取(再这提一下,/proc/kmsg是专门输出内核信息的地方) 4 Klogd的输出结果会传送给syslogd进行处理,syslogd会根据/etc/syslog.conf的配置把log信息输出到/var/log/下的不同文件中. 21、进行linux串口通信时,要重点注意串口的设置,如果输入输出设置不对的话,在接受或发送一些与回车符、空格等ASCII码相等的字符时,会出现堵塞现象。22、嵌入式Qt中,主线程中的对象(如按钮、对话框等等之类的)越多,Qt程序在处理对应对象的信号响应时就越慢。因为需要超找响应的对象变多了。可以多线程使

26、用,分配线程间的对象数。23、使用C语言进行文件的重命名及删除操作在包里有两个函数可以满足你的要求:注意,这两个函数操作的文件必须要关闭,否则会执行失败,如果失败,执行完成后可以通过比较errno的值来确定失败原因.重命名:int rename(const char *oldname, const char *newname);参数解释:oldname:原文件名newname:新文件名(可以指定全局路径来移动文件)返回值:0:成功-1:失败,并将全局变量errno置为错误码删除:int remove(const char *filename);参数解释:filename:要删除的文件名返回值:

27、0:成功-1:失败,并将全局变量errno置为错误码24、access目录描述 函数名: access 头文件:io.h(linux中为) 功 能: 确定文件的访问权限,检查某个文件的存取方式,比如说是只读方式、只写方式等。如果指定的存取方式有效,则函数返回0,否则函数返回-1。 用 法: int access(const char *filename, int amode); int _access(const char *path,int mode) ; 编辑本段描述access函数,当对文件使用时,判断是否存在指定的文件,以及是否能够按指定的模式进行访问。当对目录使用时,只判断是否存在指

28、定的目录;因为在Windows系统下所有的目录都有读和写的访问权限。 参数mode可为以下的其中之一: 00 只存在 02 写权限 04 读权限 06 读和写权限 返回值: 如果文件拥有给定的模式则返回0,如果发生错误返回-1。 可移植性: Windows,Unix 及其类似系统都存在此函数。 请注意,lcc-win32同时支持_access(微软公约)和access。 程序例: #include #include int file_exists(char *filename); int main(void) printf(Does NOTEXIST.FIL exist: %sn, file_

29、exists(NOTEXISTS.FIL) ? YES : NO); return 0; int file_exists(char *filename) return (access(filename, 0) = 0); 25、C语言linux简单编程,遍历文件夹获得文件名 2011-3-29 20:28 提问者: dlrongrong | 悬赏分:5 | 浏览次数:2059次目的:访问某个地址,遍历文件名得到文件名以0开头的文件,将此.jp2文件的文件名和文件大小读取存放到一个BUFFER里面。int GetFileCount(char ff) /ff的值为0,表示需要匹配以0开头的文件名

30、char name402400; char buf1024; memset(name,0,402400); DIR *pDir; struct dirent *pDirect; pDir=opendir(/mnt/disk1/jp2/*.jp2); if(pDir=NULL) return -1; do memset(buf,0,1024); sprintf(buf,%s:%d,pDirect-d_name,pDirect-d_reclen); if(pDirect-d_name0!=ff) continue; strcat(name,buf); while( pDirect=readdir(

31、pDir) ) != NULL); send(client_socket,name,strlen(name),0); closedir(pDir); return 0;3)Linux程序设计入门-文件操作Linux下文件的操作前言: 我们在这一节将要讨论linux下文件操作的各个函数. 文件的创建和读写文件的各个属性目录文件的操作管道文件- - 1。文件的创建和读写我假设你已经知道了标准级的文件操作的各个函数(fopen,fread,fwrite等等).当然如果你不清楚的话也不要着急.我们讨论的系统级的文件操作实际上是为标准级文件操作服务的. 当我们需要打开一个文件进行读写操作的时候,我们可以

32、使用系统调用函数open.使用完成以后我们调用另外一个close函数进行关闭操作. #include #include #include #include int open(const char *pathname,int flags); int open(const char *pathname,int flags,mode_t mode); int close(int fd); open函数有两个形式.其中pathname是我们要打开的文件名(包含路径名称,缺省是认为在当前路径下面).flags可以去下面的一个值或者是几个值的组合. O_RDONLY:以只读的方式打开文件. O_WRONL

33、Y:以只写的方式打开文件. O_RDWR:以读写的方式打开文件. O_APPEND:以追加的方式打开文件. O_CREAT:创建一个文件. O_EXEC:如果使用了O_CREAT而且文件已经存在,就会发生一个错误. O_NOBLOCK:以非阻塞的方式打开一个文件. O_TRUNC:如果文件已经存在,则删除文件的内容. 前面三个标志只能使用任意的一个.如果使用了O_CREATE标志,那么我们要使用open的第二种形式.还要指定mode标志,用来表示文件的访问权限.mode可以是以下情况的组合. - S_IRUSR 用户可以读 S_IWUSR 用户可以写S_IXUSR 用户可以执行 S_IRWXU

34、 用户可以读写执行- S_IRGRP 组可以读 S_IWGRP 组可以写S_IXGRP 组可以执行 S_IRWXG 组可以读写执行- S_IROTH 其他人可以读 S_IWOTH 其他人可以写S_IXOTH 其他人可以执行 S_IRWXO 其他人可以读写执行- S_ISUID 设置用户执行ID S_ISGID 设置组的执行ID - 我们也可以用数字来代表各个位的标志.Linux总共用5个数字来表示文件的各种权限. 00000.第一位表示设置用户ID.第二位表示设置组ID,第三位表示用户自己的权限位,第四位表示组的权限,最后一位表示其他人的权限. 每个数字可以取1(执行权限),2(写权限),4(

35、读权限),0(什么也没有)或者是这几个值的和. 比如我们要创建一个用户读写执行,组没有权限,其他人读执行的文件.设置用户ID位那么我们可以使用的模式是-1(设置用户ID)0(组没有设置)7(1+2+4)0(没有权限,使用缺省) 5(1+4)即10705: open(temp,O_CREAT,10705); 如果我们打开文件成功,open会返回一个文件描述符.我们以后对文件的所有操作就可以对这个文件描述符进行操作了. 当我们操作完成以后,我们要关闭文件了,只要调用close就可以了,其中fd是我们要关闭的文件描述符. 文件打开了以后,我们就要对文件进行读写了.我们可以调用函数read和write

36、进行文件的读写. #include ssize_t read(int fd, void *buffer,size_t count); ssize_t write(int fd, const void *buffer,size_t count); fd是我们要进行读写操作的文件描述符,buffer是我们要写入文件内容或读出文件内容的内存地址.count是我们要读写的字节数. 对于普通的文件read从指定的文件(fd)中读取count字节到buffer缓冲区中(记住我们必须提供一个足够大的缓冲区),同时返回count. 如果read读到了文件的结尾或者被一个信号所中断,返回值会小于count.如果

37、是由信号中断引起返回,而且没有返回数据,read会返回-1,且设置errno为EINTR.当程序读到了文件结尾的时候,read会返回0. write从buffer中写count字节到文件fd中,成功时返回实际所写的字节数. 下面我们学习一个实例,这个实例用来拷贝文件. #include #include #include #include #include #include #include #define BUFFER_SIZE 1024 int main(int argc,char *argv) int from_fd,to_fd; int bytes_read,bytes_write;

38、char bufferBUFFER_SIZE; char *ptr; if(argc!=3) fprintf(stderr,Usage:%s fromfile tofilena,argv0); exit(1); /* 打开源文件 */ if(from_fd=open(argv1,O_RDONLY)=-1) fprintf(stderr,Open %s Error:%sn,argv1,strerror(errno); exit(1); /* 创建目的文件 */ if(to_fd=open(argv2,O_WRONLY|O_CREAT,S_IRUSR|S_IWUSR)=-1) fprintf(st

39、derr,Open %s Error:%sn,argv2,strerror(errno); exit(1); /* 以下代码是一个经典的拷贝文件的代码 */ while(bytes_read=read(from_fd,buffer,BUFFER_SIZE) /* 一个致命的错误发生了 */ if(bytes_read=-1)&(errno!=EINTR) break; else if(bytes_read0) ptr=buffer; while(bytes_write=write(to_fd,ptr,bytes_read) /* 一个致命错误发生了 */ if(bytes_write=-1)&

40、(errno!=EINTR)break; /* 写完了所有读的字节 */ else if(bytes_write=bytes_read) break; /* 只写了一部分,继续写 */ else if(bytes_write0) ptr+=bytes_write; bytes_read-=bytes_write; /* 写的时候发生的致命错误 */ if(bytes_write=-1)break; close(from_fd); close(to_fd); exit(0); 2。文件的各个属性文件具有各种各样的属性,除了我们上面所知道的文件权限以外,文件还有创建时间,大小等等属性. 有时侯我们

41、要判断文件是否可以进行某种操作(读,写等等).这个时候我们可以使用acce ss函数. #include int access(const char *pathname,int mode); pathname:是文件名称,mode是我们要判断的属性.可以取以下值或者是他们的组合. R_OK文件可以读,W_OK文件可以写,X_OK文件可以执行,F_OK文件存在.当我们测试成功时,函数返回0,否则如果有一个条件不符时,返回-1. 如果我们要获得文件的其他属性,我们可以使用函数stat或者fstat. #include #include int stat(const char *file_name,

42、struct stat *buf); int fstat(int filedes,struct stat *buf); struct stat dev_t st_dev; /* 设备 */ ino_t st_ino; /* 节点 */ mode_t st_mode; /* 模式 */ nlink_t st_nlink; /* 硬连接 */ uid_t st_uid; /* 用户ID */ gid_t st_gid; /* 组ID */ dev_t st_rdev; /* 设备类型 */ off_t st_off; /* 文件字节数 */ unsigned long st_blksize; /*

43、 块大小 */ unsigned long st_blocks; /* 块数 */ time_t st_atime; /* 最后一次访问时间 */ time_t st_mtime; /* 最后一次修改时间 */ time_t st_ctime; /* 最后一次改变时间(指属性) */ ; stat用来判断没有打开的文件,而fstat用来判断打开的文件.我们使用最多的属性是st_ mode.通过着属性我们可以判断给定的文件是一个普通文件还是一个目录,连接等等.可以使用下面几个宏来判断. S_ISLNK(st_mode):是否是一个连接.S_ISREG是否是一个常规文件.S_ISDIR是否是一个目

44、录S_ISCHR是否是一个字符设备.S_ISBLK是否是一个块设备S_ISFIFO是否 是一个FIFO文件.S_ISSOCK是否是一个SOCKET文件. 我们会在下面说明如何使用这几个宏的. 3。目录文件的操作在我们编写程序的时候,有时候会要得到我们当前的工作路径。C库函数提供了get cwd来解决这个问题。#include char *getcwd(char *buffer,size_t size); 我们提供一个size大小的buffer,getcwd会把我们当前的路径考到buffer中.如果buffer 太小,函数会返回-1和一个错误号. Linux提供了大量的目录操作函数,我们学习几个

45、比较简单和常用的函数. #include #include #include #include #include int mkdir(const char *path,mode_t mode); DIR *opendir(const char *path); struct dirent *readdir(DIR *dir); void rewinddir(DIR *dir); off_t telldir(DIR *dir); void seekdir(DIR *dir,off_t off); int closedir(DIR *dir); struct dirent long d_ino; o

46、ff_t d_off; unsigned short d_reclen; char d_nameNAME_MAX+1; /* 文件名称 */ mkdir很容易就是我们创建一个目录,opendir打开一个目录为以后读做准备.readdir读一个打开的目录.rewinddir是用来重读目录的和我们学的rewind函数一样.closedir是关闭一个目录.telldir和seekdir类似与ftee和fseek函数. 下面我们开发一个小程序,这个程序有一个参数.如果这个参数是一个文件名,我们输出这个文件的大小和最后修改的时间,如果是一个目录我们输出这个目录下所有文件的大小和修改时间. #includ

47、e #include #include #include #include #include #include #include static int get_file_size_time(const char *filename) struct stat statbuf; if(stat(filename,&statbuf)=-1) printf(Get stat on %s Error:%sn, filename,strerror(errno); return(-1); if(S_ISDIR(statbuf.st_mode)return(1); if(S_ISREG(statbuf.st_

48、mode) printf(%s size:%ld bytestmodified at %s, filename,statbuf.st_size,ctime(&statbuf.st_mtime); return(0); int main(int argc,char *argv) DIR *dirp; struct dirent *direntp; int stats; if(argc!=2) printf(Usage:%s filenamena,argv0); exit(1); if(stats=get_file_size_time(argv1)=0)|(stats=-1)exit(1); if

49、(dirp=opendir(argv1)=NULL) printf(Open Directory %s Error:%sn, argv1,strerror(errno); exit(1); while(direntp=readdir(dirp)!=NULL) if(get_file_size_time(direntp-d_name)=-1)break; closedir(dirp); exit(1); 4。管道文件Linux提供了许多的过滤和重定向程序,比如more cat 等等.还提供了 | 等等重定向操作符.在这些过滤和重 定向程序当中,都用到了管道这种特殊的文件.系统调用pipe可以创建

50、一个管道. #include int pipe(int fildes2); pipe调用可以创建一个管道(通信缓冲区).当调用成功时,我们可以访问文件描述符fild es0,fildes1.其中fildes0是用来读的文件描述符,而fildes1是用来写的文件描述符. 在实际使用中我们是通过创建一个子进程,然后一个进程写,一个进程读来使用的. 关于进程通信的详细情况请查看进程通信#include #include #include #include #include #include #include #define BUFFER 255 int main(int argc,char *arg

51、v) char bufferBUFFER+1; int fd2; if(argc!=2) fprintf(stderr,Usage:%s stringna,argv0); exit(1); if(pipe(fd)!=0) fprintf(stderr,Pipe Error:%sna,strerror(errno); exit(1); if(fork()=0) close(fd0); printf(Child%d Write to pipena,getpid(); snprintf(buffer,BUFFER,%s,argv1); write(fd1,buffer,strlen(buffer);

52、 printf(Child%d Quitna,getpid(); exit(0); else close(fd1); printf(Parent%d Read from pipena,getpid(); memset(buffer,0,BUFFER+1); read(fd0,buffer,BUFFER); printf(Parent%d Read:%sn,getpid(),buffer); exit(1); 为了实现重定向操作,我们需要调用另外一个函数dup2. #include int dup2(int oldfd,int newfd); dup2将用oldfd文件描述符来代替newfd文件

53、描述符,同时关闭newfd文件描述符.也就是说, 所有向newfd操作都转到oldfd上面.下面我们学习一个例子,这个例子将标准输出重定向到一个文件. #include #include #include #include #include #include #include #define BUFFER_SIZE 1024 int main(int argc,char *argv) int fd; char bufferBUFFER_SIZE; if(argc!=2) fprintf(stderr,Usage:%s outfilenamena,argv0); exit(1); if(fd=o

54、pen(argv1,O_WRONLY|O_CREAT|O_TRUNC,S_IRUSR|S_IWUSR)=-1) fprintf(stderr,Open %s Error:%sna,argv1,strerror(errno); exit(1); if(dup2(fd,STDOUT_FILENO)=-1) fprintf(stderr,Redirect Standard Out Error:%sna,strerror(errno); exit(1); fprintf(stderr,Now,please input string); fprintf(stderr,(To quit use CTRL+

55、D)n); while(1) fgets(buffer,BUFFER_SIZE,stdin); if(feof(stdin)break; write(STDOUT_FILENO,buffer,strlen(buffer); exit(0); 好了,文件一章我们就暂时先讨论到这里,学习好了文件的操作我们其实已经可以写出一些比较有用的程序了.我们可以编写一个实现例如dir,mkdir,cp,mv等等常用的文件操作命令了. 想不想自己写几个试一试呢? 26、linux下,使用stime()、settimeofday()函数只能更改系统的当前时间,并不能将当前已修改的时间写入RTC中,系统重启后会丢失设置的时间。1、嵌入式系统板子上的时间是用date标准系统命令查看的,date是SHELL命令,例如busybox或者uClinux上的sash等。这个时间是有运行起来的嵌入式LINUX软件维护的,其实就是内存中的一个全局变量,LINUX默认启动给这个全局变量赋值就是19700101这样的数值。2、RTC芯片(很多

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!