标准命名空间

命名空间的使用

#define _CRT_SECURE_NO_WARNINGS
#include <iostream> using namespace std; // 命名空间必须定义在全局的作用域下
// 命名空间可以嵌套命名空间
// 如果命名空间冲突,则会自动的合并为一个命名空间 namespace zh {
int m_id = 10;
void Display(){ cout << "Display zh func" << endl; }
} namespace cn {
int m_id = 20; namespace cpp {
int m_id = 30;
}
} // 当写了无名空间,相当于写了 static int m_ptr;
// 静态变量只能在当前文件中使用
namespace{ int m_ptr = 10; } int main(int argc, char* argv[])
{
using namespace zh;
cout << zh::m_id << endl;
cout << cn::m_id << endl;
cout << cn::cpp::m_id << endl;
zh::Display(); system("pause");
return 0;
}

C++ 引用知识

引用的实质就是取别名,&写到左侧叫引用,写到右侧叫取地址。

普通的引用

#define _CRT_SECURE_NO_WARNINGS
#include <iostream> using namespace std; int main(int argc, char* argv[])
{ int a = 10;
int &b = a; // 引用 cout << b << endl; system("pause");
return 0;
}

数组引用

#define _CRT_SECURE_NO_WARNINGS
#include <iostream> using namespace std; int main(int argc, char* argv[])
{ int ary[10];
for (int x = 0; x < 10; x++)
ary[x] = x; // 给数组进行取别名
int(&parr)[10] = ary; // 用别名来输出
for (int y = 0; y < 10; y++)
{
cout << parr[y] << " " ;
} // 第二种方式取别名
typedef int(ARYS)[10]; // 一个具有10个元素的数组 ARYS &pary2 = ary;
for (int y = 0; y < 10; y++)
{
cout << pary2[y] << " ";
} system("pause");
return 0;
}

参数传递方式 参数传递两种方式,传递数值,传递地址,还可以传递引用

#define _CRT_SECURE_NO_WARNINGS
#include <iostream> using namespace std; // 指针传递
void mySwap(int *a, int *b)
{
int tmp = *a; *a = *b;
*b = tmp;
cout << *a << *b << endl;
} // 引用传递
void myswap2(int &a, int &b)
{
int tmp = a;
a = b;
b = tmp;
} int main(int argc, char* argv[])
{
int x = 10;
int y = 20; myswap2(x,y); cout << x << endl; system("pause");
return 0;
}

引用传递注意事项 int a = 10; 改成static 即可实现不销毁。

#define _CRT_SECURE_NO_WARNINGS
#include <iostream> using namespace std; int& dowork()
{
int a = 10; // 局部变量,返回前销毁了,引用就不存在了
return a;
} int main(int argc, char* argv[])
{
int &ret = dowork(); // 编译器做了优化,如果打印多次就会出现乱码 cout << ret << endl; // 10
cout << ret << endl; // 乱码了
cout << ret << endl;
cout << ret << endl;
cout << ret << endl; // 引用可以作为左值使用
dowork() = 1000; // 相当于写了 a = 1000; system("pause");
return 0;
}

引用的本质: 引用所占用的内存地址与指针类似,引用本质就是指针常量

#define _CRT_SECURE_NO_WARNINGS
#include <iostream> using namespace std; void test(int& ref)
{
ref = 1000;
} int main(int argc, char* argv[])
{ int a = 10;
int& aref = a; // 指针常量必须初始化,内部是一个指针常量 aref = 20; // 地址不可改 cout << a << endl; // 自动转为 *aref = 20; cout << aref << endl; system("pause");
return 0;
}

引用使用场景:指针的引用

#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <stdlib.h> using namespace std; struct person
{
int m_age; }; // 分配空间函数
// **p = > 具体的 person 对象
// *p => 对象的指针
// p => 指针的指针
void allocat(person **p)
{
*p = (person *) malloc(sizeof(person));
(*p)->m_age = 100; }
// 普通开辟空间写法
void test()
{
struct person *p = NULL;
allocat(&p); // 开始分配内存
cout << "p的:" << p->m_age << endl;
} // ------------------------------------------------
// 利用指针引用开辟空间
void allocatbyref(person* &p)
{
p = (person *)malloc(sizeof(person));
p->m_age = 1000;
}
void test2()
{
person *p = NULL;
allocatbyref(p);
cout << (*p).m_age << endl;
} int main(int argc, char* argv[])
{ test2();
system("pause");
return 0;
}

常量引用:

