C和C++代码精粹笔记1
CH1 更好的C
- 运算符重载规定,必须有一个为用户自定义类型
- 一些输出没注意到的函数:
float x = 123.456, y = 12345;
//cout.precision(2); //显示两个有效值,其他是科学计数法
//cout << x << " " << y << endl;
//cout.setf(ios::showpoint);//显示末尾的0
//cout << x << " " << y << endl;
cout.setf(ios::showpos);//显示符号
cout << x << " " << y << endl;
- 打印地址
Printf("%p",s);
Cout<<"address: "<<&s;
CH2 指针
- 区别 const的位置
Const char *p; 说明 *p是常量,不能改变。
Char* const p; 说明,p是常量,不能改变。
依据看 * 的位置。
- 初始化二维指针
int **a;
a = new int*[3];//行
for(int i = 0; i < 4; ++i)
{
a[i] = new int[4];//列
}
delete[] a;
int a[][4] = {{1,2,3},{4,5,6},{7,8,9}};
int (*p)[4] = a;
//p[i] == *(p+i);
//p[i][j] == *(p[i]+j) == *(*(p+i)+j);
size_t totals = sizeof(a);//整个字节数
size_t totalcols = sizeof(a[0]);//整个列字节数
size_t rows = sizeof(a)/sizeof(a[0]);
size_t cols = sizeof(a[0])/sizeof(a[0][0]);
for(int i = 0; i < rows; ++i)
{
for(int j = 0; j < cols; ++j)
cout << p[i][j] << " ";
cout <<endl;
}
cout << rows << " " << cols << endl;
- 函数指针
指向非成员函数的指针:
#include <Windows.h>
#include <iostream>
using namespace std;
int (*fp)(int,int);//全局指针变量
void (*farray[])(void); //可以定义在主函数外部,也可以在内部定义。 函数指针数组
int Max(int a, int b)
{
if(a > b)
return a;
else
return b;
}
int main()
{
fp = Max;
int a = fp(1,2);
cout << a << endl;
return 0;
}
指向成员函数的指针:
#include <Windows.h>
#include <iostream>
using namespace std;
class C
{
public:
void f(){cout << "C::f \n";};
void g(){cout << "C::g \n";};
int Max(int a, int b)
{
if(a > b)
return a;
else
return b;
}
};
int main()
{
C c;
void (C::*pmf)() = &C::f; //定义指向成员函数的指针
(c.*pmf)();//指向成员函数的指针,与非成员函数的指针相比,语法上有点小变化,多了 对象.*
pmf = &C::g;
(c.*pmf)();
int (C::*fp)(int,int) = &C::Max;
int aa = (c.*fp)(3,4);
cout << aa << endl;
return 0;
}
指向成员函数的指针数组
- #include <Windows.h>
- #include <iostream>
- using
namespace std; - class Object
- {
- public:
- void retreve(){cout << "Object::retreve";}
- void insert(){cout << "Object::insert";}
- void update(){cout << "Object::update";}
- void process(int choice);
- private:
- typedef void(Object::*Omf)();//起别名起的好
- static Omf farray[3];// 成员函数指针数组
- };
- Object::Omf Object::farray[3] = {
- &Object::insert,
- &Object::retreve,
- &Object::update
- };
- void Object::process(int choice)
- {
- if(choice >=0 && choice <=2)
- {
- (this->*farray[choice])();
- cout << endl;
- }
- }
- int main()
- {
- Object o;
- for(;;)
- {
- int choice;
- cin >> choice;
- if(choice >=0 && choice<=2)
- o.process(choice);
- else
- break;
- }
- return 0;
- }
- 封装与不完全类型
采用与源类相似的类实现,就是重新定义一个与源类相似的类,然后重新包装一下。
CH3 预处理器
- debug模式下可以运行 release下运行不了,用宏定义实现
#define DEBUG 1
int main()
{
int i = 2;
#if DEBUG
cout << "debugmod" << endl;
#endif
return 0;
}
下面这句话也可以实现上面的功能
#ifdef _DEBUG
cout << "debugmod" << endl;
#endif
// _DEBUG
要想将新的C++代码与旧的C代码混合编程,需要加下面的语句
extern "C" void f(); //f()在C环境下被编译
- 字符集
回车 \r 换行 \n 回退 \b 警示 \a
CH4 C标准库之一 : 面向合格的程序员
1、<ctype.h>
常见的函数: is系列。Eg : isupper(); islower(); isspcace() 等。
char a = 'A';
int b = isalpha(a);
实例:
- #include <Windows.h>
- #include <iostream>
- #include<ctype.h>
- #include <stdlib.h>
- #include<stdio.h>
- #include <string.h>
- using
namespace std; - long atox(char *s)
- {
- while(isspace(*s))//干掉开头的空格,只要有一个非零的数即跳出
- s++;
- long sum;
- for(sum = 0L; isxdigit(*s); ++s)
- {
- int digit;
- if(isdigit(*s))
- digit = *s - '0';
- else
- digit = toupper(*s) - 'A' + 10;
- sum = sum*16L + digit;
- }
- return sum;
- }
- long atox(char*s)
- {
- char xdigs[] = {0123456789ABCDEF};
- long sum;
- while(isspace(*s))
- s++;
- for(sum = 0; isxdigit(*s); ++s)
- {
- int digit = strchr(xdigs,toupper(*s)) - xdigs;//找到指针的位置,即数字的位置(0-15取值) 找出字符串xdigs中第一次出现字串 (*s) 的位置。
- sum = sum*16L + digit;
- }
- }
- long atox(char *s)
- {
- long n = 0;
- sscanf(s,"%lx",&n); // 参考代码:http://www.91linux.com/html/article/program/cpp/20081130/14121.html
- return n;
- }
- int main()
- {
- char* s = "123 abc";
- //方法一
- long t = atox(s);
- //方法二
- char** ss = NULL;
- long tt = strtol(s,ss,16);
- cout << tt << endl;
- return 0;
- }
C和C++代码精粹笔记1的更多相关文章
- JavaScript语言精粹笔记
JavaScript语言精粹笔记 掌握语言的每个特性可以让你出风头,但是并不推荐,因为一部分的特性带来的麻烦可能远超本身的价值.正如书中所言,坏的材料并不能雕刻出好的作品,要成为一名更好的程序员,要取 ...
- JavaScript 语言精粹笔记3
方法 毒瘤 糟粕 记录一下阅读蝴蝶书的笔记,本篇为书中最后一部分:方法.代码风格.优美的特性.毒瘤.糟粕等. 方法 这一章主要介绍了一些方法集.这里写几个我不太熟悉的方法和要点吧. array.joi ...
- Linux协议栈代码阅读笔记(二)网络接口的配置
Linux协议栈代码阅读笔记(二)网络接口的配置 (基于linux-2.6.11) (一)用户态通过C库函数ioctl进行网络接口的配置 例如,知名的ifconfig程序,就是通过C库函数sys_io ...
- [置顶] Linux协议栈代码阅读笔记(一)
Linux协议栈代码阅读笔记(一) (基于linux-2.6.21.7) (一)用户态通过诸如下面的C库函数访问协议栈服务 int socket(int domain, int type, int p ...
- Linux-3.0.8 input subsystem代码阅读笔记
先乱序记录一下阅读Linux input subsystem代码的笔记. 在input device driver的入口代码部分,需要分配并初始化input device结构,内核提供的API是inp ...
- [置顶] Linux协议栈代码阅读笔记(二)网络接口的配置
Linux协议栈代码阅读笔记(二)网络接口的配置 (基于linux-2.6.11) (一)用户态通过C库函数ioctl进行网络接口的配置 例如,知名的ifconfig程序,就是通过C库函数sys_io ...
- 《linux 内核全然剖析》 fork.c 代码分析笔记
fork.c 代码分析笔记 verifiy_area long last_pid=0; //全局变量,用来记录眼下最大的pid数值 void verify_area(void * addr,int s ...
- 《linux 内核全然剖析》sched.c sched.h 代码分析笔记
版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/u011368821/article/details/25129835 sched.c sched.h ...
- 使用Git和Github来管理自己的代码和笔记
一.Github注册 1.先注册github.com的账号,官方网站: https://github.com/ 2.登录 3.创建仓库,仓库分公开的和私有的,公开的是免费的,私有的是收费的.我现在创建 ...
随机推荐
- RIP 路由协议
RIP动态路由选择协议 routing information protocol IGP 小范围 路由器限制为15台 超过可能无法收敛 收敛概念 在一个域内 各个路由器知道各 ...
- 数据表自动生成java代码
MyBatis生成代码需要用到mybatis-generator-core-1.3.2.jar.数据库连接驱动包和一个xml文件,xml文件一般命令为:generator.xml. Xml内容格式如下 ...
- 【bzoj1965】 [Ahoi2005]SHUFFLE 洗牌 欧拉定理
题目描述 为了表彰小联为Samuel星球的探险所做出的贡献,小联被邀请参加Samuel星球近距离载人探险活动. 由于Samuel星球相当遥远,科学家们要在飞船中度过相当长的一段时间,小联提议用扑克牌打 ...
- 【Luogu】P3311数数(AC自动机上DP)
题目链接 蒟蒻今天终于学会了AC自动机,感觉很稳 (后一句愚人节快乐) 这题开一个f[i][j][k]表示有没有受到限制,正在枚举第j位,来到了AC自动机的第k个节点 的方案数 随后可以刷表更新 注意 ...
- Git的使用小结
1. git是一种分布式版本控制工具.目前项目中比较常见的版本控制器有SVN.CVS等,这些版本控制工具属于集中式版本控制器.集中式版本控制器,有一个中央服务器,开发人员的开发机从主服务器上下载了项目 ...
- [NOIP2017] 逛公园 (最短路,动态规划&记忆化搜索)
题目链接 Solution 我只会60分暴力... 正解是 DP. 状态定义: \(f[i][j]\) 代表 \(1\) 到 \(i\) 比最短路长 \(j\) 的方案数. 那么很显然最后答案也就是 ...
- 【CCF】地铁修建 改编Dijkstra
[题意] 给定有n个点,m条边的无向图,没有平行边和自环,求从1到n的路径中,最长段的最小值(最短路不再是路径和,而是所有段中的最大值) [AC] #include<iostream> # ...
- testng依赖
Testng提供了两种依赖实现 1.强制依赖:某个测试用例之前需要执行的依赖链中如果有一个失败,那么接下来所有的测试都不会被执行 2.顺序依赖(软依赖):顺序依赖的用处更多是用来检测一个测试链是否按照 ...
- 2018.8.6 Noip2018模拟测试赛(十九)
日期: 八月六号 总分: 300分 难度: 提高 ~ 省选 得分: 10分(MMP) 题目目录: T1:Tree T2:异或运算 T3:Tree Restoring 赛后反思: Emmmmm ...
- 【POJ3321】Apple Tree(DFS序,树状数组)
题意:给一棵n个节点的树,每个节点开始有一个苹果,m次操作 1.将某个结点的苹果数异或 1 2.查询一棵子树内的苹果数 n,m<=100000 思路:最近一段时间在思考树上统计问题的算法 发 ...