APUE-文件部分

文件IO

相关函数

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
// 返回的文件描述符一定是最小的未用描述符数值
// at函数从fd相对路径打开文件
// at函数可避免TOCTTOU错误
int open(const char *path, int oflag, ...);
int openat(int fd, const char *path, int oflag, ...);

// 等同于open(path, O_WRONLY|O_CREAT|O_TRUNC, mode);
int creat(const char *path, mode_t mode);

// 关闭文件的同时会释放文件上的所有记录锁
int close(int fd);

// 设置文件偏移量,只更改偏移量,不引起I/O操作
off_t lseek(int fd, off_t offset, int whence);

// 返回读/写字节数
ssize_t read(int fd, void *buf, size_t nbytes);
ssize_t write(int fd, void *buf, size_t nbytes);

// 相当于先lseek后read/write,但是是原子操作
ssize_t pread(int fd, void *buf, size_t nbytes, off_t offset);
ssize_t pwrite(int fd, void *buf, size_t nbytes, off_t offset);
阅读更多
UNP第三部分总结

第十二章 IPv4和IPv6

一图解释:

第十三章 守护进程和inetd

守护进程:在后台运行且不与任何终端关联的进程。

syslogd:这个守护进程创建Unix域数据报套接字绑定/dev/log,等待接受日志信息,不过推荐使用syslog函数。

阅读更多
UNP前两部分总结

既然意向是后台开发,理应看看网络编程相关的书籍,这方面经典书籍应该就是UNP了,花了一个多星期时间看完了前两部分,感觉上手不难,但是知识比较杂,底层API比较多,有很多坑要注意,所以先总结一下,注意,略过了SCTP相关内容

第一章 本书简介

这一章简单介绍了一下网络编程,并用timeclient和timeserver程序引入了后面要讲的基本知识,然后介绍了一些历史和标准,本书的示例等等。

值得学习的是包裹函数的思想,将可能发生错误的函数用另一个函数包起来,并在这个函数里处理那个函数可能发生的错误,可以一定程度上简化程序的编写,并且也有利于程序的维护。

习题里提到一点,不同TCP对数据的处理是不同的,应当做好把数据看做字节流来处理的准备,直至到达数据流末尾。

阅读更多
vim命令整理

开始接触Linux时便有听说vim,之后在学习Linux命令的过程中就把vim学了学,但是之后就没怎么用过vim了。直到前段时间学习shell脚本时,一直用vim在终端里写shell脚本,熟悉了一些基础的vim命令,感受到vim编辑代码的高效。

平心而论,我是懒得去把vim配置成IDE的,我还是离不开IDE的……不过在IDE中装个vim插件,同时享受vim编辑的高效和IDE的便捷,我觉得还是很好的,于是觉得自己该补补vim的命令了,特此整理:

vim有多种模式,默认进入是命令模式,之后按a,o,i,c,s等可以进入插入模式,或是按v进入可视模式。按ESC退出插入或可视模式,如果你不知道现在在干什么,按两下ESC能保证你退回到初始的命令模式。

阅读更多
从零开始机器学习

文章参考了浅谈机器学习基础从机器学习谈起什么是迁移学习神经网络入门聚类算法

机器学习的定义

作为机器学习领域的先驱,Arthur Samuel在 IBM Journal of Research and Development期刊上发表了一篇名为《Some Studies in Machine Learning Using the Game of Checkers》的论文中,将机器学习非正式定义为:“在不直接针对问题进行编程的情况下,赋予计算机学习能力的一个研究领域。”

而我认为机器学习是:我们在日常生活中,会遇到很多问题,大致分为两类,一类问题有确定的解法,比如说判断一个数是否是偶数,这种问题可以很清楚地用计算机编写程序并解决;另一类问题则没有固定的解法,比如说判断一个人说了什么,写了什么,因为这些问题的随机性很大,我们解决这些问题的方法,就是用大量的数据,采用一些训练方法,来训练计算机,使得计算机能够解决这些问题,而这个训练过程就称为机器学习。

阅读更多