页面“Org-mode”与“C基础”之间的差异

来自linux中国网wiki
(页面间的差异)
跳到导航 跳到搜索
 
→‎cp
 
第1行: 第1行:
  
Emacs 的 Org-mode 在一定程度上可以替代 OneNote,有些方面甚至更好
 
=pre=
 
  
[https://i.linuxtoy.org/docs/guide/ch32s05.html#id3156706 第 32 章 组织你的意念:Emacs org mode 事件]
+
 
 +
 +
good
 +
http://akaedu.github.io/book/
 +
 
 +
 
 +
[https://zhuanlan.zhihu.com/p/90971489 C语言编程学习必备的一些网站,干货收藏!]
 +
 
 +
[https://www.bilibili.com/video/BV17s411N78s/?spm_id_from=333.788.videocard.0 带你学C带你飞》]
 +
=如何学习C=
 +
 
 +
[https://blog.csdn.net/qwe6620692/article/details/88107248  学习C语言,如何看懂及掌握一个程序]
 +
 
 +
=2021学习C APUE=
 +
http://www.apuebook.com/
 +
 
 +
[https://www.zhihu.com/topic/19705459/hot UNIX环境高级编程(书籍)笔记什么都 有呀 ]
 +
 
 +
[https://www.zhihu.com/question/19939011 《UNIX环境高级编程》这本书怎么看?怎么学习]
 +
 
 +
 
 +
 
 +
==看法  ==
 +
第二章和第六章可以跳跳,回头看
 +
 
 +
7.中文版翻译有瑕疵,但是整体还是不错,不至于对阅读产生影响(信号量那章有细节问题,但是信号量那张和csapp第八章几乎重复)
 +
 
 +
首先,不要抱着一口气把这本书学完的心态去看。      尝试根据自己的兴趣,选择一个规模适当的开源项目,去阅读它的源代码。(例如我选择的就是一个小型的http服务器--Mongoose)当在某一方面发现自己有很多问题时,很希望去弄清楚时,这时候就可以去翻开手中的APUE,带着问题去阅读。这时候学习的效率必然比盲目地去看书更高,而且遗忘率也会降低。但是,仅仅读完是不够的。      很多时候,你看书的时候,会感觉自己看懂了,但是没过多久,又会发现自己忘了。或者,有时候你根本没看懂,而只是囫囵吞枣地看过去。所以,看完后,最好的方法就是写博客。尝试按照自己的理解以及逻辑,去将你学到的知识系统地阐述出来。这样,就算你以后忘了,再去翻翻博文,也能很快就捡起来。
 +
 
 +
十个最值得阅读学习的C开源项目代码
 +
 
 +
    Webbench
 +
    Tinyhttpd
 +
    cJSON
 +
    CMockery
 +
    Libev
 +
    Memcached
 +
    Lua
 +
    SQLite
 +
    UNIX v6
 +
    NETBSD
 +
 
 +
建议先看 >> Unix/Linux编程实践教程
 +
 
 +
https://book.douban.com/subject/1219329/
 +
 
 +
http://item.kongfz.com/book/32040616.html?push_type=2&min_price=57.00&utm_source=101004009001
 +
 
 +
https://detail.tmall.com/item.htm?spm=a1z10.1-b.w9858442-8055933095.4.fH3HiL&id=19729431809
 +
 
 +
[https://github.com/woai3c/recommended-books 常用计算机书的下载]
 +
 
 +
[https://blog.csdn.net/qwe6620692/article/details/88107248  学习C语言,如何看懂及掌握一个程序!]
 +
 
 +
[https://blog.51cto.com/chinalx1/2143904 十个经典的C开源项目代码]
 +
 
 +
[https://developer.51cto.com/art/201903/593703.htm 初学玩转C语言,这17个小项目收下不谢]
 +
 
 +
https://zhuanlan.zhihu.com/p/83185476
 +
 
 +
== tinyhttpd C 语言实现最简单的 HTTP 服务器 学习 ==
 +
 
 +
[https://www.shuzhiduo.com/A/ZOJPY9Ge5v/ tinyhttpd ------ C 语言实现最简单的 HTTP 服务器]
 +
 
 +
https://github.com/nengm/Tinyhttpd
 +
 
 +
[https://blog.csdn.net/baiwfg2/article/details/45582723  tinyhttpd源码详解]
 +
 
 +
[https://blog.csdn.net/konghhhhh/article/details/103752962  tinyhttp整理(一)]
 +
 
 +
[https://blog.csdn.net/weixin_30387663/article/details/99664160  tinyhttp源码阅读(注释)]
 +
 
 +
[https://juejin.cn/post/6870760453619122183  Tinyhttp源码分析及知识点总结 ]
 +
 
 +
[https://www.bilibili.com/video/BV1hy4y1C71M/?spm_id_from=333.788.videocard.1 b站 C/C++ tinyHttp服务器小项目及源码讲解1]
 +
 
 +
[https://blog.csdn.net/wwxy1995/article/details/99362666  tinyhttpd深入解析与源码剖析]
 +
 
 +
[https://blog.csdn.net/qq_40677350/article/details/90201758  Tinyhttpd-master 源码学习笔记1]
 +
 
 +
[https://blog.csdn.net/yzhang6_10/article/details/51534409  Tinyhttp源码分析]
 +
 
 +
[https://github.com/EZLippi/Tinyhttpd Tinyhttpd非官方镜像,Fork自sourceForge,仅供学习]
 +
 
 +
 
 +
 
 +
 
 +
[https://www.jianshu.com/p/18cfd6019296 tinyhttp源码分析]
 +
 
 +
我把一些核心代码和相应的注释贴在这里,如果你感兴趣全部,可以移步我的github。
 +
https://github.com/zhaozhengcoder/rebuild-the-wheel/tree/master/tinyhttpd
 +
 
 +
 
 +
[https://www.google.com/search?q=Tinyhttp+%E4%BB%A3%E7%A0%81%E5%AE%8C%E5%85%A8%E8%AE%B2%E8%A7%A3&newwindow=1&safe=active&sxsrf=ALeKk00sI_LE3rix9st768kTRNvSLADqfQ%3A1616990574286&source=hp&ei=blFhYIrjDoTcswW95aqACg&iflsig=AINFCbYAAAAAYGFffrh-H2QmmZeV5OlApkx5kRBpdYOT&oq=Tinyhttp+%E4%BB%A3%E7%A0%81%E5%AE%8C%E5%85%A8%E8%AE%B2%E8%A7%A3&gs_lcp=Cgdnd3Mtd2l6EANQ0QhY0Qhg2gpoAHAAeACAAQCIAQCSAQCYAQCgAQKgAQGqAQdnd3Mtd2l6&sclient=gws-wiz&ved=0ahUKEwiK0qGmz9TvAhUE7qwKHb2yCqAQ4dUDCAY&uact=5 Tinyhttp 代码完全讲解]
 +
 
 +
==Mongoose-基于C的Web服务器代码学习 ==
 +
 
 +
[https://www.jianshu.com/p/745c03a8864a Mongoose-基于C的Web服务器 介绍和使用]
 +
 
 +
 
 +
[https://blog.csdn.net/hnzwx888/article/details/84971205  Web服务器----mongoose]
 +
 
 +
https://github.com/cesanta/mongoose
 +
 
 +
[https://www.cnblogs.com/skynet/archive/2010/07/24/1784110.html Mongoose源码剖析:外篇之web服务器 ]
 +
 
 +
[https://blog.csdn.net/lixiaogang_theanswer/article/details/102753370  Mongoose-6.14源码剖析之基础篇]
 +
 
 +
== 我的笔记 ==
 +
apue.3e/include/apue.h
 +
=== chapter 1===
 +
[https://zhuanlan.zhihu.com/p/136700729 APUE读书笔记-01UNIX系统概述]
 +
 
 +
这是原文学不过是 Second Edition  firefox 放大 就可以看  找一下 第三版本吧 Third Edition
 +
https://vaqeteart.gitee.io/file_bed/shared/books/APUE2/toc.html
 +
 
 +
=understanding_unix_programming =
 +
 
 +
==chapter 2  who ==
 +
 
 
<pre>
 
<pre>
Emacs键盘命令的约定表示方法:
+
/* 再看一下书 非常 好的啦 
 +
who命令的实现过程是先打开一个系统文件UTMP_FILE,创建对应的格式struct utmpfd变量,读取数据到这个结构体中,作相应格式输出即可
 +
*/
 +
#include<stdio.h>
 +
#include<utmp.h>
 +
#include<fcntl.h>
 +
#include <time.h>
 +
#include<unistd.h>
 +
#define SHOWHOST
 +
void showtime(long);
 +
void showtime(long timeval){
 +
    char *cp;
 +
    cp = ctime(&timeval);
 +
    //cp[strlen(cp)-1]='\0';
 +
    printf("%s",cp+4 ); //wed jun 21:40:09  +4是因为*cp所指的一串字符前4个字符表示为“星期”,可以忽略此信息
 +
}
 +
// 指向结构体 utmp 的指针 utbufp
 +
void show_info(struct utmp *utbufp)
 +
{
 +
    printf("%-8.8s",utbufp->ut_name) ;
 +
    printf(" ");
 +
  printf("%-8.8s",utbufp->ut_line);
 +
  printf("");
 +
  printf("% 10ld",utbufp->ut_time );
 +
 
 +
  printf(" ");
 +
 
 +
  printf(" ");
 +
 
 +
}
 +
 
 +
int main()
 +
{
 +
  struct utmp current_record;
 +
  int  utmpfd;
 +
  int reclen = sizeof(current_record);
  
C 代表 Ctrl 键
+
  if (( utmpfd = open (UTMP_FILE, O_RDONLY)) == -1) {
M 代表 Alt 键
+
  perror(UTMP_FILE);
S 代表 Shift 键
+
  return 1;
以上三个按键单独按下没有意义,用 - 号表示它们搭配使用的按键
+
  }
用空格连接的一系列符号表示顺序按下符号所代表的按键
+
  while ( read(utmpfd, &current_record, reclen) == reclen )
其他符号: LEFT/RIGHT/UP/DOWN 分别代表的左右上下方向键, TAB 即 Tab 键, RET 代表 Enter 键
+
  show_info(&current_record);
例如:
+
  close(utmpfd);
C-x 表示同时按下Ctrl和x字符键
+
  return 0;
C-S-TAB 表示同时按下Ctrl, Shift和Tab键
+
 
M-x org-mode 表示先同时按下Alt和x字符键,再键盘输入org-mode字符串
+
}
C-x C-s 表示先同时按Ctrl和x字符键,然后同时按下Ctrl和s字符键
+
 
C-c C-e hh 表示先同时按Ctrl和c字符键,然后同时按下Ctrl和e字符键,最后键盘输入hh
+
 
 +
 
 +
 
 +
 
 +
 
 +
 
 +
 
 +
 
 +
 
 +
 
 +
 
 +
 
 +
 
 +
 
 +
 
 +
C 库函数 void *memset(void *str, int c, size_t n) 复制字符 c(一个无符号字符)到参数 str 所指向的字符串的前 n 个字符。
 +
memset(str,'$',7);
 +
 
 +
This is string.h library function
 +
$$$$$$$ string.h library function
 
</pre>
 
</pre>
  
=emacs-gtk=
+
参考 和书 chapter 2  这个最接近原书的了
 +
https://www.cnblogs.com/20145221GQ/p/6060420.html
 +
 
 +
https://www.runoob.com/cprogramming/c-function-memset.html
 +
===别人实现1===
 +
https://www.cnblogs.com/20145221GQ/p/6060420.html
 +
 
 +
https://gitee.com/20145221/linux-besti-is-2016-2017-1-20145221/blob/master/src/week09/who.c?dir=0&filepath=src%2Fweek09%2Fwho.c&oid=6ca54191e2a046c9de2e42cfc5eb895ff665b429&sha=6cd302d6cb4f0d36f667754e972ce63963483044#
 
<pre>
 
<pre>
让选中可以高亮
+
 
自己打开随便看下 居然就看到了 不错
+
#include <stdio.h> 
emacs-gtk --> Options --> customize emacs   --> custom themes   -->   个人感觉 adwaita 还不错
+
#include <utmp.h>
save theme settings
+
#include <fcntl.h> 
 +
#include <unistd.h> 
 +
#include <time.h> 
 +
#include <string.h>
 +
 
 +
#define SHOWHOST 
 +
 
 +
void showtime(long timeval){ 
 +
    char* cp; 
 +
    cp = ctime(&timeval); 
 +
    cp[strlen(cp)-1] = '\0';
 +
    printf("%s",cp+4); 
 +
 +
 
 +
void show_info(struct utmp* utbufp){ 
 +
    if(utbufp->ut_type != USER_PROCESS){ 
 +
        return ; 
 +
    }  
 +
 
 +
    printf("%-8.8s",utbufp->ut_name); 
 +
    printf(" "); 
 +
    printf("%-8.8s",utbufp->ut_line); 
 +
    printf(" "); 
 +
    showtime(utbufp->ut_time); 
 +
    printf(" "); 
 +
    
 +
#ifdef SHOWHOST 
 +
    if(utbufp->ut_host[0] != '\0'){ 
 +
        printf("(%s)",utbufp->ut_host); 
 +
    } 
 +
#endif 
 +
    printf("\n"); 
 +
}
 +
 
 +
int main(){ 
 +
    struct utmp current_record; 
 +
    int utmpfd; 
 +
    int reclen = sizeof(current_record); 
 +
    
 +
    if((utmpfd = open(UTMP_FILE,O_RDONLY)) == -1){ 
 +
        perror(UTMP_FILE); 
 +
 
 +
        return 1; 
 +
    } 
 +
 
 +
    while( read(utmpfd,&current_record,reclen) == reclen ){ 
 +
        show_info(&current_record); 
 +
    } 
 +
 
 +
    close(utmpfd); 
 +
    
 +
    return 0; 
 +
 +
 
 
</pre>
 
</pre>
 +
===see also===
 +
[https://blog.csdn.net/u010307522/article/details/72862589  who命令实现]
  
=install=
+
 
 +
===cp===
 +
[https://www.cnblogs.com/cxy1616/p/6063463.html cp命令的编写最接受原书的了]
 +
 
 +
[https://blog.csdn.net/hejishan/article/details/2250995  Unix程序设计:实现cp命令]
 +
 
 +
[https://blog.csdn.net/XSL1990/article/details/8250039 linux自己编写的 cp 命令像os的那个了 ]
 +
 
 +
http://bbs.chinaunix.net/thread-247946-1-1.html
 +
 
 +
=C IDE=
 +
 
 +
https://www.jetbrains.com/zh-cn/clion/
 +
 
 +
[[Eclipse]]
 +
 
 +
[[Anjuta on linux]]
 +
 
 +
https://atom.io/
 +
 
 +
=pre main =
 
<pre>
 
<pre>
Emacs 22 以后的版本已经集成了 org-mode,打开 .org 扩展的文件会自动进入 org 模式。
+
init main( int argc, char *argv[]);
vi  ~/.emacs #添加源
+
argc 是命令行参数的数目 也包括自身 没有后台的参数 那么 argc=1
(require 'package)
+
 
(add-to-list 'package-archives '("org" . "https://orgmode.org/elpa/") t)
+
argv 指向参数的各个指针所构成的数组, argv[0]表示命令本身,argv[1] 表示第一个参数
 +
看代码的时候我最先不理解的就是main函数的定义:
 +
 
 +
int main(int argc, char *argv[]){}
 +
 
 +
经查阅得知,argc是用来表示在命令行下输入命令时的参数个数,包括指令本身;argv[]是用来取得你输入的参数。针对具体指令分析如下(每一步解释由注释形式给出)。
 +
</pre>
 +
 
 +
=基础=
 +
 
 +
==计算机为什么要用二进制==
 +
Everything over Binary 模拟路转换成为数字电路
  
 +
https://blog.csdn.net/weixin_44296862/article/details/95277924
  
# 如果用老版本的emacs 或者你想安装
+
https://blog.csdn.net/c46550/article/details/90951557
Get it with M-x package-install RET org RET (
+
 
 +
[https://wenku.baidu.com/view/77074002e009581b6ad9eb2c.html 一位全加器]
 +
=== signed char 类型的范围为 -128~127===
 +
<pre>
 +
按八位来算:
 +
在计算机里面是用补码表示的,128的二进制码是:10000000,这个东西在计算里面并不是128,因为最高位是符号,它是个负数,那么负数的原码是多少呢,我们知道如果补码的符号位为“1”,表示是一个负数,求原码的操作可以是:符号位为1,其余各位取反,然后再整个数加1。
 +
所以,10000000取反后就是11111111,把符号位去了就是01111111再加1就是10000000就是-128了。
 +
其实你看-127是10000001,这个很好理解,-128加1不就是-127
 +
[https://blog.csdn.net/zy986718042/article/details/71699079 浅谈char类型范围]
 +
 
 +
补码表示时,-0和+0补码相同都是0 000 0000,所义导致可以多表示一个负数,...这个负数是最小的那个..
 
</pre>
 
</pre>
 +
[https://blog.csdn.net/czg13548930186/article/details/52602279?ops_request_misc=&request_id=&biz_id=102&utm_term=%25E6%25B5%2585%25E6%259E%2590%25E4%25B8%25BA%25E4%25BB%2580%25E4%25B9%2588char%25E7%25B1%25BB%25E5%259E%258B%25E7%259A%2584%25E8%258C%2583%25E5%259B%25B4%25E6%2598%25AF%2520%25E2%2580%2594128~%2520127&utm_medium=distribute.pc_search_result.none-task-blog-2~all~sobaiduweb~default-1-52602279.pc_search_result_no_baidu_js  浅析为什么char类型的范围是 —128~+127]
  
=进入Org模式=
+
 
 +
[https://wenwen.sogou.com/z/q871193299.htm?ch=fromnewwenwen.pc char 其数值表示 范围的计算]
 +
 
 +
[https://www.bilibili.com/video/BV1Gt4y1D73z?from=search&seid=13506202580160943636 b站 C语言数据类型及数值范围]
 +
 
 +
===原码 补码 反码 ===
 
<pre>
 
<pre>
 +
1.原码
 +
最高位表示符号位。剩下的位数,是这个数的绝对值的二进制
  
1. org作为后缀名
+
就比方说 一个完整的int型变量在内存中占的是4个字节,32位的编译器中 那么这时候他的二进制表示是00000000 00000000 00000000 00000000
2. 文件的第一个非空行包含: -*-org-*-
 
  
 +
所以
  
C-x C-f ~/test/test.org
+
10的原码就是00000000 00000000 00000000 00001010
  
1.打开后缀名为org的文件自动进入org-mode模式
+
那么负数的原码就是例如
2.在init.el配置文件中设置某类文件的编辑模式为org,如txt类文件:
 
  
      (add-to-list 'auto-mode-alist '("\\.txt\\'" . org-mode))
+
-10的原码10000000 00000000 00000000 00001010
  
3.用Emacs打开文件后使用主模式选择命令( M-x org-mode )
+
符号位是第一位 0为正数 1为负数
  
4.任意文件名,如果文件的第一个非空行包含: -*-org-*- ,用Emacs打开该文件后会自动使用org-mode模式。
+
2.反码
 +
    正数的反码就是其原码.
  
后面这种方式对于使用Emacs编辑程序文件尤其方便,无需改变文件的后缀名。
+
    负数的反码就是在其原码的基础之上 符号位不变,其他位取反.
 +
   
 +
3.补码
 +
 
 +
    正数的补码就是其原码.
 +
 
 +
    负数的补码就是在其反码的基础之上+1
 +
   
 
</pre>
 
</pre>
  
=TODO=
+
[https://www.cnblogs.com/wangxiaoqi/p/6419676.html  C语言中的原码、反码和补码 ]
 +
 
 +
[https://www.cnblogs.com/burningc/p/10741253.html  C语言之原码、反码和补码 ]
 +
 
 +
[https://blog.csdn.net/liuyangsyouxiang/article/details/6050525  C语言——源码、反码、补码]
 +
 
 +
[https://www.bilibili.com/video/BV1Wx411g7Jg/?spm_id_from=333.788.videocard.1 b站原码 反码 补码]
 +
 
 +
=gdb=
 
<pre>
 
<pre>
输入C-c . 会出现一个日历,我们点选相应的时间即可插入
 
  
*  待办事项(TODO )
 
  TODO是org-mode最具特色的一个功能,也是org-mode设计的初衷,org-mode的作者本意是用其来完成一个个人时间管理程序(GDT)。因此,可以用org-mode来做一个个人时间管理工具!   下面我们来看怎么写TODO。TODO 也是一类标题,因此也需要用*开头,在Emacs中输入 * 然后快捷键如下
 
C-c C-t 按照 无状态->TODO->DONE->无状态 的顺序更改任务状态
 
  
** TODO 洗衣服
 
可以看到当中的TODO变成了红色,我们讲光标移到该行,按C-c C-t,则发现TODO变成了DONE(这个序列可以自己定义,详见org-mode手册)。org-mode兼有了标题和列表的功能,也可以添加checkbox和完成进度,除此之外,还可以设计优先级。 我们输入:
 
  
*** TODO [# A] 任务1
+
start  st 开始执行程序,在main函数的第一条语句前面停下来
*** TODO [# B] 任务2
+
step      s  下一条语句,如果该语句为函数调用,则进入函数执行其中的第一条语句
*** TODO 总任务 [33%]
+
next    n  执行下一条语句,如果该语句为函数调用,不会进入函数内部执行(即不会一步步地调试函数内部语句)
**** TODO 子任务1
+
 
**** TODO 子任务2 [0%]
+
 
      - [-] subsub1 [1/2]
+
 
      - [ ] subsub2
+
 
      - [X] subsub3
+
 
    **** DONE 一个已完成的任务
 
  
一些常用操作如下: - C-c C-t 变换TODO的状态 - C-c / t以树的形式展示所有的 TODO - C-c C-c 改变 checkbox状态 - C-c, 设置优先级(方括号里的ABC) - M-S-RET 插入同级TODO标
 
</pre>
 
  
== 快速创建任务的操作==
 
<pre>
 
快捷键   功能                                           备注(return is enter)
 
  
M-<return> 在当前 headline 后建立一个同级 headline 无 headline 时创建一个一级 headline
 
  
M-S-return 在当前任务后建立一个同级任务,标记为TODO(好像无效) 同下 (这个试过有效)
+
使用例子  结合他看C代码 爽到不行了
C-S-return 在当前任务的内容后面建立一个同级任务,标记为TODO 无任务时创建一级任务,标记为TODO
+
184
 +
185gcc -g 11.2.c -o 11.2
 +
186gdb 11.2
 +
187
 +
188(gdb) start
 +
189(gdb) s  #一直用step命令(简写为s)进入函数中 ,n命令呢
 +
190
 +
191
 +
192step s  下一条语句,如果该语句为函数调用,则进入函数执行其中的第一条语句
 +
193next n  执行下一条语句,如果该语句为函数调用,不会进入函数内部执行(即不会一步步地调试函数内部语句)
  
 
</pre>
 
</pre>
  
==自定义状态序列 ==
+
=c=
 
<pre>
 
<pre>
如果只想在某个文件中为其设置独有的关键词序列,那么可以在org文件的头部用"#+SEQ_TODO"来进行设置:
 
  
;+SEQ_TODO: TODO DOING DONE
+
/*                                                                                                                                                                                         
 +
20答案是 Tuesday  因为列数定了是10                                                                                                                                                           
 +
21days[2] === days[2][10]                                                                                                                                                                   
 +
22                                                                                                                                                                                           
 +
23解说                                                                                                                                                                                       
 +
24days[2][0]=T                                                                                                                                                                               
 +
25days[2][1]=u                                                                                                                                                                               
 +
26days[2][2]=e                                                                                                                                                                               
 +
27days[2][3]=s                                                                                                                                                                               
 +
28days[2][4]=d                                                                                                                                                                               
 +
29days[2][5]=a                                                                                                                                                                               
 +
30days[2][6]=y                                                                                                                                                                               
 +
31days[2][7]=                                                                                                                                                                               
 +
32days[2][8]=                                                                                                                                                                               
 +
33days[2][9]=                                                                                                                                                                               
 +
34                                                                                                                                                                                           
 +
35               
 +
</pre>
 +
==eg ==
 +
=== 石头剪刀布===
 +
<pre>
 +
#include <stdio.h>
 +
#include <stdlib.h>
 +
#include <time.h>
  
;我的emacs 配置 .emacs
+
int main(void)
(setq org-todo-keywords '((sequence "TODO" "DOING" "DONE")))
+
{
(setq org-todo-keyword-faces '(("TODO" . "red")
+
char gesture[3][10] = { "scissor", "stone", "cloth" };
                              ("DOING" . "yellow")
+
int man, computer, result, ret;
                              ("DONE" . "green")))
 
  
 +
srand(time(NULL));
 +
while (1) {
 +
computer = rand() % 3;
 +
  printf("\nInput your gesture (0-scissor 1-stone 2-cloth):\n");
 +
ret = scanf("%d", &man);
 +
  if (ret != 1 || man < 0 || man > 2) {
 +
printf("Invalid input! Please input 0, 1 or 2.\n");
 +
continue;
 +
}
 +
printf("Your gesture: %s\tComputer's gesture: %s\n",
 +
gesture[man], gesture[computer]);
  
 +
result = (man - computer + 4) % 3 - 1;
 +
if (result > 0)
 +
printf("You win!\n");
 +
else if (result == 0)
 +
printf("Draw!\n");
 +
else
 +
printf("You lose!\n");
 +
}
 +
return 0;
 +
}
  
  
;去掉了 TODO
+
/*
(setq org-todo-keywords '((sequence  "DOING" "DONE")))
+
0、1、2三个整数分别是剪刀石头布在程序中的内部表示,用户也要求输入0、1或2,然后和计算机随机生成的0、1或2比胜负。这个程序的主体是一个死循环,需要按Ctrl-C退出程序。以往我们写的程序都只有打印输出,在这个程序中我们第一次碰到处理用户输入的情况。在这里只是简单解释一下,以后再细讲。scanf("%d", &man)这个调用的功能是等待用户输入一个整数并回车,这个整数会被scanf函数保存在man这个整型变量里。如果用户输入合法(输入的确实是整数而不是字符串),则scanf函数返回1,表示成功读入一个数据。但即使用户输入的是整数,我们还需要进一步检查是不是在0~2的范围内,写程序时对用户输入要格外小心,用户有可能输入任何数据,他才不管游戏规则是什么。
(setq org-todo-keyword-faces '(("DOING" . "red")("DONE" . "green")))
 
  
 +
和printf类似,scanf也可以用%c、%f、%s等转换说明。如果在传给scanf的第一个参数中用%d、%f或%c表示读入一个整数、浮点数或字符,则第二个参数的形式应该是&运算符加一个相应类型的变量名,表示读进来的数存到这个变量中;如果在第一个参数中用%s读入一个字符串,则第二个参数应该是数组名,数组名前面不加&,因为数组类型做右值时自动转换成指针类型,而scanf后面这个参数要的就是指针类型,在第 10 章 gdb有scanf读入字符串的例子。&运算符的作用也是得到一个指针类型,这个运算符以后再详细解释。
  
 +
留给读者的思考问题是:(man - computer + 4) % 3 - 1这个神奇的表达式是如何比较出0、1、2这三个数字在“剪刀石头布”意义上的大小的
 +
*/
  
 +
</pre>
  
</pre>
+
[https://wenku.baidu.com/view/55e520da5022aaea998f0f5e.html 石头剪刀布_C语言]
  
=基本语法=
+
https://blog.csdn.net/guoqingchun/article/details/8104197
除了 headline 外,Org mode 还支持列表、文字修饰(粗体、斜体、下划线等)、代码块、引用等常见的功能
 
  
[http://www.zmonster.me/2015/07/12/org-mode-introduction.html 强大的Org mode(1):简单介绍与基本使用]
 
  
==基本的任务管理==
+
===Linux下C语言获取目录中的文件列表 ===
 
<pre>
 
<pre>
快捷键         功能                                               备注
+
/*
C-c C-t       按照 无状态->TODO->DONE->无状态 的顺序更改任务状态 org-todo
+
* dir.c
Shift-<right> 同上  
+
*
Shift-<left> 按照与 Shift-<right> 相反的顺序更改任务状态
+
Linux下C语言获取目录中的文件列表  https://www.cnblogs.com/dgwblog/p/12158373.html
 +
http://c.biancheng.net/cpp/html/1548.html  怎样使用C语言列出某个目录下的文件?
 +
*  Created on: 2020年11月2日
 +
*      Author: evan
 +
*/
 +
#include <sys/types.h>
 +
#include <dirent.h>
 +
#include <unistd.h>
 +
#include <stdio.h>
 +
int main(){
 +
DIR *dir;
 +
struct dirent *ptr;
 +
dir = opendir("/home/evan/t1/");
 +
while((ptr = readdir(dir)) != NULL)
 +
printf("d_name:%s\n",ptr->d_name);
 +
closedir(dir);
 +
return 0;
 +
}
 +
 
 +
 
 +
/* 结果
 +
*
 +
d_name:.
 +
d_name:..
 +
d_name:1.py
 +
d_name:22.py
 +
 
 +
*/
 +
 
 +
 
 
</pre>
 
</pre>
  
[http://www.zmonster.me/2015/07/15/org-mode-planning.html 强大的Org mode(2):任务管理]
+
=排序与查找=
 +
==插入排序 ==
 +
<pre>
 +
#include <stdio.h>
 +
#define LEN 5
 +
int a[LEN] = { 10, 5, 2, 4, 7 };
 +
void insertion_sort(void)
 +
{
 +
int i, j, key;
 +
for (j = 1; j < LEN; ++j) {
 +
printf("%d, %d, %d, %d, %d\n",
 +
      a[0], a[1], a[2], a[3], a[4]);
 +
key = a[j];  //key 标记为未排序的第一个元素
 +
i = j - 1;
 +
                // key  与已排序元素从大到小比较,寻找key应插入的元素 a[i+1]一般就是key 起初的值
 +
////采用顺序查找方式找到插入的位置,在查找的同时,将数组中的元素进行后移操作,给插入元素腾出空间 ?
  
== 标题编辑==
+
while (i >= 0 && a[i] > key) {
<pre>
+
a[i+1] = a[i];
M-S-LEFT/RIGHT 升级/降级标题树,即标题树内的各级标题相应升/降级
+
--i; //跳出while
 +
}
 +
a[i+1] = key; ////插入到正确位置
 +
}
 +
printf("%d, %d, %d, %d, %d\n",
 +
      a[0], a[1], a[2], a[3], a[4]);
 +
}
 +
int main(void)
 +
{
 +
insertion_sort();
 +
return 0;
 +
}
 +
/* 就是key 一直和前面排好的比,找到正确的位置
 +
10, 5, 2, 4, 7
 +
5, 10, 2, 4, 7
 +
2, 5, 10, 4, 7
 +
2, 4, 5, 10, 7
 +
2, 4, 5, 7, 10 */  
 
</pre>
 
</pre>
  
https://blog.csdn.net/u014801157/article/details/24372485
 
  
== org 图片==
+
===算法的时间复杂度分析===
<pre>
+
则总的执行时间粗略估计是(n-1)*(c1+c2+c5+m*(c3+c4))。 #怎么来的呢  线性函数  不记得了 要补一下
 +
 
 +
[https://blog.csdn.net/qq_25775935/article/details/88724130 插入排序算法及C语言实现]
 +
 
 +
 
 +
==11.4 归并排序==
 +
递归实现 归并排序
 +
 
 +
 
 +
 
 +
 
 +
===see also===
  
相对路径方便些
 
file:~/lx/emimg/gen.png
 
  
[file://home/evan/wallpaper/f.jpg]
+
还有下一节 ?
填写地址时 要先写 [[    最后再  ]] 不过显示时就没了 ,还有 记得有快捷 键 有空找找 ctrl+l 什么来着
 
  
 +
[https://www.bilibili.com/video/av73101599?from=search&seid=6748303640916868853 4-5 通过归并排序算法深入理解递归]
  
  
C-c C-x C v  快捷键
+
非递归
 +
https://blog.csdn.net/zjy900507/article/details/80530336
  
国 外强大的表达
+
=chapter 12 栈与队列=
an image without description
+
==堆栈==
[[file:/tmp/image.png]]
+
http://docs.linuxtone.org/ebooks/C&CPP/c/ch12s02.html
 +
==3. 深度优先搜索 ==
 +
未看
 +
http://akaedu.github.io/book/ch12s03.html
  
an image with description
 
[[file:/tmp/image.png][my description]]
 
  
emacs gui 
+
=第 13 章 计算机中数的表示=
 +
==1. 为什么计算机用二进制计数==
  
alt+x  org-toggle-inline-images  回车就显示了  ,cli  下好像是不显示的  要images 什么的支持吧
+
=第 14 章 计算机中数的表示=
不过一般不用命令而是用快快捷 键
 
 
 
  
显示图片 快键
+
[http://c.biancheng.net/cpp/html/437.html c语言基本数据类型short、int、long、char、float、double]
You can run the command ‘org-toggle-inline-images’ with C-c C-x C-v
 
152 images displayed inline
 
  
中文表达如下
+
[https://www.cnblogs.com/luofay/p/6070613.html  C语言的基本数据类型 ]
使用如下标签插入图片,使用C-c C-x C-v inline方式显示图片,或者使用C-c C-o打开链接。
 
[[file:a.png]]
 
  
#添加到 .emacs ; iimage-mode 听说现在是内置的了  不用什么 iimage.el了
 
;; 显示图片
 
(auto-image-file-mode t)
 
(defun do-org-show-all-inline-images ()
 
  (interactive)
 
  (org-display-inline-images t t))
 
(global-set-key (kbd "C-c C-x C v")
 
                'do-org-show-all-inline-images)
 
  
</pre>
+
[https://www.php.cn/csharp-article-443107.html c语言char是什么意思]
===TODO Capture the image===
+
== 二进制制转十进制==
 
<pre>
 
<pre>
: ;; screenshot in org-mode
+
在 C 语言中, signed char 类型的范围为 -128~127,每本教科书上也这么写,但是没有哪一本书上(包括老师)也不会给你为什么是 -128~127,这个问题貌似看起来也很简单容易, 以至于不用去思考为什么,不是有一个整型范围的公式吗:  -2^(n-1)~2^(n-1)-1 (n为整型的内存占用位数),所以 int 类型 32 位那么就是 -(2^31) ~ 2^31-1 即 -2147483648~2147483647,但是为什么最小负数绝对值总比最大正数多 1 ,这个问题甚至有的工作几年的程序员都模棱两可,因为没有深入思考过,只知道书上这么写。于是,我不得不深入思考一下这个被许多人忽视的问题。
: ;; modified by [email protected]
 
: ;; based on [http://praktikanten.brueckenschlaeger.org/2010/11/28/screenshots-in-org-mode]
 
: (defun my-screenshot ()
 
: "Take a screenshot into a unique-named file in the current buffer file
 
: directory and insert a link to this file."
 
: (interactive)
 
: (setq filename
 
: (concat (make-temp-name
 
: (concat (file-name-directory (buffer-file-name)) "images/" ) ) ".png"))
 
: (if (file-accessible-directory-p (concat (file-name-directory
 
(buffer-file-name)) "images/"))
 
: nil
 
: (make-directory "images"))
 
: (call-process-shell-command "scrot" nil nil nil nil "-s" (concat
 
"\"" filename "\"" ))
 
: (insert (concat "[[" filename "]]"))
 
: (org-display-inline-images)
 
: )
 
:
 
: (global-set-key (kbd "s-s") 'my-screenshot)
 
  
 +
对于无符号整数,很简单,全部位都表示数值,比如 char 型,8位,用二进制表示为 0000 0000 ~ 1111 1111,1111 1111 最大即为十进制255,所以 unsigned char 的范围为 0~ 255,在这里普及一下 2 进制转十进制的方法, 二进制每一位的数值乘以它的位权(2^(n-1),n为自右向左的位),再相加,可得到十进制数,比如 :1111 1111 = 1*2^7 + 1*2^6 + 1*2^5 + 1*2^4 + 1*2^3 + 1*2^2 + 1*2^1 + 1*2^0 = 255 。
  
使用说明
 
按win-s键,然后用鼠标划要截屏的范围。这一部分会保存在当前org文件的目录下的images目录下,文件名随机。如果该目录不存在,会自动建立。
 
  
依赖; scrot 0.8-11 command line screen capture utility
+
但是对于有符号整数,二进制的最高位表示正负,不表示数值,最高位为 0 时表示正数,为 1 时表示负数,这样一来,能表示数值的就剩下( n-1 )位了,
 +
比如 char a = -1;   那么二进制表示就为 1 0000001,1 表示为 0 0000001,所以 signed char 型除去符号位剩下的 7 位最大为 1111 111 = 127,再把符号加上,0 1111111 = 127,1 1111111 = -127,范围应该为 -127~127 ,同理 int 类型也一样,但是问题出来了,教科书上是 -128~127 啊,下面就剖析一下这个惊人的奇葩。 加上反码 看到这里
  
 +
 +
再普及一下计算机内部整数存储形式,大家都知道计算机内部是以二进制来存贮数值的,无符号整数会用全部为来存储,有符号的整数,最高位当做符号位 ,其余为表示数值。
 
</pre>
 
</pre>
=== 图片进阶===
 
  
[https://wiki.dreamrunner.org/public_html/Emacs/org-mode.html org-mode and Worg]
+
=第 17 章=
 +
==3. 设备==
 +
http://akaedu.github.io/book/ch17s03.html
 +
 
 +
=4. MMU=
 +
按照离CPU由近到远的顺序依次是CPU寄存器、Cache、内存、硬盘,越靠近CPU的存储器容量越小但访问速度越快
 +
http://akaedu.github.io/book/ch17s04.html
 +
 
 +
=Memory Hierarchy=
 +
http://akaedu.github.io/book/ch17s05.html
 +
 
 +
=附录 A. 字符编码=
 +
20191112
 +
字符编码的高位 左边是也
 +
 
 +
=如何学习c=
 +
 
 +
== mongoose 开源http库==
 +
有空学习这个作为C的入门例子
 +
 
 +
Mongoose是一个用C编写的网络库。它为客户端和服务器模式实现TCP,UDP,HTTP,WebSocket,CoAP,MQTT的事件驱动的非阻塞API。
 +
[https://www.cnblogs.com/gardenofhu/p/6961343.html  mongoose 开源http库 ]
 +
 
 +
[https://www.cnblogs.com/lifan3a/articles/7478295.html Mongoose 利用实现HTTP服务 ]
 +
=funciton=
 +
==strcmp  ==
 +
<pre>
 +
C/C++函数,比较两个字符串
  
 +
strcmp函数是string compare(字符串比较)的缩写,用于比较两个字符串并根据比较结果返回整数
  
[https://www.cnblogs.com/tigertnt/archive/2013/04/28/3050117.html 截屏并插入图片]
+
设这两个字符串为str1,str2,
  
[https://stackoverflow.com/questions/9780124/insert-image-into-text-buffer insert image into text buffer]
+
若str1==str2,则返回零;
  
[https://www.cnblogs.com/yangwen0228/p/6287455.html 使用Emacs中的org-mode写cnblogs之图片插]
+
若str1<str2,则返回负数;
  
==插入源代码==
+
若str1>str2,则返回正数。
 +
</pre>
 +
[https://baike.baidu.com/item/strcmp/5495571 strcmp]
 +
 
 +
https://baike.so.com/doc/61175-64376.html
 +
==C library function - remove()==
 
<pre>
 
<pre>
 +
/*
 +
* remvoe.c
 +
*
 +
*  Created on: 2020年11月30日
 +
*      Author: evan
 +
*/
 +
#include <stdio.h>
 +
#include<string.h>
  
手工插入代码块  只有 shell  标识符 为sh 其它常见都一样
+
int main() {
 +
int ret;
 +
FILE *fp;
 +
char filename[] = "file.txt";  // 这个是什么意思  定义一个 数组 ? 是的 
  
#+BEGIN_SRC sh
+
fp = fopen(filename,"w");
youshell
 
#+END_SRC
 
  
org-mode除了可以直接插入源代码之外,可以直接求出运行结果,这也是其强大之处,在使用之前,需要在.emacs配置文件中设置加载的运行语言:
+
fprintf(fp,"%s", "THis is tutor \n");
 +
fprintf(fp,"%s", "ln2 THis is tutor");
 +
fclose(fp);
  
(org-babel-do-load-languages
+
//ret = remove(filename);
'org-babel-load-languages
+
/*
'(
+
cat file.txt
  (sh . t)
+
THis is tutor*/
  (python . t)
 
  (R . t)
 
  (ruby . t)
 
  (ditaa . t)
 
  (dot . t)
 
  (octave . t)
 
  (sqlite . t)
 
  (perl . t)
 
  (C . t)
 
  ))
 
  
设置好之后输入:
+
if(ret == 0) {
# +BEGIN_SRC emacs-lisp
+
printf("file deleted successfully");
(+ 1 2 3 4)
+
}else {
# +END_SRC
+
printf("Error: unable to delte the file");
 +
}
 +
return(0);
  
将光标移到代码块内,按C-c C-c,org-mode会自动添加如下一行:
+
}
  
# +RESULTS:
 
: 10
 
  
这正是该代码的计算结果。下面试一试Python代码:
+
</pre>
  
# +BEGIN_SRC python :results output
+
== C语言perror函数的作用 ==
a = 1+1
+
<pre>
print a
+
 不可以掉了这个头文件,perror是包含在这个文件里的//编辑本段perror表头文件完善版定义函数
# +END_SRC
+
  void perror(const char *s); perror ("open_port");
 +
函数说明
 +
  perror ( )用 来 将 上 一 个 函 数 发 生 错 误 的 原 因 输 出 到 标 准 设备 (stderr) 。参数 s 所指的字符串会先打印出,后面再加上错误原因字符串。此错误原因依照全局变量errno 的值来决定要输出的字符串。   在库函数中有个errno变量,每个errno值对应着以字符串表示的错误类型。当你调用"某些"函数出错时,该函数已经重新设置了errno的值。perror函数只是将你输入的一些信息和现在的errno所对应的错误一起输出。
  
# +RESULTS:
+
void perror(const char *str)
: 2
 
  
下面测试一下C语言
+
参数
  
# +begin_src C++ :includes <stdio.h>
+
    str -- 这是 C 字符串,包含了一个自定义消息,将显示在原本的错误消息之前
  int a=1;
 
  int b=1;
 
  printf("%d\n", a+b);
 
# +end_src
 
  
# +RESULTS:
+
#include <stdio.h>   
: 2
+
int main(void)   
 +
{   
 +
FILE *fp ;   
 +
fp = fopen( "/root/noexitfile", "r+" );   
 +
if ( NULL == fp )  ?
 +
{   
 +
perror("/root/noexitfile");   //下面有这个输出
 +
}   
 +
return 0;   
 +
}
  
常用快捷键: - C-c C-c 对当前代码块求值
+
运行结果
 +
[root@localhost io]# gcc perror.c   
 +
[root@localhost io]# ./a.out   
 +
/root/noexitfile: No such file or directory
  
 
</pre>
 
</pre>
  
[http://wenshanren.org/?p=327 Emacs:在 org-mode 中插入源代码块]
 
  
=进阶=
 
[https://emacs-china.org/t/org-mode-site/13874  Org Mode 生成静态站点 Site]
 
  
[https://zhuanlan.zhihu.com/p/80133952 神之编辑器 -- Emacs]
+
[https://blog.csdn.net/ypist/article/details/7886209  linux下 C语言perror函数的作用]
  
==写博客==
+
https://www.cnblogs.com/yujianfei/p/8973867.html
现在有网站已经支持org-mode格式(比如github),有些只支持markdown格式,不过这个根部不是问题,Emacs可以一键将org-mode 转为 markdown 格式文件
 
  
 +
https://www.runoob.com/cprogramming/c-function-perror.html
  
==IRC 通讯:==
 
最好用的IRC客户端,绝对是Emacs下的ERC,通过可扩展接口,你可以完成你想要的功能,自动回复,自动翻译,等等
 
  
RSS阅读器: 订阅你收集的网站,使用Emacs操作模式,来更舒服的浏览内容
+
==c语言实现rm命令 or 删除==
Latex完美支持: 绝对是你写论文时的一大神器,严格的排版格式,完美的公式显示
+
<pre>
翻译软件,语音朗读: 一键翻译你想要翻译的单词或句子,不用再切换到其它窗口,或者鼠标点点点(我是个键盘控,几乎很少使用鼠标)
+
头文件:#include <stdio.h>
煮咖啡,玩游戏,这些Emacs都可以做到
 
听音乐: 使用mplayer作后端,emacs作前端来听音乐,同样是一件很舒服的事情,全键盘控制音乐列表,快速搜索,暂停,下一首,随机播放,等等,只有你想不到,没有做不到。
 
  
=see aslo=
+
remove()函数用于删除指定的文件,其原型如下:
 +
    int remove(char * filename);
  
[https://blog.csdn.net/u014801157/article/details/24372485 Emacs月月积累(终结篇):熟练使用org-mode管理日常事务]
+
【参数】filename为要删除的文件名,可以为一目录。如果参数filename 为一文件,则调用unlink()处理;若参数filename 为一目录,则调用rmdir()来处理。
  
[https://changelog.complete.org/archives/tag/emacs2018 Emacs #5: Documents and Presentations with org-mode]
+
【返回值】成功则返回0,失败则返回-1,错误原因存于errno。
 +
</pre>
  
[http://fuzihao.org/blog/2015/02/19/org-mode%E6%95%99%E7%A8%8B/ org-mode入门教程 ]
+
[https://blog.csdn.net/teleger/article/details/80537229?utm_medium=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-1.pc_relevant_is_cache&depth_1-utm_source=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-1.pc_relevant_is_cache  C语言remove()函数:删除文件或目录]
  
[https://i.linuxtoy.org/docs/guide/ch32s03.html#id3155525 第 32 章 组织你的意念:Emacs org mode]
+
[https://blog.csdn.net/piaoliangjinjin/article/details/80707139?utm_medium=distribute.pc_relevant.none-task-blog-title-7&spm=1001.2101.3001.4242  linux下实现rm()函数删除文件或目录]
  
[http://www.zmonster.me/2015/07/12/org-mode-introduction.html 强大的Org mode(1):简单介绍与基本使用]
+
[https://blog.csdn.net/qq_38074673/article/details/98047329  c语言实现rm命令,删除指定文件或目录]
  
[https://i.linuxtoy.org/docs/guide/ch32s03.html#id3155525 Emacs org mode]
+
==C语言access()函数:判断是否具有存取文件的权限==
  
[https://www.cnblogs.com/qlwy/archive/2012/06/15/2551034.html#sec-1 神器中的神器org-mode之入门篇]
 
  
[http://www.cnblogs.com/Open_Source/archive/2011/07/17/2108747.html Org-mode 简明手册]
+
[http://c.biancheng.net/cpp/html/303.html C语言access()函数:判断是否具有存取文件的权限]
  
[http://www.cnblogs.com/holbrook/archive/2012/04/12/2444992.html org-mode: 最好的文档编辑利器,没有之一]
+
[https://blog.csdn.net/eager7/article/details/8131169  C语言中access函数]
  
[https://www.jianshu.com/p/32501603970d 用1天快速上手org-mode]
+
[https://www.runoob.com/cprogramming/c-arrays.html C 数组]
  
[https://emacs-china.org/t/org-mode/204 如何使用 Org-mode 来计划一天的工作]
 
  
[http://fuzihao.org/blog/2015/02/19/org-mode%E6%95%99%E7%A8%8B/ org-mode入门教程]
+
=进阶=
 
+
==十个经典的C开源项目代码==
[http://www.cnblogs.com/holbrook/archive/2012/04/14/2447754.html Org-mode,最强的任务管理利器,没有之一]
+
[https://blog.51cto.com/chinalx1/2143904 十个经典的C开源项目代码]
  
  
[https://phower.me/project/500/460731605/ 使用Org-Mode&Git-Hook自动部署Wiki]
+
=2021=
  
https://ox-hugo.scripter.co/
 
  
 +
[https://www.cnblogs.com/wucongzhou/p/12498740.html#%E4%B8%80%E3%80%81%E8%8E%B7%E5%8F%96%E5%BD%93%E5%89%8D%E5%B7%A5%E4%BD%9C%E7%9B%AE%E5%BD%95 C语言目录操作]
  
[http://www.cnblogs.com/holbrook/archive/2012/04/17/2454619.html 用Org-mode实现GTD]
+
[http://www.freecplus.net C语言技术网]
  
[https://blog.csdn.net/u011729865/article/details/54236547 spacemacs org-mode配置GTD]
+
[https://www.cnblogs.com/qigaohua/p/5838263.html      博客园  C语言中关于对目录的操作 ]
  
[https://emacs-china.org/t/topic/5013/10 一个实际可用的 org-mode 轻度GTD 方案]
+
=书=
 +
[https://www.codetd.com/article/2162329 《Linux环境C程序设计(第2版)徐诚》pdf 附下载链接]
  
 +
http://www.txtepub.com/105693.html
  
[https://linux.cn/article-10340-1.html Emacs 系列(五):Org 模式之文档与演示稿 ]
+
=see also=
 +
[https://wiki.ubuntu.com.cn/C%E8%AF%AD%E8%A8%80%E7%AE%80%E8%A6%81%E8%AF%AD%E6%B3%95%E6%8C%87%E5%8D%97 C语言简要语法指南]
  
 +
https://wiki.ubuntu.com.cn/Compiling_C
  
[http://smallzhan.github.io/emacs/2018/05/30/p-org-mode-orgbabel.html Org mode 和 Org-babel 的那些事(二)]
+
[https://wiki.ubuntu.com.cn/Gcchowto Gcc-howto]
  
[https://zh.wikipedia.org/wiki/Org-%E6%A8%A1%E5%BC%8F org-mode meawiki]
+
=c++=
  
[https://www.zhihu.com/question/19851600/answer/17893051 Org-mode、reST、 Markdown 各有什么优缺点]
+
[https://zh.wikipedia.org/wiki/C%2B%2B c++ zh.wikipedia.org]
  
[[category:emacs]]
+
https://isocpp.org/
 +
[[category:c]]

2021年4月6日 (二) 12:18的版本



good http://akaedu.github.io/book/


C语言编程学习必备的一些网站,干货收藏!

带你学C带你飞》

如何学习C

学习C语言,如何看懂及掌握一个程序

2021学习C APUE

http://www.apuebook.com/

UNIX环境高级编程(书籍)笔记什么都 有呀

《UNIX环境高级编程》这本书怎么看?怎么学习


看法

第二章和第六章可以跳跳,回头看

7.中文版翻译有瑕疵,但是整体还是不错,不至于对阅读产生影响(信号量那章有细节问题,但是信号量那张和csapp第八章几乎重复)

首先,不要抱着一口气把这本书学完的心态去看。 尝试根据自己的兴趣,选择一个规模适当的开源项目,去阅读它的源代码。(例如我选择的就是一个小型的http服务器--Mongoose)当在某一方面发现自己有很多问题时,很希望去弄清楚时,这时候就可以去翻开手中的APUE,带着问题去阅读。这时候学习的效率必然比盲目地去看书更高,而且遗忘率也会降低。但是,仅仅读完是不够的。 很多时候,你看书的时候,会感觉自己看懂了,但是没过多久,又会发现自己忘了。或者,有时候你根本没看懂,而只是囫囵吞枣地看过去。所以,看完后,最好的方法就是写博客。尝试按照自己的理解以及逻辑,去将你学到的知识系统地阐述出来。这样,就算你以后忘了,再去翻翻博文,也能很快就捡起来。

十个最值得阅读学习的C开源项目代码

   Webbench
   Tinyhttpd
   cJSON
   CMockery
   Libev
   Memcached
   Lua
   SQLite
   UNIX v6
   NETBSD

建议先看 >> Unix/Linux编程实践教程

https://book.douban.com/subject/1219329/

http://item.kongfz.com/book/32040616.html?push_type=2&min_price=57.00&utm_source=101004009001

https://detail.tmall.com/item.htm?spm=a1z10.1-b.w9858442-8055933095.4.fH3HiL&id=19729431809

常用计算机书的下载

学习C语言,如何看懂及掌握一个程序!

十个经典的C开源项目代码

初学玩转C语言,这17个小项目收下不谢

https://zhuanlan.zhihu.com/p/83185476

tinyhttpd C 语言实现最简单的 HTTP 服务器 学习

tinyhttpd ------ C 语言实现最简单的 HTTP 服务器

https://github.com/nengm/Tinyhttpd

tinyhttpd源码详解

tinyhttp整理(一)

tinyhttp源码阅读(注释)

Tinyhttp源码分析及知识点总结

b站 C/C++ tinyHttp服务器小项目及源码讲解1

tinyhttpd深入解析与源码剖析

Tinyhttpd-master 源码学习笔记1

Tinyhttp源码分析

Tinyhttpd非官方镜像,Fork自sourceForge,仅供学习



tinyhttp源码分析

我把一些核心代码和相应的注释贴在这里,如果你感兴趣全部,可以移步我的github。 https://github.com/zhaozhengcoder/rebuild-the-wheel/tree/master/tinyhttpd


Tinyhttp 代码完全讲解

Mongoose-基于C的Web服务器代码学习

Mongoose-基于C的Web服务器 介绍和使用


Web服务器----mongoose

https://github.com/cesanta/mongoose

Mongoose源码剖析:外篇之web服务器

Mongoose-6.14源码剖析之基础篇

我的笔记

apue.3e/include/apue.h

chapter 1

APUE读书笔记-01UNIX系统概述

这是原文学不过是 Second Edition firefox 放大 就可以看 找一下 第三版本吧 Third Edition https://vaqeteart.gitee.io/file_bed/shared/books/APUE2/toc.html

understanding_unix_programming

chapter 2 who

/* 再看一下书 非常 好的啦  
who命令的实现过程是先打开一个系统文件UTMP_FILE,创建对应的格式struct utmpfd变量,读取数据到这个结构体中,作相应格式输出即可
*/
#include<stdio.h>
#include<utmp.h>
#include<fcntl.h>
#include <time.h>
#include<unistd.h>
#define SHOWHOST
void showtime(long);
void showtime(long timeval){
    char *cp;
    cp = ctime(&timeval);
    //cp[strlen(cp)-1]='\0';
    printf("%s",cp+4 ); //wed jun 21:40:09  +4是因为*cp所指的一串字符前4个字符表示为“星期”,可以忽略此信息
}
// 指向结构体 utmp 的指针 utbufp
void show_info(struct utmp *utbufp)
{
    printf("%-8.8s",utbufp->ut_name)	;
    printf(" ");
  printf("%-8.8s",utbufp->ut_line);
  printf("");
  printf("% 10ld",utbufp->ut_time );

  printf(" ");

  printf(" ");

}

int main()
{
   struct utmp current_record;
   int  utmpfd;
   int reclen = sizeof(current_record);

   if (( utmpfd = open (UTMP_FILE, O_RDONLY)) == -1) {
	   perror(UTMP_FILE);
	   return 1;
   }
   while ( read(utmpfd, &current_record, reclen) == reclen )
	   show_info(&current_record);
   close(utmpfd);
   return 0;

}
















C 库函数 void *memset(void *str, int c, size_t n) 复制字符 c(一个无符号字符)到参数 str 所指向的字符串的前 n 个字符。
memset(str,'$',7);

This is string.h library function
$$$$$$$ string.h library function

参考 和书 chapter 2 这个最接近原书的了 https://www.cnblogs.com/20145221GQ/p/6060420.html

https://www.runoob.com/cprogramming/c-function-memset.html

别人实现1

https://www.cnblogs.com/20145221GQ/p/6060420.html

https://gitee.com/20145221/linux-besti-is-2016-2017-1-20145221/blob/master/src/week09/who.c?dir=0&filepath=src%2Fweek09%2Fwho.c&oid=6ca54191e2a046c9de2e42cfc5eb895ff665b429&sha=6cd302d6cb4f0d36f667754e972ce63963483044#


#include <stdio.h>  
#include <utmp.h>
#include <fcntl.h>  
#include <unistd.h>  
#include <time.h>  
#include <string.h>
  
#define SHOWHOST  
  
void showtime(long timeval){  
    char* cp;  
    cp = ctime(&timeval);  
    cp[strlen(cp)-1] = '\0';
    printf("%s",cp+4);  
}  
  
void show_info(struct utmp* utbufp){  
    if(utbufp->ut_type != USER_PROCESS){  
        return ;  
    }  
  
    printf("%-8.8s",utbufp->ut_name);  
    printf(" ");  
    printf("%-8.8s",utbufp->ut_line);  
    printf(" ");  
    showtime(utbufp->ut_time);  
    printf(" ");  
  
#ifdef SHOWHOST  
    if(utbufp->ut_host[0] != '\0'){  
        printf("(%s)",utbufp->ut_host);  
    }  
#endif  
    printf("\n");  
}

int main(){  
    struct utmp current_record;  
    int utmpfd;  
    int reclen = sizeof(current_record);  
  
    if((utmpfd = open(UTMP_FILE,O_RDONLY)) == -1){  
        perror(UTMP_FILE);  
  
        return 1;  
    }  
  
    while( read(utmpfd,&current_record,reclen) == reclen ){  
        show_info(&current_record);  
    }  
  
    close(utmpfd);  
  
    return 0;  
}  

see also

who命令实现


cp

cp命令的编写最接受原书的了

Unix程序设计:实现cp命令

linux自己编写的 cp 命令像os的那个了

http://bbs.chinaunix.net/thread-247946-1-1.html

C IDE

https://www.jetbrains.com/zh-cn/clion/

Eclipse

Anjuta on linux

https://atom.io/

pre main

 init main( int argc, char *argv[]);
argc 是命令行参数的数目 也包括自身 没有后台的参数 那么 argc=1

argv 指向参数的各个指针所构成的数组, argv[0]表示命令本身,argv[1] 表示第一个参数
看代码的时候我最先不理解的就是main函数的定义:

int main(int argc, char *argv[]){}

经查阅得知,argc是用来表示在命令行下输入命令时的参数个数,包括指令本身;argv[]是用来取得你输入的参数。针对具体指令分析如下(每一步解释由注释形式给出)。

基础

计算机为什么要用二进制

Everything over Binary 模拟路转换成为数字电路

https://blog.csdn.net/weixin_44296862/article/details/95277924

https://blog.csdn.net/c46550/article/details/90951557

一位全加器

signed char 类型的范围为 -128~127

 按八位来算:
在计算机里面是用补码表示的,128的二进制码是:10000000,这个东西在计算里面并不是128,因为最高位是符号,它是个负数,那么负数的原码是多少呢,我们知道如果补码的符号位为“1”,表示是一个负数,求原码的操作可以是:符号位为1,其余各位取反,然后再整个数加1。 
所以,10000000取反后就是11111111,把符号位去了就是01111111再加1就是10000000就是-128了。
其实你看-127是10000001,这个很好理解,-128加1不就是-127
[https://blog.csdn.net/zy986718042/article/details/71699079 浅谈char类型范围]

补码表示时,-0和+0补码相同都是0 000 0000,所义导致可以多表示一个负数,...这个负数是最小的那个..

浅析为什么char类型的范围是 —128~+127


char 其数值表示 范围的计算

b站 C语言数据类型及数值范围

原码 补码 反码

1.原码
最高位表示符号位。剩下的位数,是这个数的绝对值的二进制

就比方说 一个完整的int型变量在内存中占的是4个字节,32位的编译器中 那么这时候他的二进制表示是00000000 00000000 00000000 00000000

所以

10的原码就是00000000 00000000 00000000 00001010

那么负数的原码就是例如

-10的原码10000000 00000000 00000000 00001010

 符号位是第一位 0为正数 1为负数

2.反码
    正数的反码就是其原码.

    负数的反码就是在其原码的基础之上 符号位不变,其他位取反.
    
3.补码

    正数的补码就是其原码.

    负数的补码就是在其反码的基础之上+1
    

C语言中的原码、反码和补码

C语言之原码、反码和补码

C语言——源码、反码、补码

b站原码 反码 补码

gdb




start   st 开始执行程序,在main函数的第一条语句前面停下来
step       s   下一条语句,如果该语句为函数调用,则进入函数执行其中的第一条语句
 next    n  执行下一条语句,如果该语句为函数调用,不会进入函数内部执行(即不会一步步地调试函数内部语句)









使用例子  结合他看C代码 爽到不行了 
184
185gcc -g 11.2.c -o 11.2
186gdb 11.2
187
188(gdb) start
189(gdb) s   #一直用step命令(简写为s)进入函数中 ,n命令呢
190
191
192step s  下一条语句,如果该语句为函数调用,则进入函数执行其中的第一条语句
193next n  执行下一条语句,如果该语句为函数调用,不会进入函数内部执行(即不会一步步地调试函数内部语句)

c


/*                                                                                                                                                                                          
20答案是 Tuesday  因为列数定了是10                                                                                                                                                            
21days[2] === days[2][10]                                                                                                                                                                     
22                                                                                                                                                                                            
23解说                                                                                                                                                                                        
24days[2][0]=T                                                                                                                                                                                
25days[2][1]=u                                                                                                                                                                                
26days[2][2]=e                                                                                                                                                                                
27days[2][3]=s                                                                                                                                                                                
28days[2][4]=d                                                                                                                                                                                
29days[2][5]=a                                                                                                                                                                                
30days[2][6]=y                                                                                                                                                                                
31days[2][7]=                                                                                                                                                                                 
32days[2][8]=                                                                                                                                                                                 
33days[2][9]=                                                                                                                                                                                 
34                                                                                                                                                                                            
35                 

eg

石头剪刀布

#include <stdio.h>
#include <stdlib.h>
#include <time.h>

int main(void)
{
	char gesture[3][10] = { "scissor", "stone", "cloth" };
	int man, computer, result, ret;

	srand(time(NULL));
	while (1) {
		computer = rand() % 3;
	  	printf("\nInput your gesture (0-scissor 1-stone 2-cloth):\n");
		ret = scanf("%d", &man);
	  	if (ret != 1 || man < 0 || man > 2) {
			printf("Invalid input! Please input 0, 1 or 2.\n");
			continue;
		}
		printf("Your gesture: %s\tComputer's gesture: %s\n", 
			gesture[man], gesture[computer]);

		result = (man - computer + 4) % 3 - 1;
		if (result > 0)
			printf("You win!\n");
		else if (result == 0)
			printf("Draw!\n");
		else
			printf("You lose!\n");
	}
	return 0;
}


/*
0、1、2三个整数分别是剪刀石头布在程序中的内部表示,用户也要求输入0、1或2,然后和计算机随机生成的0、1或2比胜负。这个程序的主体是一个死循环,需要按Ctrl-C退出程序。以往我们写的程序都只有打印输出,在这个程序中我们第一次碰到处理用户输入的情况。在这里只是简单解释一下,以后再细讲。scanf("%d", &man)这个调用的功能是等待用户输入一个整数并回车,这个整数会被scanf函数保存在man这个整型变量里。如果用户输入合法(输入的确实是整数而不是字符串),则scanf函数返回1,表示成功读入一个数据。但即使用户输入的是整数,我们还需要进一步检查是不是在0~2的范围内,写程序时对用户输入要格外小心,用户有可能输入任何数据,他才不管游戏规则是什么。

和printf类似,scanf也可以用%c、%f、%s等转换说明。如果在传给scanf的第一个参数中用%d、%f或%c表示读入一个整数、浮点数或字符,则第二个参数的形式应该是&运算符加一个相应类型的变量名,表示读进来的数存到这个变量中;如果在第一个参数中用%s读入一个字符串,则第二个参数应该是数组名,数组名前面不加&,因为数组类型做右值时自动转换成指针类型,而scanf后面这个参数要的就是指针类型,在第 10 章 gdb有scanf读入字符串的例子。&运算符的作用也是得到一个指针类型,这个运算符以后再详细解释。

留给读者的思考问题是:(man - computer + 4) % 3 - 1这个神奇的表达式是如何比较出0、1、2这三个数字在“剪刀石头布”意义上的大小的
*/

石头剪刀布_C语言

https://blog.csdn.net/guoqingchun/article/details/8104197


Linux下C语言获取目录中的文件列表

/*
 * dir.c
 *
Linux下C语言获取目录中的文件列表  https://www.cnblogs.com/dgwblog/p/12158373.html
http://c.biancheng.net/cpp/html/1548.html  怎样使用C语言列出某个目录下的文件?
 *  Created on: 2020年11月2日
 *      Author: evan
 */
#include <sys/types.h>
#include <dirent.h>
#include <unistd.h>
#include <stdio.h>
int main(){
	 DIR *dir;
	 struct  dirent *ptr;
	 dir = opendir("/home/evan/t1/");
	 while((ptr = readdir(dir)) != NULL)
		 printf("d_name:%s\n",ptr->d_name);
	 closedir(dir);
	 return 0;
}


/* 结果
 *
d_name:.
d_name:..
d_name:1.py
d_name:22.py

*/


排序与查找

插入排序

#include <stdio.h>
#define LEN 5
int a[LEN] = { 10, 5, 2, 4, 7 };
void insertion_sort(void)
{
	int i, j, key;
	for (j = 1; j < LEN; ++j) {
		printf("%d, %d, %d, %d, %d\n",
		       a[0], a[1], a[2], a[3], a[4]);
		key = a[j];  //key 标记为未排序的第一个元素
		i = j - 1;
                // key  与已排序元素从大到小比较,寻找key应插入的元素 a[i+1]一般就是key 起初的值
////采用顺序查找方式找到插入的位置,在查找的同时,将数组中的元素进行后移操作,给插入元素腾出空间 ?

		while (i >= 0 && a[i] > key) {
			a[i+1] = a[i];
			--i; //跳出while 
		}
		a[i+1] = key; ////插入到正确位置
	}
	printf("%d, %d, %d, %d, %d\n",
	       a[0], a[1], a[2], a[3], a[4]);
}
int main(void)
{
	insertion_sort();
	return 0;
}
/* 就是key 一直和前面排好的比,找到正确的位置 
10, 5, 2, 4, 7
5, 10, 2, 4, 7
2, 5, 10, 4, 7
2, 4, 5, 10, 7
2, 4, 5, 7, 10 */ 


算法的时间复杂度分析

则总的执行时间粗略估计是(n-1)*(c1+c2+c5+m*(c3+c4))。 #怎么来的呢  线性函数  不记得了 要补一下

插入排序算法及C语言实现


11.4 归并排序

递归实现 归并排序



see also

还有下一节 ?

4-5 通过归并排序算法深入理解递归


非递归 https://blog.csdn.net/zjy900507/article/details/80530336

chapter 12 栈与队列

堆栈

http://docs.linuxtone.org/ebooks/C&CPP/c/ch12s02.html

3. 深度优先搜索

未看 http://akaedu.github.io/book/ch12s03.html


第 13 章 计算机中数的表示

1. 为什么计算机用二进制计数

第 14 章 计算机中数的表示

c语言基本数据类型short、int、long、char、float、double

C语言的基本数据类型


c语言char是什么意思

二进制制转十进制

 在 C 语言中, signed char 类型的范围为 -128~127,每本教科书上也这么写,但是没有哪一本书上(包括老师)也不会给你为什么是 -128~127,这个问题貌似看起来也很简单容易, 以至于不用去思考为什么,不是有一个整型范围的公式吗:  -2^(n-1)~2^(n-1)-1 (n为整型的内存占用位数),所以 int 类型 32 位那么就是 -(2^31) ~ 2^31-1 即 -2147483648~2147483647,但是为什么最小负数绝对值总比最大正数多 1 ,这个问题甚至有的工作几年的程序员都模棱两可,因为没有深入思考过,只知道书上这么写。于是,我不得不深入思考一下这个被许多人忽视的问题。

对于无符号整数,很简单,全部位都表示数值,比如 char 型,8位,用二进制表示为 0000 0000 ~ 1111 1111,1111 1111 最大即为十进制255,所以 unsigned char 的范围为 0~ 255,在这里普及一下 2 进制转十进制的方法, 二进制每一位的数值乘以它的位权(2^(n-1),n为自右向左的位),再相加,可得到十进制数,比如 :1111 1111 = 1*2^7 + 1*2^6 + 1*2^5 + 1*2^4 + 1*2^3 + 1*2^2 + 1*2^1 + 1*2^0 = 255 。


但是对于有符号整数,二进制的最高位表示正负,不表示数值,最高位为 0 时表示正数,为 1 时表示负数,这样一来,能表示数值的就剩下( n-1 )位了,
比如 char a = -1;   那么二进制表示就为 1 0000001,1 表示为 0 0000001,所以 signed char 型除去符号位剩下的 7 位最大为 1111 111 = 127,再把符号加上,0 1111111 = 127,1 1111111 = -127,范围应该为 -127~127 ,同理 int 类型也一样,但是问题出来了,教科书上是 -128~127 啊,下面就剖析一下这个惊人的奇葩。 加上反码 看到这里 


再普及一下计算机内部整数存储形式,大家都知道计算机内部是以二进制来存贮数值的,无符号整数会用全部为来存储,有符号的整数,最高位当做符号位 ,其余为表示数值。

第 17 章

3. 设备

http://akaedu.github.io/book/ch17s03.html

4. MMU

按照离CPU由近到远的顺序依次是CPU寄存器、Cache、内存、硬盘,越靠近CPU的存储器容量越小但访问速度越快

http://akaedu.github.io/book/ch17s04.html

Memory Hierarchy

http://akaedu.github.io/book/ch17s05.html

附录 A. 字符编码

20191112

字符编码的高位 左边是也

如何学习c

mongoose 开源http库

有空学习这个作为C的入门例子

Mongoose是一个用C编写的网络库。它为客户端和服务器模式实现TCP,UDP,HTTP,WebSocket,CoAP,MQTT的事件驱动的非阻塞API。 mongoose 开源http库

Mongoose 利用实现HTTP服务

funciton

strcmp

C/C++函数,比较两个字符串

strcmp函数是string compare(字符串比较)的缩写,用于比较两个字符串并根据比较结果返回整数

设这两个字符串为str1,str2,

若str1==str2,则返回零;

若str1<str2,则返回负数;

若str1>str2,则返回正数。

strcmp

https://baike.so.com/doc/61175-64376.html

C library function - remove()

/*
 * remvoe.c
 *
 *  Created on: 2020年11月30日
 *      Author: evan
 */
#include <stdio.h>
#include<string.h>

int main() {
	int ret;
	FILE *fp;
	char filename[] = "file.txt";  // 这个是什么意思  定义一个 数组 ? 是的  

	fp = fopen(filename,"w");

	fprintf(fp,"%s", "THis is tutor \n");
	fprintf(fp,"%s", "ln2 THis is tutor");
	fclose(fp);

	//ret = remove(filename);
/*
	 cat file.txt
	THis is tutor*/

	if(ret == 0) {
		printf("file deleted successfully");
	}else {
		printf("Error: unable to delte the file");
	}
	return(0);

}


C语言perror函数的作用

 不可以掉了这个头文件,perror是包含在这个文件里的//编辑本段perror表头文件完善版定义函数
  void perror(const char *s); perror ("open_port");
函数说明
  perror ( )用 来 将 上 一 个 函 数 发 生 错 误 的 原 因 输 出 到 标 准 设备 (stderr) 。参数 s 所指的字符串会先打印出,后面再加上错误原因字符串。此错误原因依照全局变量errno 的值来决定要输出的字符串。   在库函数中有个errno变量,每个errno值对应着以字符串表示的错误类型。当你调用"某些"函数出错时,该函数已经重新设置了errno的值。perror函数只是将你输入的一些信息和现在的errno所对应的错误一起输出。

void perror(const char *str)

参数

    str -- 这是 C 字符串,包含了一个自定义消息,将显示在原本的错误消息之前

#include <stdio.h>   
int main(void)   
{   
	FILE *fp ;   
	fp = fopen( "/root/noexitfile", "r+" );   
	if ( NULL == fp )  ?
	{   
		perror("/root/noexitfile");   //下面有这个输出
	}   
	return 0;   
}

运行结果
[root@localhost io]# gcc perror.c   
[root@localhost io]# ./a.out   
/root/noexitfile: No such file or directory


linux下 C语言perror函数的作用

https://www.cnblogs.com/yujianfei/p/8973867.html

https://www.runoob.com/cprogramming/c-function-perror.html


c语言实现rm命令 or 删除

头文件:#include <stdio.h>

remove()函数用于删除指定的文件,其原型如下:
    int remove(char * filename);

【参数】filename为要删除的文件名,可以为一目录。如果参数filename 为一文件,则调用unlink()处理;若参数filename 为一目录,则调用rmdir()来处理。

【返回值】成功则返回0,失败则返回-1,错误原因存于errno。

C语言remove()函数:删除文件或目录

linux下实现rm()函数删除文件或目录

c语言实现rm命令,删除指定文件或目录

C语言access()函数:判断是否具有存取文件的权限

C语言access()函数:判断是否具有存取文件的权限

C语言中access函数

C 数组


进阶

十个经典的C开源项目代码

十个经典的C开源项目代码


2021

C语言目录操作

C语言技术网

博客园 C语言中关于对目录的操作

《Linux环境C程序设计(第2版)徐诚》pdf 附下载链接

http://www.txtepub.com/105693.html

see also

C语言简要语法指南

https://wiki.ubuntu.com.cn/Compiling_C

Gcc-howto

c++

c++ zh.wikipedia.org

https://isocpp.org/