linux程序设计——个人总结

linux程序设计——个人总结

    到今天为止,《linux程序设计》学习基本完毕了。从五月下旬開始接触linux,学习安装Ubuntu14.04,六月份開始学习《linux程序设计》,实习考试之余花费了足足快两个月的时间,看完大部分章节。敲了一些代码。 文章都在这里--linux程序设计。
    细致看过的章节:第一章入门、第二章shell程序设计、第三章文件操作、第四章linux环境、第七章数据管理、第八章MySQL、第九章开发工具、第十一章进程和信号量、第十二章POSIX线程、第十三章进程间通信:管道、第十四章信号量共享内存消息队列、第十五章套接字。
    没有细看的章节:第五章终端、第六章屏幕控制(curses)、第十章调试、第十六章X视窗、第十七章用Qt进行KDE编程、第十八章linux标准。
    在看 第一章第二章的时候,同一时候学习了《linux入门基础》的视频, 在这里--linux入门基础。
     第三章第四章看的有点枯燥。有些函数仅仅是给出了函数原型(比方有些系统调用函数)。后面的章节还是经经常使用到的。
     第七章数据管理介绍动态内存管理和文件锁定( 文件锁,区域锁定,死锁)

   
    第八章MySQL的一些基本的语法之前就有看过。主要新学习了如何使用C语言连接MySQL数据库訪问MySQL数据。
    第九章开发工具主要了解多文件编译和makefile语法。
    七月份主要就是学习进程信号量套接字这些新内容,还挺有意思的。


    第十一章进程和信号量fork函数复制父进程,exec替换进程,结合在一起就可创建新进程所需的一切。


    第十二章POSIX线程中子线程共享父线程的全局变量,文件描写叙述符等。

还介绍了相互排斥量和多线程。
    第十三章管道中介绍父进程和子进程的通信,父进程向管道中写入数据,子进程从管道中读取数据(由于创建新进程时,原先打开的文件描写叙述符扔将保持打开状态。
    第十四章信号量共享内存消息队列中介绍信号量PV操作,P(-1)挂起进程,V(+1)释放进程,共享内存把不同进程之间共享的内存安排为同一段物理内存,这样能够在不同进程之间传递数据。消息队列独立于发送和接收进程而存在,创建消息队列、加入消息到消息队列、从消息队列获取消息、控制消息队列完毕进程间的通信。


    第十五章套接字用于在计算机网络中的通信,套接字有点类似于管道,但套接字明白地将客户和server区分开。


    套接字通信的原理
    基于套接字系统的服务端:
    首先server程序使用socket创建一个套接字(类似于文件描写叙述符)
    然后使用bind给套接字命名。可是在命名之前必须给出套接字的标识符(这个标识符同意linux将进入的针对特定port号的连接转到正确的server进程,标识符是一个用于特定服务的port号)
    然后server进程就開始等待客户连接到这个命名套接字。
    listen的作用是创建一个监听队列并将用于存放来自客户的进入连接。
    accept的作用是server接收客户的连接。
    server调用accept时,它会创建一个与原有的命名套接字不同的新套接字。

这个新套接字仅仅用于与这个特定的客户进行通信。而命名套接字则被保留下来继续处理来自其它客户的连接。兴许的客户将在监听队列中等待,直到server再次准备就绪。
    基于套接字系统的client:
    首先客户程序使用socket创建一个未命名套接字
    然后将server的命名套接字作为一个地址来调用connect与server建立连接。
    一旦连接成功。就能够像使用底层的文件描写叙述符那样用套接字实现双向的数据通信。





你可能感兴趣的:(linux程序设计——个人总结)