#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <stdlib.h> using namespace std; void test()
{
const int &ref = 10; // 加入const后,编译器会处理,创建了一个临时变量,int tmp = 10; const int &ref = tmp;
// ref = 10; 无法直接修改 // 换种方式修改它
int *p = (int*)&ref;
*p = 1000;
cout << ref << endl;
} int main(int argc, char* argv[])
{
test();
system("pause");
return 0;
}

常量引用使用场景: 用来修饰型can

#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <stdlib.h> using namespace std; void test(const int &val) // 不让你修改下
{ cout << val << endl;
} int main(int argc, char* argv[])
{
int a = 10; test(a);
system("pause");
return 0;
}

函数与类的一些知识点

内联函数,为了替换c中的宏,内联函数本身也是函数,只是加了一个关键字inline()

编译器会如何除了? 直接变成了宏,直接内嵌到调用的位置,并不增加新的函数。

在类中定义的,成员函数,默认会自动加上内联函数关键字声明,这是编译器为我们加上的。

但是,如果函数过大,或使用了循环等结构,则类则不会声明为内联函数。

#include <iostream>
#include <string> using namespace std; inline void compare(int x, int y)
{
int ret = x < y ? x : y;
cout << ret << endl;
} int main(int argc, char *argv[])
{
compare(10, 20);
system("pause");
return 0;
}

函数的默认参数

#include <iostream>
#include <string> using namespace std; void func(int x = 10, int y = 20)
{
cout <<x+y << endl;
} int main(int argc, char *argv[])
{
func(1, 20);
system("pause");
return 0;
}

函数重载: 名称相同,但是符号不同,后面的参数不同,就是重载。

当使用重载时,编译器会偷偷在前面加上 _func 关键字,这样来使用重载,通过编译检查。

using namespace std;

void func(int x)
{
cout <<x << endl;
} void func(double x)
{
cout << x << endl;
} int main(int argc, char *argv[])
{
func(1);
func(1.1);
system("pause");
return 0;
}

extern c 的作用: 在c++ 中想要使用C代码,需要加上extern 关键字。

#include <iostream>
#include <string> using namespace std; extern "C" void show()
{
printf("aaaaa \n");
} int main(int argc, char *argv[])
{
show();
system("pause");
return 0;
}

类的基本定义

#include <iostream>
#include <string> using namespace std; class Student
{
public:
int uid;
char *name;
int age; public:
void set(int id,char *name,int age)
{
this->uid = id;
this->name = name;
this->age = age;
}
void display()
{
cout << this->uid << this->name << this->age << endl;
}
}; int main(int argc, char *argv[])
{
Student stu; // 实例化 stu.set(1001, "lyshark", 23); // 设置数据
cout << stu.uid << stu.name << stu.age << endl; // 输出
stu.display(); // 使用成员函数输出 Student *ptr = &stu; // 使用指针
cout << ptr->uid << ptr->name << ptr->age << endl; system("pause");
return 0;
}

C语言实现的类: 这个是不是看起来很麻烦了,我们继续改进。

#include <iostream>
#include <string> using namespace std; struct Student
{
char name[64];
int age;
}; void PrintPerson(struct Student *ptr)
{
printf("Name: %s --> Age: %d \n", ptr->name, ptr->age);
} int main(int argc, char *argv[])
{
struct Student stu; strcpy(stu.name, "lyshark");
stu.age = 23;
PrintPerson(&stu); system("pause");
return 0;
}

