1.开始编译器在当前目录运行:source /opt/fsl-imx-x11/4.1.15-2.1.0/environment-setup-cortexa7hf-neon-poky-linux-gnueabi命令
2.tftp服务器不响应,出现tftp timeout时,使用命令sudo service tftpd-hpa restart重启tftp服务器
3.open函数标志记不住:O_RDONLY(只读);O_WRONLY(只写);O_RDWR(可读可写);
O_CREAT(如果文件不存在则创建文件);O_EXCL(可以用于测试一个文件是否存在,如 果不存在则创建此文件,如果存在则 返回错误,这使得测试和创建两者成 为一个原子操作)
4:open和fopen区别:
1、缓冲文件系统与非缓冲系统的区别
缓冲文件系统(fopen) :在内存为每个文件开辟一个缓存区,当执行读操作,从磁盘文件将数据读入内存缓冲区,装满后从内存缓冲区依次读取数据。写操作同理。
内存缓冲区的大小影响着实际操作外存的次数,缓冲区越大,操作外存的次数越少,执行速度快,效率高。缓冲区大小由机器而定。
借助文件结构体指针对文件管理,可读写字符串、格式化数据、二进制数据。
非缓冲文件系统(open):依赖操作系统功能对文件读写,不设文件结构体指针,只能读写二进制文件。
2、open属于低级IO,fopen属于高级IO
3、open返回文件描述符,属于用户态,读写需进行用户态与内核态切换。
fopen返回文件指针
4、open是系统函数,不可移植
fopen是标准C函数,可移植
5、一般用fopen打开普通文件,open打开设备文件
6、 如果顺序访问文件,fopen比open快
如果随机访问文件,open比fopen快
5.线程和进程的区别:
进程:进程其实就是一个可执行程序的实例,可执行程序就是一个可执行文件。进程是一个动态过程,而非静态文件,它是程序的一次运行过程,当应用程序被加载到内存中运行之后 它就称为了一个进程,当程序运行结束后也就意味着进程终止,这就是进程的一个生命周期。子线程生成后代码和父线程基本一样,也是从父线程中创建子线程后面程序继续执行。
使用fork()创建子进程,fork()系统调用的关键在于,完成对其调用后将存在两个进程,一个是原进程(父进程)、另一个 则是创建出来的子进程,并且每个进程都会从 fork()函数的返回处继续执行,会导致调用 fork()返回两次值, 子进程返回一个值、父进程返回一个值。在程序代码中,可通过返回值来区分是子进程还是父进程。子进程被创建出来之后,便是一个独立的进程,拥有自己独立的进程空间,系统内唯一的进程号,拥有 自己独立的 PCB(进程控制块),子进程会被内核同等调度执行,参与到系统的进程调度中。
使用atexit(void (*function)(void))用于注册一个进程在正常终止时要调用的函数,参数是指针指向注册的函数,并且该函数无需传参。
线程:线程是允许应用程序并发执行多个任务的 一种机制,线程参与系统调度,事实上,系统调度的最小单元是线程、而并非进程。线程是参与系统调度的最小单位。它被包含在进程之中,是进程中的实际运行单位。一个进程中可以创建多个线程,多个线程实现 并发运行,每个线程执行不同的任务。
特点:线程是程序最基本的运行单位,而进程不能运行,真正运行的是进程中的线程。当启动应用程序后,系 统就创建了一个进程,可以认为进程仅仅是一个容器,它包含了线程运行所需的数据结构、环境变量等信息。