/*************************************************************************
> File Name: class.c
> Author: khalil
> Mail: hsgwpj@gmail.com
> Created Time: Sat 14 Nov 2015 09:14:48 AM CST
*************************************************************************/
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<assert.h>
//KeyPoint:
// Nginx
// Zabbix
// MySQL
#if 1
// Binary Code Analysis
//为了提升效率 二进制代码使用段表信息
//.text 代码段
//.data 数据段
//.rodata 只读数据段
//.bss 未初始化的数据段
//查看命令 objdump -s -d 汇编代码及二进制信息/ -h 显示段表信息/ -x 查看符号表
// readelf -S 更详细的段表信息 -h显示二进制文件表头信息
//凡是全局的函数和变量 都是符号
//符号有强弱之分 一旦初始化就是强符号 未初始化是弱符号
//
//多重定义强弱符号规则:
//
//1.不允许出现多个强符号;
//2.如果有一个强符号和多个弱符号时,编译器选择强符号;
//3.如果是多个弱符号,部分编译器选择最大的类型,部分编译器随机;
//
//链接处理的过程:
//
//1.空间和地址的重新分配
//2.符号的解析和重定义;
int global_init_value = 10; //data
int global_uninit_value; //bss
void func1(int value)
{
int a = 10; //stack
printf("%d\n", value);
}
int main(int argc, char **argv)
{
static int static_value1 = 20; //data
static int static_value2; //bss 如果初始化为0还在bss
int a = 10; //data
int b = 30; //data
func1(static_value1 + static_value2 + a + b);
return 0;
}
#endif
#if 0
//动态内存分配
// malloc族的函数:
// void *malloc(size_t size);
// void free(void *ptr);
// void *calloc(size_t nmemb, size_t size);
// void *realloc(void *ptr, size_t size);
int main (int argc, char **argv)
{
int array[10] = {12, 34, 45, 56, 68};
int *p_int = NULL;
char *p_char = NULL;
int i = 0;
p_int = malloc(sizeof(int) * 10);
p_char = (char *)malloc(sizeof(char) * 30);
printf("p_int = %x\n", p_int);
strcpy(p_char, "hello,world!");
free(p_int);
printf("p_int = %x\n", p_int);
p_int = NULL;
printf("p_int = %x\n", p_int);
for (i = -20 ; i < 30; ++i )
{
printf("%d\t:%c\n",i,p_char[i]);
}
printf("\n");
printf("char :%s\n", p_char);
free(p_char);
for (i = -20 ; i < 30; ++i )
{
printf("%d\t:%c\n",i,p_char[i]);
}
printf("\n");
printf("char :%s\n", p_char);
return 0;
}
#endif