unix c 03
C程序员的错误处理
errno/perror/strerror 都是系统设计好的
自定义函数中的错误处理
1 可以返回-1 代表错误
2 指针类型可以用 NULL 代表错误
3 如果不需要考虑错误,用void
环境变量和环境表
extern char** environ;
(用指针操作字符串数据/字符串 是基本能力)
内存管理
内存管理的依附关系:
STL-自动管理 -> C++ new/delete ->
C malloc/free ->Unix sbrk/brk -> Unix mmap
内存的管理 使用 虚拟内存地址 技术,就是说:程序员 接触的是 虚拟的地址,不是 真实的 物理内存地址。虚拟内存地址 必须 映射到 物理内存 才能真正使用(mmap),否则 产生段错误。虚拟内存地址有用户空间(0-3G)和内核空间(3G-4G)之分。
一个进程(就是运行起来的程序)内存是分为以下部分:
1 代码区 存函数 (只读区),常量和字面值近似
2 全局区 存static和初始化的全局变量
3 BSS段 存未初始化的全局变量
4 栈 存局部变量(包括函数的参数)
5 堆 自由区,由程序员控制
可以用cat /proc/进程ID/maps 查看内存的分配情况
进程ID 可以用 ps -aux查看,也可以用 getpid()取得。
malloc 一次分配33个内存页,但如果申请的内存比较大(超过32个内存页)就会分配比申请的内存 稍大一点的内存页数(不固定)。
malloc分配内存时,先记录附加信息,然后再返回一个首地址。但不影响使用。
如果33个内存页用完,会增加新的内存页,不一定是66个。
由于 内存映射 非常耗费时间,所以free并不确保一定解除映射。malloc分配的内存,free会最后保留33个内存页,直到内存被清空时。
结论:申请内存用malloc,释放内存用free.
getpagesize()函数可以取得内存页的大小。
注:不同进程之间即使虚拟地址一样,也是对应不同的物理内存。(IPC之共享内存除外)
brk和sbrk
底层维护了一个位置,由位置决定内存的分配或回收。
sbrk本身可以申请/释放内存,
void* sbrk(int num)
num 是正数 申请内存,同时移动位置,把移动之前的位置作为首地址返回。
num 是负数 释放内存,同时移动位置,返回值意义不大。
num 是0 取当前的位置地址。
sbrk是以 一个内存页作为操作内存的基本单位。
经验:sbrk分配内存简单,但释放内存 麻烦。
sbrk一般用于 分配内存,brk 负责回收内存。
练习:
用sbrk申请内存,用brk释放内存,实现以下要求
存放一个整数,再存放一个double,再存放一个长度为8的字符串,放入"abcd",最后,逐一释放空间。
mmap负责 映射 物理内存/文件。
关于多个选项合并的方式:
用一个二进制位代表一种权限,用 | 进行合并。
001 - 执行
010 - 写权限 PROT_READ
100 - 读权限 PROT_WRITE
PROT_READ | PROT_WRITE -> 110
取 i的后8位
i & 0xFF
1000 0000
1111 1111
unix c 03的更多相关文章
- 三个入侵的必备小工具-lcx.exe、nc.exe、sc.exe
lcx.exe的使用方法 以前抓肉鸡都是通过1433弱口令,然后.. 但是发现很多服务器开了1433,3389,但是终端是连不上的,因为服务器本身是在内网,只对外开放了1433端口,幸好有lcx. ...
- 2016-1-28 图解HTTP(03)
6.2.5 非HTTP/1.1首部字段 不限于RFC2616中定义的47种首部字段,还有Cookie.Set-Cookie和Content-Disposition等在其他RFC中首部字段 ...
- UNIX系统的显示时间何时会到达尽头
本文分为三个小块: 一.UNIX系统中时间的存储形式: 二. time_t 的最大值是多少: 三. 将time_t 的最大值转化为真实世界的时间: #---------------------# # ...
- UNIX常用命令
以下只说明各常用指令的基本用法, 若需详细说明, 请用 man 去读详细的 manual. 1.关於档案/目录处理的命令 ls--列目录 这是最基本的档案指令. ls 的意义为 "list& ...
- js 取得 Unix时间戳(Unix timestamp)
js 取得 Unix时间戳 Unix时间戳(Unix timestamp),或称Unix时间(Unix time).POSIX时间(POSIX time),是一种时间表示方式,定义为从格林威治时间19 ...
- Unix权限管理
// */ // ]]> Unix权限管理 Table of Contents 1 Unix权限管理 2 进程权限 3 文件权限 4 进程对文件的存取访问的权限校验过程 1 Unix权限管理 权 ...
- multiple definition of `err_sys' 《UNIX环境高级编程》
本文地址:http://www.cnblogs.com/yhLinux/p/4079930.html 问题描述: [点击此处直接看解决方案] 在练习<UNIX环境高级编程>APUE程序清单 ...
- UNIX Time 时间戳 与 北京时间 相互转换
typedef struct t_xtime { int year; int month; int day; int hour; int minute; int second; } _xtime ; ...
- Unix Shell 程序设计 —— 正则表达式
参考:http://www.cnblogs.com/erichhuang/archive/2012/03/13/2394119.html 简介: 简单的说,正则表达式是一种可以用于模式匹配和替换的强有 ...
随机推荐
- Codeforce 217 div2
C 假设每种颜色的个数都相同,可以用轮换的方式,让答案达到最大n,当不同的时候,可以每次从每种颜色中取出相同个数的手套来操作; 一直迭代下去直到只剩下1种颜色; 再将这一种颜色与之前交换过的交换就行了 ...
- c语言指针与结构体
#include <stdio.h> #include <stdlib.h> struct mydata { int num; ]; }; void main1() { /*i ...
- 第33讲 UI组件_进度条ProcessBar和消息队列处理器handler
第33讲UI组件_进度条ProcessBar和消息队列处理器handler 1. 进度条ProcessBar 一个可视化的进度指示器,代表正在执行的耗时任务.可以为用户展示一个进度条,表示正在执行的任 ...
- VSCode
下载: 打开终端控制器 wget http://download.microsoft.com/download/0/D/5/0D57186C-834B-463A-AECB-BC55A8E466AE/V ...
- python3-day4(递归)
递归 特点 递归算法是一种直接或者间接地调用自身算法的过程.在计算机编写程序中,递归算法对解决一大类问题是十分有效的,它往往使算法的描述简洁而且易于理解. 递归算法解决问题的特点: (1) 递归就是在 ...
- 【Cocos2d-X开发学习笔记】第19期:动作管理类(CCActionManager)的使用
本系列学习教程使用的是cocos2d-x-2.1.4(最新版为3.0alpha0-pre) ,PC开发环境Windows7,C++开发环境VS2010 一.动作管理类 动作管理类CCActionMan ...
- 未知宽高div水平垂直居中3种方法
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> </head&g ...
- [Cycle.js] Making our toy DOM Driver more flexible
Our previous toy DOM Driver is still primitive. We are only able to sends strings as the textContent ...
- React 入门最好的实例-TodoList
React 的核心思想是:封装组件,各个组件维护自己的状态和 UI,当状态变更,自动重新渲染整个组件. 最近前端界闹的沸沸扬扬的技术当属react了,加上项目需要等等原因,自己也决定花些时间来好好认识 ...
- C# Serializable学习
先上代码,感觉这个功能很给力啊. class Program { static void Main(string[] args) { //下面代码将对象Person进行序列化并存储到一个文件中 Per ...