C/C++ 命名空间引用知识的更多相关文章

  1. 命名空间引用问题 包括找不到ConfigurationManager 这个类

        因为SqlConnection类是属于 System.Data.SqlClient命名空间下的,     所以命名空间引用的时候需要加上 System.Data.SqlClient,代码如下: ...

  2. MVC layout 命名空间引用问题

    虽然用MVC做了很多项目,但是都是在别人搭好的框架上实现 今天碰到一个很简单的命名空间引用问题 如图所示,Scripts和Styles 都没有引用命名空间 解决方法一: 直接使用 System.Web ...

  3. using Sysyem.Net.Http命名空间引用不了的解决方案

    1.查看.Net Framework的框架是否是在4.5之上,如果不是要下载4.5之上的目标框架. 2.在引用器里面添加using System.Net.Http命名空间 选择项目列表中的“引用”-- ...

  4. C++基础 (1) 第一天 C++相对C的改进 命名空间 引用

    第一天 语法 STL 数据结构  设计模式… 2 C++语言的间接 C++ = C语言+面向对象 本贾尼 语言分类: 不关心效率 只关心架构:java/脚本语言 效率:(内存要自己管理了,操作指针)C ...

  5. java引用知识

    最近从新拜读<深入理解Java虚拟机:JVM高级特性与最佳实践>这本书,看到有关引用的相关知识,以前没有好的习惯,这次看完在博客上记录下 引用:如果reference类型中的数据存储的数值 ...

  6. C#自定义的命名空间引用

    项目右键引用 ,添加要引用的 然后在代码用 using 绰用

  7. C++基础 (2) 第二天 C++相对C的改进 命名空间 引用

    1 昨日回顾 2内联函数 3 默认参数和占位参数 4函数重载 函数重载 就是可以定义多个相同名字的函数 6 类和对象的基本语法 7 类的封装和访问控制 还有一个结论: 封装有两层含义: 把属性和方法进 ...

  8. C# 基础知识系列- 17 实战篇 编写一个小工具(1)

    0. 前言 这是对C# 基础系列的一个总结,现在我们利用之前学到的知识做一个小小的工具来给我们使用. 如果有看过IO篇的小伙伴,应该有印象.当时我提过一个场景描述,我们在平时使用系统的时候,经常会为了 ...

  9. python基础--面向对象基础(类与对象、对象之间的交互和组合、面向对象的命名空间、面向对象的三大特性等)

    python基础--面向对象 (1)面向过程VS面向对象 面向过程的程序设计的核心是过程(流水线式思维),过程即解决问题的步骤,面向过程的设计就好比精心设计好一条流水线,考虑周全什么时候处理什么东西. ...

  10. python模块引用梳理

    文件组织结构: t ├── __init__.py ├── main.py ├── t1 │   ├── A.py │   └── __init__.py └── t2 ├── B.py └── __ ...

随机推荐

  1. 详解 SSL(三):SSL 证书该如何选择?

    在上一篇< 详解 SSL(二):SSL 证书对网站的好处>中,我们知道了在网站部署 SSL 证书后,不管是对网站本身还是对网站的用户都能够带来许多好处.那么随着 HTTPS 的普及,市面上 ...

  2. Go--统计数组中重复的元素及重复次数

    代码: package main import ( "fmt" ) func main() { //创建有重复数值的数组 a1 := []int{1, 2, 3, 1, 4, 5, ...

  3. Centos7 cmake版本升级(v2.8.12.2->v3.16.6)

    1. 查看当前cmake版本 [root@localhost ~]# cmake -version cmake version 2.8.12.2 2. 进行卸载 [root@localhost ~]# ...

  4. ME21N 采购订单新增页签增强

    1.实现效果 根据客制化需求,要在采购订单中新增大量字段,所以要在界面上添加一个单独的页签.效果如下: 2.增强实现 2.1.增强结构 因为是在抬头上边添加,所以增强CI_EKKODB结构 2.2.函 ...

  5. Spring 学习笔记(5)AOP

    本文介绍 Spring 中 AOP 的原理及使用方式. Spring AOP 简介 如果说 IoC 是 Spring 的核心,那么面向切面编程就是 Spring 最为重要的功能之一了,在数据库事务中切 ...

  6. babel相关配置

    npm install --save-dev @babel/core @babel/cli @babel/preset-env @babel/node npm install --save @babe ...

  7. Power Designer建模之餐饮在线点评系统——概念数据模型

    企业信息管理 局部概念模型 企业 餐饮企业 食材提供商 食材 特色菜 团购活动 优惠券 促销活动 会员团购订单 优惠券下载和浏览记录表 会员信息管理 局部概念模型 会员 会员扩展信息 会员积分记录 餐 ...

  8. yakit的web fuzzer功能的使用

    问题 yakit没有Burp 的 Intruder 爆破模块,那么yakit该怎么进行参数爆破?yakit参数爆破的方式与burp有什么区别? 前言 手工测试场景中需要渗透人员对报文进行反复的发送畸形 ...

  9. 机器学习-线性分类-支持向量机SVM-SMO算法代码实现-15

    1. alpha2 的修剪 if y1 != y2 : α1 - α2 = k # 不用算k的具体大小 if k > 0: # 上图的左 下这条线 α2 的区间 (0, c-k) k < ...

  10. Kafka 面试题

    1. 为什么要使用 Kafka,为什么要使用消息队列 1.使用消息队列的目的: 服务解耦 流量削峰 异步通信 在早期的 web 应用程序开发中,当请求量突然上来了时候,我们会将要处理的数据推送到一个队 ...