1. int main()
  2. {
  3. int updates=; //定义int变量updates
  4. int * p_updates; //定义指针p_updates
  5. p_updates=&updates;//将updates的地址赋给指针p_upfates
  6.  
  7. cout<<"value:update="<<updates<<endl; //updates=6
  8. cout<<"*p_updates="<<*p_updates<<endl; //*p_updates为地址中存储的值 即6
  9.  
  10. cout<<"address:&updates="<<&updates<<endl; //&update 取地址
  11. cout<<"p_updates="<<p_updates<<endl; //p_updates 地址值
  12.  
  13. *p_updates=*p_updates+; //地址中存储的值加1 即6+1=7
  14. cout<<"now updates="<<updates<<endl; //update=7
  15. system("pause");
  16. return ;
  17. }

  1. int main()
  2. {
  3. int higgens=;
  4. int *pt=&higgens;
  5.  
  6. cout<<"value of higgens="<<higgens<<endl; //
  7. cout<<"address of higgens="<<&higgens<<endl; //地址
  8. cout<<"value of *pt="<<*pt<<endl; //
  9. cout<<"value of pt="<<pt<<endl; //地址
  10. system("pause");
  11. }

  1. int main()
  2. {
  3. double * p3=new double [];//定义一个double类型的指针
  4. p3[]=0.2;
  5. p3[]=0.5;
  6. p3[]=0.8;
  7. cout<<"p3[1] is"<<p3[]<<endl; //p3当做数组名使用,p3[1]为第二个元素
  8. p3=p3+;//修改指针的值,+1之后p3[0]指向的是之前的第二个值
  9. cout<<"now p3[0] is"<<p3[]<<endl;
  10. cout<<"p3[1] is"<<p3[]<<endl;
  11. p3=p3-; //为delete []提供正确的地址
  12. delete [] p3;
  13.  
  14. system("pause");
  15. return ;
  16. }

  1. int main()
  2. {
  3. double wages[]={10000.0,20000.0,30000.0};
  4. short stacks[]={,,};
  5. double *pw=wages;
  6. short *ps=&stacks[];
  7.  
  8. cout<<"pw="<<pw<<",*pw="<<*pw<<endl;
  9. pw=pw+;
  10. cout<<"pw="<<pw<<",*pw="<<*pw<<endl;
  11. cout<<"ps="<<ps<<",*ps="<<*ps<<endl;
  12. ps=ps+;
  13. cout<<"ps="<<ps<<",*ps="<<*ps<<endl;
  14. cout<<"stacks[0]="<<stacks[]<<",stacks[1]="<<stacks[]<<endl;
  15. cout<<"*stacks="<<*stacks<<",*(stacks+1)="<<*(stacks+)<<endl;
  16.  
  17. cout<<sizeof(wages)<<"=size of wages array"<<endl;//数组长度 3*8=24
  18. cout<<sizeof(pw)<<"=size of pw pointer"<<endl; //指针长度 4 在32位机上,所有指针类型变量占用内存字节数都为4 ,64位机指针占用的内存大小为8个字节
  19. system("pause");
  20. return ;
  21. }

