指针c艹】的更多相关文章

#include <iostream> using namespace std;int value=1;void func(int *p){ p=&value; }void func(int **p).......重载{ *p=&value; }int main(){ int a=3; int *ptr; ptr=&a; cout<<*ptr<<endl; func(ptr);............传的是副本 cout<<*ptr&…
c++ 学习路线  c++学习路线 c++ 学习目录 c++ 常用数据类型,命名规则, 不常有数据类型 C++复合类型(数组) C艹复合类型(字符串) C++复合类型(结构体) C++ 结构体和枚举 C艹函数与结构体 C++指针 C++ 指针二维数组, C++二维指针数组笔记 C++ 面向对象 类成员函数this指针 C艹重复输入小方法,for循环+while C++视频课程 C++ 查看数据类型长短 , python的len的封装原理 C++ 面向对象 C++ 模板 template c++…
有两种不同的形式将const关键字指向指针. 第一种:让指针指向一个常量对象 const float g_moon = 1.63; float * pm = &g_moon; // 不允许 no allowed 第二种: 是将指针本身声明为常量 声明一个指向常量的指针pt ; const int *pt = &age; 这个声明表示, pt指向一个const int, 但不能使用*pt来修改age的值: 但是可以修改指向的内存地址 ; p = ∑ 注意,有种情况不允许: const flo…
在C艹中有两种字符串形式, 一种是C-风格, 另一种是C艹风格的 初始化: char str[10] = {'a', 'c', 'd', '\0'};char str[20]= “aaa”; string str = "aaa"; #include <iostream> #include <cstring> int main(int argc, char const *argv[]) { /* code */ using namespace std; ; cha…
C 内存开辟出的空间一般可以分成:代码段,数据段(初始化的数据段, 为初始化的数据段BSS),堆,栈 代码段:保存程序文本,指令指针EIP就是指向代码段,可读可执行不可写 数据段:保存初始化的全局变量和静态变量,可读可写不可执行 BSS:未初始化的全局变量和静态变量 堆(Heap):动态分配内存,向地址增大的方向增长,可读可写可执行 栈(Stack):存放局部变量,函数参数,当前状态,函数调用信息等,向地址减小的方向增长,非常非常重要,可读可写可执行 最特别的是 栈stack ,它和别人是反着的…
TODO:Golang指针使用注意事项 先来看简单的例子1: 输出: 1 1 例子2: 输出: 1 3 例子1是使用值传递,Add方法不会做任何改变:例子2是使用指针传递,会改变地址,从而改变地址. 在看例子3: 输出: map[a:aa b:bb] map[b:world a:hello] 发现什么了,TestMap前面没有加*,没有用指针,怎么也会改变值呢?因为map提供键值功能,用起来像指针引用的类型.类似这种功能的类型还有,数组切片,channel,interface.Go语言包这种指针…
要知道什么是智能指针,首先了解什么称为 “资源分配即初始化” what RAII:RAII—Resource Acquisition Is Initialization,即“资源分配即初始化” 在<C++ Primer>这样解释的,“通过定义一个类来封装资源的分配和释放,可以保证正确释放资源” 核心:C++98提供了语言机制:对象([!值语意对象])在超出作用域,,析构函数会被自动调用 [如果构造函数中抛出异常,则不会调用析构函数.只有构造函数正确地执行,构建对象成功,才会调用析构函数]  …
C++虚函数和函数指针一起使用,写起来有点麻烦. 下面贴出一份示例代码,可作参考.(需要支持C++11编译) #include <stdio.h> #include <list> using namespace std; class VirtualWithCallBack { public: using CallBack = void(VirtualWithCallBack::*)(int); public: ; ; }; class VirtualWithCallBackSamp…
多线程程序经常会遇到在某个线程A创建了一个对象,这个对象需要在线程B使用, 在没有shared_ptr时,因为线程A,B结束时间不确定,即在A或B线程先释放这个对象都有可能造成另一个线程崩溃, 所以为了省时间一般都是任由这个内存泄漏发生. 当然也可以经过复杂的设计,由一个监控线程来统一删除, 但这样会增加代码量和复杂度.这下好了,shared_ptr 可以方便的解决问题,因为它是引用计数和线程安全的. shared_ptr不用手动去释放资源,它会智能地在合适的时候去自动释放. 我们来测试看看效果…
数组变量和指针变量有一点小小的区别 所以把数组指针赋值给指针变量的时候千万要小心 加入把数组赋值给指针变量,指针变量只会包含数组的地址信息 而对数组的长度一无所知 相当于指针丢失了一部分信息,我们把这种信息的丢失称为退化 只要把数组当做参数传递给函数,数组免不了退化为指针 但需要记清楚代码中那些地方发生过数组退化 因为他会引起一些不易察觉的错误 举例说明: char ar[] = "abc";sizeof(ar) 结果为:6char *ch = ar; sizeof(ch) 结果为 8…