linux系统 C语言编程
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了linux系统 C语言编程相关的知识,希望对你有一定的参考价值。
几个小问题请教一下
1.char buffer[PIPE_BUF];这个定义,是数组吗?PIPE_BUF是什么
2.函数原型看不懂,比如ssize_t read(int fd, void *buf, size_t count);
ssize_t和各参数是什么意思哦。还有像
FILE * fopen(const char * path,const char * mode); fopen前面的
FILE*又是什么。这些函数的功能,参数意思是不是都要一个个去看去学
函数的命名其实学问也挺大。。不过你使用非正式的话对程序也没有什么影响只是别人的 易读性差了些。
1.定义的一个 char类型的数组。
2. 属于函数调用。。 看程序应该从main看 main中应该有调用这个语句的时候 比如
int main (void)
int a=5,int array[10]=1,2,3,4,5,6,7,8,;
int number=0;
ssize_t read(a,array,number);
..........
for (XXXXXX)
看到 ssize_t read的时候就调用到你那个函数去了。。程序就去你那里运行了。。 后面的FOR 等你那里执行完毕后 接着运行。。
size_t 可以理解为 带符号的int型!!
FILE *fopen
也是和上面的函数调用一样。。不过返回值 是 *X,也就是指针...
先把基本语法搞定后,,再去看系统函数 就明白了。。大同小异。。。
系统编程前 先要精通C 这是一个必备的过程。。欲速则不达。。
看的出来。。自定义函数 指针 数组 结构体 堆栈。 链表 二叉树 您还是不太懂吧。。那么先从学习这个开始吧!!~~
学完这些 再去看系统函数 才算 如鱼得水。。 参考技术A 1. 当然是数组
#define PIPE_BUF 4096 /* # bytes in atomic write to a pipe */
PIPE_BUF只是一个宏而已
2.size_t read(int fd, void *buf, size_t count);
size_t是函数返回值,实际读取的字节数
int fd 是文件的句柄,相当于FILE* fp
void* buf是用来存储读取到的内容
size_t count是你打算读多少个字节
类似于函数
int fread(void *ptr, int size, int nitems, FILE *stream);
int fd 对应 FILE *stream
size_t count 对应 int size*int nitems
void* buf 对应 void *ptr
这两个函数的返回值意义一样
3FILE * fopen(const char * path,const char * mode);
FILE* 是C语言的啊,在windows下也有的啊!!
首先它是一个指针,指向你打开的那个文件
const char * path 是你要操作的文件的路径,如"c:\\1.txt"
const char * mode 是你要进行的操作,如"r"代表读取,"w"代表写入
... 参考技术B 2.6.11 之后, PIPE_BUF 被定义为65536
ssize_t 与size_t 类似, 只是必须是有符号数
FILE 是一个结构体, FILE 结构体内含有文件的相关信息, 像大小, 权限之类,只记得这么多了……
参数应该是要记住的
Linux系统C语言开发环境学习
Linux系统C语言开发环境学习
项目 | 内容 |
---|---|
这个作业属于哪个课程 | 2021春季Linux系统与应用 (南昌航空大学 - 信息工程学院) |
这个作业的要求在哪里 | 实验四 Linux系统C语言开发环境学习 |
学号-姓名 | 18041503-闵思思 |
作业学习目标 | (1)Linux系统下C语言开发环境搭建(2)学习Linux系统环境C语言开发过程 |
1.安装C语言开发环境
如果安装没有问题,接下来查看gcc的版本信息
查看make版本信息
如果上面没有问题,我们就可以使用gcc对C语言程序进行编译链接等操作
2.简单C语言练习
1)首先我们通过man命令查看帮助文档
如果我们不清楚一些命令的操作,我们可以通过man命令来查看帮助。如:man gcc
这里简单列出一些通过man命令查看gcc帮助文档的信息,man帮助文档通常都是英文的,大家可以安装中文的帮助文档,不过通常英文的要准确一点。
2)命令行模式简单C语言编译链接等操作
我们可以通过vim编辑器编写一个最简单的C语言程序,如写一个输出自己学号的程序。先创建一个文件夹,然后进入该新创建的文件夹。
我们输入完了源程序,接下来我们进行C语言程序编译的四个阶段,预编译,编译,汇编,链接
a) 预编译
我们可以用vim打开test.i文件来查看文件内容,也可以用命令来查看。
b)编译
同样的我们可以用vim打开test.s文件来查看内容,也可以用命令,如cat
因为预编译和编译得到的文件都是文本文件,所以我们可以用vim打开查看文件内容。
c) 汇编
这里生成的不是文本文件了,是二进制文件,我们可以通过objdump命令来反汇编该文件来分析文件内容
d)链接
可执行文件是二进制文件,同样需要用objdump命令来反汇编该文件分析文件内容
这里反汇编输出内容较多,我只截图main函数部分,大家可以与test.o反汇编的内容进行对比分析。
e)运行
3)多文件编译
我们在exp4文件夹下面再建一个文件夹mfc(multi-files compile)
在该文件夹下面创建5个文件,文件名分别如下:
每个文件的内容分别如下:
完成上面的代码输入,接下来我们进行编译,对于多文件编译,我们可以一次编译链接生成可执行文件,也可以分别编译每个C文件,最后再进行链接得到可执行文件。
请说明两种方法的区别?
第一种是一次编译链接直接生成可执行文件;第二种是先分别对每个文件进行编译生成目标文件,然后再进行链接生成可执行文件。
接下来我们编写一个简单的Makefile,通过make工具帮助我们进行编译。在当前文件夹编写一个Makefile文件
注意这里每个gcc以及最后的rm前面都是有一个tab
现在我们可以直接在终端输入make就可以进行编译链接操作
以上是关于linux系统 C语言编程的主要内容,如果未能解决你的问题,请参考以下文章