嵌入式(文件属性、目录操作)

打开目录

#include  <dirent.h>
 DIR  *opendir(const char *name);

DIR *fdopendir(int fd); 使用文件描述符,要配合open函数使用
DIR是用来描述一个打开的目录文件的结构体类型
成功时返回目录流指针;出错时返回NULL

读取目录

#include  <dirent.h>
 struct  dirent *readdir(DIR *dirp);

struct dirent是用来描述目录流中一个目录项的结构体类型
包含成员char d_name[256] 参考帮助文档
成功时返回目录流dirp中下一个目录项;
出错或到末尾时时返回NULL

关闭目录
closedir函数用来关闭一个目录文件:

 #include  <dirent.h>
 int closedir(DIR *dirp);

成功时返回0;出错时返回EOF

#include <dirent.h>
#include <stdio.h>

int main(int argc,char **argv){

    DIR* dp;
    struct dirent *dt;
    dp=opendir("/home/hsd/ds/code");
        perror("opendir");
    if(dp<0)
    {
        return 0;
    }
    while((dt=readdir(dp))!=NULL)
    {
       printf("%s\n",dt->d_name);
    }
    closedir(dp);
}

修改文件权限
chmod/fchmod函数用来修改文件的访问权限:

 #include  <sys/stat.h>
 int  chmod(const char *path, mode_t mode);
 int  fchmod(int fd, mode_t mode);
#include <stdio.h>
#include <sys/stat.h>

int main(int argc,char **argv){
   int ret;
   ret = chmod("temp",0444);
   if(ret<0){
        perror("chmod");
        return 0;
    }
}

成功时返回0;出错时返回EOF
注意:在vmware和windows共享的文件夹下,有些权限不能改变。

获取文件属性

#include  <sys/stat.h>
 int  stat(const char *path, struct stat *buf);
 int  lstat(const char *path, struct stat *buf);
 int  fstat(int fd, struct stat *buf);

成功时返回0;出错时返回EOF
如果path是符号链接stat获取的是目标文件的属性;而lstat获取的是链接文件的属性

#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <unistd.h>
#include <time.h>

int main (int argc,char **argv){
   struct stat buf;
   int ret;
   ret = stat("chmod_t.c",&buf);
   if(ret<0){
      perror("stat");
      return 0;
   }
   if(S_ISREG(buf.st_mode)){
       printf("-");
   }
   if(S_ISDIR(buf.st_mode)){
       printf("d");
   }
   if(S_ISCHR(buf.st_mode)){
       printf("c");
   }
   if(S_ISBLK(buf.st_mode)){
       printf("b");
   }
   if(S_ISFIFO(buf.st_mode)){
       printf("p");
   }
   if(S_ISSOCK(buf.st_mode)){
       printf("s");
   }
   int i;
   for(i=8;i>=0;i--){
       if(buf.st_mode & (1<<i)){
          switch(i%3){
          case 2:
              printf("r");
              break;
          case 1:
              printf("w");
              break;
          case 0:
              printf("x");
              break;
          }
       }else{
           printf("-");
       }
   }
   printf(" %d",(int)buf.st_size);

   struct tm *t;
   t = localtime(&buf.st_ctime);
   printf(" %d-%d-%d %d:%d",t->tm_year+1900,t->tm_mon+1,t->tm_mday,t->tm_hour,t->tm_min);

   printf(" chmod_t.c\n");
}

库的概念:

静态库

创建静态库步骤:
1 . 编写库文件代码,编译为.o 目标文件。
2.ar 命令 创建 libxxxx.a 文件
ar -rsv libxxxx.a xxxx.o
注意:
(1) 静态库名字要以lib开头,后缀名为.a

(2) 没有main函数的.c 文件不能生成可执行文件。

链接错误:
test.c:(.text+0x15):对‘hello’未定义的引用
collect2: error: ld returned 1 exit status
含义:表示hello函数在编译的源码内没有找到实现
解决:实现代码或者找到对应函数的库并且链接它。

链接静态库:

gcc -o 目标文件 源码.c -L路径 -lxxxx

-L 表示库所在的路径
-l 后面跟库的名称

动态库的生成步骤:

1.生成位置无关代码的目标文件
gcc -c -fPIC xxx.c xxxx.c …
2.生成动态库
gcc -shared -o libxxxx.so xxx.o xxx.o …

3.编译可执行文件
gcc -o 目标文件 源码.c -L路径 -lxxxx
执行动态库的可执行文件错误

./test: error while loading shared libraries: libmyheby.so: cannot open shared object file: No such file or directory

含义:可执行文件所使用的动态库找不到
解决办法:
找到动态库,添加到/usr/lib里面
或者使用export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:你的动态库目录
添加在~/.bashrc 文件里面
使用source ~/.bashrc 生效。

查看可执行文件使用的动态库:
ldd 命令 : ldd 你的可执行文件

root@haas-virtual-machine:/mnt/hgfs/share/newIOP# ldd test
	linux-vdso.so.1 =>  (0x00007fff6548d000)
	libmyheby.so => /mnt/hgfs/share/newIOP/day5/libmyheby.so (0x00007f5c89521000)
	libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f5c89144000)
	/lib64/ld-linux-x86-64.so.2 (0x000055fe52211000)

root@haas-virtual-machine:/mnt/hgfs/share/newIOP/day5# ldd test
	linux-vdso.so.1 =>  (0x00007ffcb652c000)
	libmyheby.so => not found
	libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007fbeeffaf000)
	/lib64/ld-linux-x86-64.so.2 (0x0000561003c3b000)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
RT-Thread是一个开源的实时操作系统,它的设计目标是提供一个简单、高效、可靠的实时操作系统内核。下面是RT-Thread的原理分析: 1. 内核对象的设计:RT-Thread内核对象包括线程、信号量、邮箱、消息队列、内存池等。每个内核对象都有一个控制块,用于描述该对象的状态和属性。内核对象的设计使得RT-Thread内核具有高度的可扩展性和灵活性。 2. 线程调度的机制:RT-Thread采用抢占式的优先级调度算法,支持多级优先级和时间片轮转调度。线程的优先级越高,被调度的机会就越大。当多个线程的优先级相同时,采用时间片轮转调度算法。 3. 中断处理机制:RT-Thread支持中断嵌套和中断优先级控制。当一个中断处理程序正在执行时,如果发生了更高优先级的中断,RT-Thread会挂起当前中断处理程序,转而执行更高优先级的中断处理程序。 4. 内存管理机制:RT-Thread采用动态内存管理机制,支持内存池和动态内存分配。内存池可以提高内存分配的效率,动态内存分配可以更灵活地管理内存。 5. 设备驱动机制:RT-Thread采用设备驱动框架,支持字符设备、块设备、网络设备等。设备驱动程序可以通过注册设备驱动的方式来实现。 6. 文件系统机制:RT-Thread支持多种文件系统,包括FAT、YAFFS、ROMFS等。文件系统可以通过挂载的方式来使用。 7. 网络协议栈:RT-Thread支持TCP/IP协议栈,包括TCP、UDP、IP、ICMP、ARP等协议。网络协议栈可以通过配置的方式来启用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

嵌入式学习者。

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值