C语言细节总结笔记
C语言细节总结笔记
*/-->
C语言细节总结笔记
Table of Contents
1 三步异或法交换数字
a ^= b;
b ^= a;
a ^= b;
2 做差法交换数字
x=x+y;
y=x-y;
x=x-y;
3 按n位置位
先置0
a&=~(1<<n)
再置1/0,i为1或0
a|=(i<<n)
4 求余求商求积
求余
a&=7 a%=8
求商
a>>=3 a/=8
求积
a<<=3 a*=8
a=(a<<3)+a a*=9
5 辗除法求最大公约数
while(b!=0)/*利用辗除法,直到b为0为止*/
{
temp=a%b;
a=b;
b=temp;
}
printf("公约数:%d\n",a);
6 求数组元素个数方法
sizeof(a)/sizeof(a1)
7 运算符优先级
| 优先级 | 运算符 | 结合性 |
|---|---|---|
| 1 | () [] . -> | 从左到右 |
| 2 | -(符号) ~ ++ – *(指针) & ! (类型) sizeof | 从右向左 |
| 3 | * / % | 从左向右 |
| 4 | +(加) -(减) | 从左到右 |
| 5 | 从左向右 | |
| 6 | < <= > >= | 从左向右 |
| 7 | = ! |
从左到右 |
| 8 | &(安位与) | 从左到右 |
| 9 | ^ | 从左到右 |
| 10 | 按位或 | 从左到右 |
| 11 | && | 从左到右 |
| 12 | 逻辑或 | 从左到右 |
| 13 | ?: | 从右到左 |
| 14 | = += -= *= /= %= &= | 从右到左 |
| &= ^= ~= = >>>= | ||
| 15 | ,(逗号) | 自左到右 |
8 scanf处理字符串
scanf("%[\n]",str);
用到正则表达式
9 指针题
- 指针的加减法:
char a = 100;
char *p = &a;
若:p的地址为0x20008000,则
p+1=0x______; 0x20008001
*p + 1 =0x_____; 101(我写的是10进制)
(int )p + 1 = 0x______; 0x20008001
(int *)p + 1 = 0x______; 0x20008004
(char *)p + 1 = 0x______; 0x20008001
(char)p + 1 = 0x______; 1 - a &a &a+1
char a2;
a :=a1
&a :=a1 本质发生变化 数组地址 现象如下
&a+1 :=a2 - 指针
(*p)++
++(*p)
*(\\p)
*p
*(p++) - 设有二维数组
int a3, 4= {0, 1, 2, 3,4, 5, 6, 7, 8, 9, 10, 11};
请说明以下表示形式的的含义:
并写出地址值,设a的起始地址为0x2000.
a表示 二维数组名,那么 a==&a1 - 数组 int a3, 4, 请用3-4种方法表示a5, 6的地址?
a1+1*4+2 0行开始 1
*a+1*4+2 2
&a5, 6 1行开始 3
*(1)+2 4
a5+2 5
*(a+2)-2 2行开始 6
a6-2 7
*(*(&a+1))-6 3行开始 8
*(*(&a+1)-1)-2 末尾开始 9
10 int const *p问题
const int *p 定义指向const的指针(指针指向的内容不能被修改)
int const p 定义指向const的指针(指针指向的内容不能被修改)
int const p 定义const指针(由于指针本身的值不能改变所以必须得初始化)
const int* const p 指针本身和它指向的内容都是不能被改变的所以也得到初始化
int const* const p 指针本身和它指向的内容都是不能被改变的所以也得到初始化
11 数组和指针
12 字符数组
char *p = "Hello World!"; //它存储在只读存储区,不能修改,如果修改会出现段错误
13 二维数组
15 指针数组
16 指针函数
17 函数指针
18 函数指针数组
19 存储方式
data段:初始化的全局变量和静态变量
bss段 :未初始化的全局变量和静态变量, 自动清零
代码段:常量 代码
堆:用户分配,用户回收
栈:系统分配,局部变量
20 typedef
Date: a date, fixed, of a format string for format-time-string
Author: 野书
Created: 2016-07-24 日 15:50
C语言细节总结笔记的更多相关文章
- C语言细节——献给入门者(三)
C语言细节——献给入门者(三) >>主题:关于强制类型转换 先来瞎扯下强制类型转换,c语言有很多数据类型,long,short,int,float,double,bool,char等等.当 ...
- C语言细节——献给初学者(二)
C语言细节——献给初学者(二) 主题 循环运用+选择判断 C语言循环有for和while/do...while: 选择判断有:if...else和switch...case 在循环中需要注意搭配br ...
- C语言细节——献给入门者(一)
C语言细节——献给入门者(一) 主题 输入输出需要注意的细节 首先我们要知道大致有scanf(),printf(),getchar(),putchar(),gets(),puts()这几种输入方式. ...
- # C语言假期学习笔记——6
C语言假期学习笔记--6 数组 主要学习了一位数组和二维数组. 数组是一组具有相同类型的变量的集合.C语言程序通过元素的下标来访问数组中的元素.(下标从0开始) 一位数组 类型 数组名[元素个数] 二 ...
- R语言可视化学习笔记之添加p-value和显著性标记
R语言可视化学习笔记之添加p-value和显著性标记 http://www.jianshu.com/p/b7274afff14f?from=timeline 上篇文章中提了一下如何通过ggpubr ...
- 二级C语言真题笔记
二级C语言真题笔记 1. 知识重点:数据类型.循环.数组.函数.指针.结构体与共同体 2. 求程序的运行结果 #include <stdio.h> main() { short i ...
- [转载] C语言细节,写的非常棒!
这篇文章主要讨论C语言细节问题.在找一份工作的时候,语言细节占的比例非常小,之前看某个贴着讨论,估计语言细节在面试中,占了10%的比重都不到,那为什么还要研究C语言的细节呢,我觉得有三个原因促使我总结 ...
- C/C++编程笔记:C语言入门知识点(三),请收藏C语言最全笔记!
今天我们继续来学习C语言的入门知识点,第一课:C/C++编程笔记:C语言入门知识点(二),请收藏C语言最全笔记! 21. 输入 & 输出 当我们提到输入时,这意味着要向程序填充一些数据.输入可 ...
- C语言细节笔记2
C语言常见问题笔记: 1. 指针的声明 char * p1, p2; p1 是一个指向char类型的指针,而p2是一个char类型变量 这是由于 * 并不是基本类型的一部分,而是包含 ...
随机推荐
- ubuntu网站做图像外链
http://paste.ubuntu.org.cn
- #ifdef _cplusplus (转)
原文不可考,转载链接:http://blog.csdn.net/owldestiny/article/details/5772916 有发现原文的请告知,我会及时更新. 时常在cpp的代码之中看到这样 ...
- STM32学习笔记——FSMC 驱动大容量NAND FLASH [复制链接]
本文原创于观海听涛,原作者版权所有,转载请注明出处. 近几天开发项目需要用到STM32驱动NAND FLASH,但由于开发板例程以及固件库是用于小页(512B),我要用到的FLASH为1G bit的大 ...
- 在ASP.NET MVC中修改默认代码生成/支架模板
到 C:\Program Files (or x86)\Microsoft Visual Studio 10.0\Common7\IDE\ItemTemplates\CSharp (or Visual ...
- uva11426 GCD Extreme(II)
题意:求sum(gcd(i,j),1<=i<j<=n)1<n<4000001 思路: 1.建立递推关系,s(n)=s(n-1)+gcd(1,n)+gcd(2,n)+……+ ...
- 利用迅雷提供的接口从磁力链得到bt种子文件
本地下载工具的磁力链下载速度不给力,而百度云盘有提供离线下载服务,相当于就是直接到服务器取个链接而已.但这需要bt文件,而我只有链力链.网上搜了一下,可以从磁力链构造一个bt文件的下载地址,用pyth ...
- HDU-4642 Fliping game 简单博弈
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4642 看右下角的状态就行了,因为上面的操作每次都会改变它,而最后的局势是根据它来的... //STAT ...
- <转>HTML中的table转为excel
转换html 中的table 为excel,firefox浏览器支持,代码如下 <%@ page language="java" contentType="text ...
- iOS block并发
多核运算 在iOS中concurrency编程的框架就是GCD(Grand Central Dispatch), GCD的使用非常简单.它把任务分派到不同的queue队列来处理.开发者把任务代码装到一 ...
- Stones
题目是:HDU1896 题目简述:输入一堆石头,每个石头有自己所在的位置p,以及自己可以抛多远的距离d.你每遇到第奇数个石头,就把石头丢出去,第偶数个石头就不管.计算出最后一个石头它所处的位置. 解法 ...