指针 * &的更多相关文章

  1. TODO:Golang指针使用注意事项

    TODO:Golang指针使用注意事项 先来看简单的例子1: 输出: 1 1 例子2: 输出: 1 3 例子1是使用值传递,Add方法不会做任何改变:例子2是使用指针传递,会改变地址,从而改变地址. ...

  2. enote笔记法使用范例(2)——指针(1)智能指针

    要知道什么是智能指针,首先了解什么称为 “资源分配即初始化” what RAII:RAII—Resource Acquisition Is Initialization,即“资源分配即初始化” 在&l ...

  3. C++虚函数和函数指针一起使用

    C++虚函数和函数指针一起使用,写起来有点麻烦. 下面贴出一份示例代码,可作参考.(需要支持C++11编译) #include <stdio.h> #include <list> ...

  4. C++11 shared_ptr 智能指针 的使用,避免内存泄露

    多线程程序经常会遇到在某个线程A创建了一个对象,这个对象需要在线程B使用, 在没有shared_ptr时,因为线程A,B结束时间不确定,即在A或B线程先释放这个对象都有可能造成另一个线程崩溃, 所以为 ...

  5. c 数组与指针的使用注意事项

    数组变量和指针变量有一点小小的区别 所以把数组指针赋值给指针变量的时候千万要小心 加入把数组赋值给指针变量,指针变量只会包含数组的地址信息 而对数组的长度一无所知 相当于指针丢失了一部分信息,我们把这 ...

  6. Marshal.Copy将指针拷贝给数组

    lpStatuss是一个UNITSTATUS*的指针类型实例,并包含SensorDust字段 //定义一个数组类型 byte[] SensorDust = new byte[30] //将指针类型拷贝 ...

  7. C++智能指针

    引用计数技术及智能指针的简单实现 基础对象类 class Point { public: Point(int xVal = 0, int yVal = 0) : x(xVal), y(yVal) { ...

  8. EC笔记:第三部分:17、使用独立的语句将newed对象放入智能指针

    一般的智能指针都是通过一个普通指针来初始化,所以很容易写出以下的代码: #include <iostream> using namespace std; int func1(){ //返回 ...

  9. 智能指针shared_ptr的用法

    为了解决C++内存泄漏的问题,C++11引入了智能指针(Smart Pointer). 智能指针的原理是,接受一个申请好的内存地址,构造一个保存在栈上的智能指针对象,当程序退出栈的作用域范围后,由于栈 ...

  10. 智能指针unique_ptr的用法

    unique_ptr是独占型的智能指针,它不允许其他的智能指针共享其内部的指针,不允许通过赋值将一个unique_ptr赋值给另一个unique_ptr,如下面错误用法: std::unique_pt ...

随机推荐

  1. HttpServletRequest接口是怎么实现的

    request只是规范中的一个名称而已.不是SUN提供的,这是由各个不同的Servlet提供商编写的,SUN只是规定这个类要实现HttpServletRequest接口,并且规定了各个方法的用途,但具 ...

  2. Win10激活Office2013的技巧

    原文:http://www.xitongzhijia.net/xtjc/20150720/53252.html KMSpico Win10激活工具 是一款能激活Win8/Win8.1/win10/Of ...

  3. JS --- 数组循环要用length

    socket.on("receive", function (data) { deviceone.print("返回的数据:"+data) // 发送异常 va ...

  4. python爬虫遇到10060

    python爬虫遇到10060 学习了:https://blog.csdn.net/wetest_tencent/article/details/51272981 可以设置代理,可以手动进行图片获取:

  5. angular1.x 组件开发

    搜索框组件开发: 1.注册组件 app.js angular.module("myApp",[]) .component("nameSearch",{ temp ...

  6. 【iOS】系统框架学习

    iOS的系统架构分为四个层次:核心操作系统层(Core OS layer).核心服务层(Core Services layer).媒体层(Media layer)和可触摸层(Cocoa Touch l ...

  7. binary-tree-postorder-traversal——二叉树后续遍历

    Given a binary tree, return the postorder traversal of its nodes' values. For example:Given binary t ...

  8. eclipse 配置执行hadoop 2.7 程序样例參考步骤

    前提:你搭建好了hadoop 2.x的linux环境,并可以成功执行.还有就是window可以訪问到集群.over 1. hfds-site.xml 添加属性:关闭集群的权限校验.windows的用户 ...

  9. js 类继承extends

    先看例子: <!DOCTYPE html><html> <head> <meta charset="UTF-8"> <titl ...

  10. 从头学起-CLR的执行模型

    1.将源代码编译成托管代码 公共运行时(Common Language Runtime) a.面向运行时的所有语言都可以通过异常报告错误 b.面向运行时的所有语言都可以创建线程 c.核心功能:管理内存 ...