C语言,变量与内存
一、数在计算机中的二进制表示
符号位:最高位为符号位,正数该位为0,负数该位为1;
原码:原码就是符号位加上真值的绝对值, 即用第一位表示符号, 其余位表示值
反码:正数的反码是其本身;负数的反码是在其原码的基础上, 符号位不变,其余各个位取反。
补码: 正数的补码就是其本身;负数的补码是在其原码的基础上, 符号位不变, 其余各位取反, 最后+1. (即在反码的基础上+1)。
正数的原码、补码、反码表示方法均相同,不需转换。
任何数值在内存中都是以补码的形式存储的。
- 正数的补码与原码相同。比如9的原码和补码都是1001。
- 负数的补码等于它正数的原码按位取反后再+1。
负数补码计算:
1> -10的二进制形式 :1000 0000 0000 0000 0000 0000 0000 1010 //原
2> 除符号位取反 :1111 1111 1111 1111 1111 1111 1111 0101 //反
3> 对取反后的结果+1 :1111 1111 1111 1111 1111 1111 1111 0110 //补
二、基本数据类型
in linux-32:
sizeof(char) = 1sizeof(int) = 4sizeof(short int) = 2sizeof(long int) = 4sizeof(float) = 4sizeof(double) = 8sizeof(long double) = 12三、综合示例,说明变量的二进制表示以及在内存中的分布:
#include "stdafx.h" #include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include "t.h" void f0(void); typedef struct ds{
unsigned int ui;
int i;
int j;
long int li;
char c;
unsigned char uc;
short int si;
unsigned short int usi;
float f;
double d;
long double ld; char data[];
}DST; int t1(void)
{
f0();
DST* pdst = (DST*)malloc(sizeof(DST)+1000);
if(pdst == 0){
return -1;
} memset(pdst, 0, sizeof(DST)+1000); pdst->ui = 0xffffffff;
pdst->i = pdst->ui;
pdst->j = -2147483648; pdst->li = -2147483648; pdst->c = -1;
pdst->uc = -1;
pdst->si = -1;
pdst->usi = -1; pdst->f = -1;
pdst->d = -1;
pdst->ld = -1; printf("pdst->c addr = %08x\n", &(pdst->c) );
printf("pdst->uc addr = %08x\n", &(pdst->uc) );
printf("pdst->si addr = %08x\n", &(pdst->si) );
printf("pdst->usi addr = %08x\n", &(pdst->usi) ); printf("pdst->f addr = %08x\n", &(pdst->f) );
printf("pdst->d addr = %08x\n", &(pdst->d) );
printf("pdst->ld addr = %08x\n", &(pdst->ld) ); free(pdst);
pdst = 0; return 0;
} void f0(void)
{
printf("in vs2010:\n");
printf("sizeof(char) = %d\n", sizeof(char));
printf("sizeof(int) = %d\n", sizeof(int));
printf("sizeof(short int) = %d\n", sizeof(short int));
printf("sizeof(long int) = %d\n", sizeof(long int)); printf("sizeof(float) = %d\n", sizeof(float)); printf("sizeof(double) = %d\n", sizeof(double));
printf("sizeof(long double) = %d\n", sizeof(long double)); }

