C++高级编程1 C++速成
C++高级编程1 C++速成
1.常用的预处理指令
#include [file]
#define key value 这个是在C中经常使用的,定义常量数值,用于字符串替换的工作。
#ifndef key #ifdef key
#define key
#endif
#pragma once 会因为编译器而有所不同,如果编译器支持的话可以用于代替上面的指令,在预处理阶段会提示警告。
#ifndef KEY
#define KEY
//code
#endif
可以使用#pragma once 代替。
2.C++运行程序传递的参数
int main(int argc,char ** argv):
其中argv表示的是这些参数,第一个参数都是程序的名字。
3.变量初始化
C++中如果使用了未初始化的变量,在程序编译期间会报错,但是我们可以通过指针输出指针指向的内存区域的对象数据,但是该数据是乱起八糟。
对于利用char 指针指向字符串,删除的时候需要使用 delete [] p,但是问题是必须char指向的是在堆中的内存空间,而不可以是字符串常量。
char *pChar = new char[100];
pChar[0] = 'a';
pChar[1] ='b';
pChar[2] = '\0';
cout << pChar << endl;
delete []pChar;
这个样子是可以的,但是如果char *p = "yangteng";但是不可以delete掉,因为这样的话,指针指向的是在常量区的数据.不可以删除.但是在此语句之前需要删除delete []p;
4.枚举类型
enum Type{
yang,teng=10,fei
};
cout <<"enum yang:"<< yang << endl;
cout <<"enum teng:" << teng << endl;
cout << "enum fei:" << Type::fei << endl;
5.C++11规范中新增加的循环:
int arr[] = {1,2,3,4,5,6};
for(auto i : arr){ // for(auto & i : arr)
i = i*2;
cout << i << " " ;
}
cout << endl;
for(auto i : arr){
cout << i<<" " ;
}
cout << endl;
6数组的初始化
int arr [10]={10};//只有第一个元素是10,其他的都初始化为0
for (int i =0; i<sizeof(arr)/sizeof(int) ; i++){
cout << arr[i] << " " ;
}
cout << endl;
在C++11 中引入了array (#include <array>)初始化为 0,但是大小在编译期间就已经决定了,不可以字运行的时候改变,运行时数组不会变大或者是变小。
array<int,4> arr = {9,7};
for(auto i : arr){
cout << i << " ";
}
7.堆栈的知识
堆栈和栈是在编译期间决定了内存的大小,因此在编程中是不可以声明大小可以变化的数组,必须是确定的值。
const int size = 100;
int arrays[size] ;
这样是对的,但是如果将const删除掉,就会出现编译不通过的错误提示。
8.字符串的形式
C风格的字符串:
char arrayString[10] = “yang”;最后面需要考虑\0字符。
char* p = “yang;
c++中使用的是string
9.const用法
定义常量 const float PI = 3.1415926;
const保护参数, void fun(const int a); 放置在程序中修改参数变量的值。
修饰方法,放在最后面,在成员函数中,如果不修改成员变量的话,就最好使用const修饰成员函数,然后在程序函数中如果不小心修改了成员变量,就会编译报错。
C++高级编程1 C++速成的更多相关文章
- 读《C#高级编程》第1章问题
读<C#高级编程>第1章 .Net机构体系笔记 网红的话:爸爸说我将来会是一个牛逼的程序员,因为我有一个梦,虽然脑壳笨但是做事情很能坚持. 本章主要是了解.Net的结构,都是一些概念,并没 ...
- MVC高级编程+C#高级编程
本人今年的目标是学习MVC高级编程和C#高级编程,把自己的基础打的扎实,本文中值是一个开到,定期会在上面记录学习的技术点和心得就,加油吧!!!!!
- 《C#高级编程》读书笔记
<C#高级编程>读书笔记 C#类型的取值范围 名称 CTS类型 说明 范围 sbyte System.SByte 8位有符号的整数 -128~127(−27−27~27−127−1) sh ...
- jquery插件开发继承了jQuery高级编程思路
要说jQuery 最成功的地方,我认为是它的可扩展性吸引了众多开发者为其开发插件,从而建立起了一个生态系统.这好比大公司们争相做平台一样,得平台者得天下.苹果,微软,谷歌等巨头,都有各自的平台及生态圈 ...
- jQuery高级编程
jquery高级编程1.jquery入门2.Javascript基础3.jQuery核心技术 3.1 jQuery脚本的结构 3.2 非侵扰事JavaScript 3.3 jQuery框架的结构 3. ...
- (十三) [终篇] 一起学 Unix 环境高级编程 (APUE) 之 网络 IPC:套接字
. . . . . 目录 (一) 一起学 Unix 环境高级编程 (APUE) 之 标准IO (二) 一起学 Unix 环境高级编程 (APUE) 之 文件 IO (三) 一起学 Unix 环境高级编 ...
- multiple definition of `err_sys' 《UNIX环境高级编程》
本文地址:http://www.cnblogs.com/yhLinux/p/4079930.html 问题描述: [点击此处直接看解决方案] 在练习<UNIX环境高级编程>APUE程序清单 ...
- Shell高级编程视频教程-跟着老男孩一步步学习Shell高级编程实战视频教程
Shell高级编程视频教程-跟着老男孩一步步学习Shell高级编程实战视频教程 教程简介: 本教程共71节,主要介绍了shell的相关知识教程,如shell编程需要的基础知识储备.shell脚本概念介 ...
- unix环境高级编程基础知识之第二篇(3)
看了unix环境高级编程第三章,把代码也都自己敲了一遍,另主要讲解了一些IO函数,read/write/fseek/fcntl:这里主要是c函数,比较容易,看多了就熟悉了.对fcntl函数讲解比较到位 ...
随机推荐
- 28UDP
UDP通信流程步骤: 服务端: 等待(被动)接收发送 1: 创建 socket: socket() 2: 绑定端口: bind() 3: 读取消息: read() 4: 发送消息 ...
- Jmeter使用流程及简单分析监控(转载)
转载自:https://www.cnblogs.com/linglingyuese/archive/2013/03/04/linglingyuese-one.html#undefined 一.安装Jm ...
- JS正则表达式从入门到入土(6)—— 贪婪模式与非贪婪模式
贪婪模式 之前说了正则的量词,但是量词会带来一个到底该匹配哪个的问题. 如下正则表达式: \d{3,6} 这个正则表达式是匹配3到6个数字,但是当这个正则表达式被用来匹配12345678这个字符串,到 ...
- IP查找所属网段
最近同学接到阿里面试题 package io.guangsoft.analysis; /* 数据文件: 1.1.1.0/24,123 1.1.2.0/28,345 1.2.0.0/16,789 */ ...
- 软件测试技术作业3---PrintPrimes()
一.代码部分: private static void printPrimes (int n) { int curPrime; // Value currently considered for pr ...
- 20145231熊梓宏 《网络对抗》 实验8 Web基础
20145231熊梓宏 <网络对抗> 实验8 Web基础 基础问题回答 ●什么是表单? 表单是一个包含表单元素的区域,表单元素是允许用户在表单中输入信息的元素,表单在网页中主要负责数据采集 ...
- The Startup Manager FAQ
Main Features: 1. Login Items: Manageable list of applications that are launched automatically ever ...
- 翻翻git之---丰富多样的路由跳转开源库 ARouter
转载请注明出处:王亟亟的大牛之路 有一段时间没更新博客了,最近也没学什么新东西,正好组里小伙在做路由跳转的一个"公共库",然后正好最近这样的轮子不少,我也就跟着看看,学习一下人家的 ...
- Matlab绘图基础——colormap在数字图像处理及三维图形展示上的应用(分层设色)
色图(color map)是MATLAB系统引入的概念.在MATLAB中,每个图形窗口只能有一个色图. 色图是m×3 的数值矩阵,它的每一行是RGB三元组.色图矩阵可以人为地生成 ...
- Unique Binary Search Trees,Unique Binary Search Trees2 生成二叉排序树
Unique Binary Search Trees:求生成二叉排序树的个数. Given n, how many structurally unique BST's (binary search t ...