内存中的i是0xffffffff,
(1)转化为二进制 1111 1111 1111 1111 1111 1111 1111 1111
(2)发现是负数
(3)减一 1111 1111 1111 1111 1111 1111 1111 1110
(4)除符号位取反 1000 0000 0000 0000 0000 0000 0000 0001 ; 真值为-1
内存中的j是0x80000000,(最小的一个负值,暂时还不能理解,因为借了一位才能完成这换算,需33位,不知是不是因为cpu中的计算单元有33位以上寄存器。)
(1)转化为2进制, 1000 0000 0000 0000 0000 0000 0000 0000
(2)发现是负数
(3)减一 1 0111 1111 1111 1111 1111 1111 1111 1111
(4)除符号位取反1 1000 0000 0000 0000 0000 0000 0000 0000 ;真值为-231= -2147483648
原码, 反码, 补码 详解,张子秋的博客
c语言,内存字节对齐,oucaijun
【零基础学习iOS开发】【02-C语言】06-变量与内存,M了个J
【零基础学习iOS开发】【02-C语言】07-基本数据类型,M了个J
C语言,变量与内存的更多相关文章
- C语言变量声明内存分配
转载: C语言变量声明内存分配 一个由c/C++编译的程序占用的内存分为以下几个部分 1.栈区(stack)— 程序运行时由编译器自动分配,存放函数的参数值,局部变量的值等.其操作方式类似于数据结 ...
- 关于c语言变量的内存分布测试程序
#include <stdio.h> #include <stdlib.h> ; // 常全局变量 ; // 初始化全局变量 int uninit_global; // 未初始 ...
- [C语言 - 2] C语言变量
A.变量的作用域: 1.局部变量:在函数或者代码块内部定义的变量 作用域:从定义处到代码块结束 生命周期:从定义处分配控件,代码块结束后被回收 局部变量没有默认值,要自己初始化 2.全局变量:在函 ...
- C语言中计算变量占用内存空间
C语言中计算变量占用内存空间 在C语言中通常用[sizeof]运算符计算变量占内存空间,如下面的例子:
- C语言中的内存分配与释放
C语言中的内存分配与释放 对C语言一直都是抱着学习的态度,很多都不懂,今天突然被问道C语言的内存分配问题,说了一些自己知道的,但感觉回答的并不完善,所以才有这篇笔记,总结一下C语言中内存分配的主要内容 ...
- JavaScript变量——栈内存or堆内存
原文 http://blog.csdn.net/xdd19910505/article/details/41900693 堆和栈这两个字我们已经接触多很多次,那么具体是什么存在栈中什么存在堆中呢?就 ...
- C语言中的内存压缩技术
C语言中的内存压缩技术 前言 在整个研究生阶段我都在参与一个LTE协议栈实现的项目,在这个项目中,我们利用一个自己编写的有限状态机框架将协议栈中每一层实现为一个内核模块.我们知道,在编写内核代码时需要 ...
- block没那么难(二):block和变量的内存管理
本系列博文总结自<Pro Multithreading and Memory Management for iOS and OS X with ARC> 了解了 block的实现,我们接着 ...
- 黑马程序员-- C语言变量作用域与代码块
这里通过变量作用域的两种错误用法来介绍一下C语言变量作用域 其次对代码块的使用进行了简单说明: #include <stdio.h> 1.变量的作用域(作用范围) 变量定义的那一行开始,直 ...
- C语言中的内存管理
开始陆续的发一下唐老师视频的笔记吧,顺便带一些正冲哥书的的内容.不能一下都发出来,因为内容发多了自己也受不了,而且发的都是学习视频时候的一些笔记,可能会有一些问题不是很清晰. 先说一下C语言中的内存管 ...
随机推荐
- TPM 2.0 近况及模拟器开发
可信计算平台模块TPM 2.0的相关标准和技术准则由 TCG ( Trust Computing Group )于2011年前后提出,至今已经过了多次修改.该标准无疑将成为下一代可信计算平台模块的业界 ...
- 1298 The Hardest Problem Ever
题目链接:http://poj.org/problem?id=1298 思路分析:水题,字符偏移求解,注意字符串输入问题即可. 代码如下: #include <iostream> #inc ...
- codility上的练习 (1)
codility上面添加了教程.目前只有lesson 1,讲复杂度的……里面有几个题, 目前感觉题库的题简单. tasks: Frog-Jmp: 一只青蛙,要从X跳到Y或者大于等于Y的地方,每次跳的距 ...
- opencv是什么
OpenCV是一个用于图像处理.分析.机器视觉方面的开源函数库. 不管你是做科学研究,还是商业应用,opencv都能够作为你理想的工具库,由于,对于这两者,它全然是免费的.该库採用C及C+ ...
- SQL常用语句集合(不断更新)
1.多条件 查询 上下级 所有数据 select * from OrgUnit where (ParentId = '3' or OrgId='3' or ParentId in (select Or ...
- N皇后( DFS,推荐)
N皇后问题 Description 在N*N的方格棋盘放置了N个皇后,使得它们不相互攻击(即任意2个皇后不允许处在同一排,同一列,也不允许处在与棋盘边框成45角的斜线上. 你的任 ...
- [Swust OJ 1026]--Egg pain's hzf
题目链接:http://acm.swust.edu.cn/problem/1026/ Time limit(ms): 3000 Memory limit(kb): 65535 hzf ...
- WebView之2
首先需要添加权限: <uses-permission android:name="android.permission.INTERNET"/> MainActivity ...
- Android GridView增加HeaderView和FooterView的实现
Android GridView增加HeaderView和FooterView的实现 做的项目中遇到一个问题,需要实现一个页面 页面的上面是一个自定义的View和GridView,当向下滚动屏幕的时候 ...
- Chapter 17 Replication 复制
Chapter 17 Replication 复制 Table of Contents 17.1 Replication Configuration 17.2 Replication Implemen ...