首页 > 其他分享 >15指向成员变量和成员方法的指针

15指向成员变量和成员方法的指针

时间:2024-01-16 10:58:28浏览次数:24  
标签:15 cout int 成员 Test ma 指针

指向成员变量和成员方法的指针

指向成员变量的指针

class Test {
public:
	int ma;
	static int mb;
};

int Test::mb;

int main() {

    //类对象的成员变量指针不是普通的指针,需要加入类名限定符
    //类的静态成员变量指针不针对某一个特定对象,使用普通指针
	int* p = &Test::mb;
	int Test::* q = &Test::ma; 

	Test t1;
	Test *t2 = new Test();
	t1.ma = 1;
	t1.*q = 2;
	cout << t1.ma << endl;

	t2->ma = 1;
	t2->*q = 2;
	cout << t2->ma << endl;

	//t2->*p = 2; //错误
	*p = 2;
	cout << Test::mb << endl;
}

指向成员方法的指针

class Test {
public:
	void func() {
		cout << "func" << endl;
	}
	static void sfunc() {
		cout << "sfunc" << endl;
	}
	int ma;
	static int mb;
};

int Test::mb;

int main() {
	Test t1;
	Test *t2 = new Test();

    //普通成员函数指针是针对对象的,要加上类名限定符
    //静态成员函数指针不针对某一个特定对象,使用普通指针
	void(Test:: * func_ptr)() = &Test::func;
	void(* func_sptr)() = &Test::sfunc;

	(t1.*func_ptr)();
	(t2->*func_ptr)();

	(*func_sptr)();
}

标签:15,cout,int,成员,Test,ma,指针
From: https://www.cnblogs.com/sio2zyh/p/17967126

相关文章

  • 9类和对象与this指针
    类和对象,this面向对象的四大特性:抽象,封装/隐藏,继承,多态属性一般都是私有的,向外提供公有方法以访问私有属性。类本身不占内存,实例化对象占内存。类体内定义的成员函数默认为内联,体外定义需要加inline修饰。一个类可以定义无数的对象,每一个对象都有自己的成员变量,成员函数是公......
  • 《c++dll篇》VS2015生成dll及调用
    VS2015生成dll及调用原文链接:https://blog.csdn.net/qq_20792765/article/details/109801411创建DLL文件创建的DLL文件包括三个文件(.h/.dll/.lib),1、打开VS新建一个项目。2、选择DLL,附加选项选择空项目3、在头文件和源文件下分别添加如下文件4、在头文件CaculatorDLL.h......
  • 每日总结2024/1/15(爬虫学习)
    原文链接python爬虫-Python3.x+Fiddler抓取APP数据-学习分享-SegmentFault思否我爬取的为浏览器数据  可以看到在这里我们成功爬取到了浏览器数据,但是在实现python中爬取数据遇到了很多版本以及配置缺少的问题,同时我的版本中http为2,不知道有没有其他影响,代码目前......
  • 1月15日总结
    好呀,我是歪歪。Spring的事件监听机制,不知道你有没有用过,实际开发过程中用来进行代码解耦简直不要太爽。但是我最近碰到了一个涉及到泛型的场景,常规套路下,在这个场景中使用该机制看起来会很傻,但是最终了解到Spring有一个优雅的解决方案,然后去了解了一下,感觉有点意思。和你一......
  • 1.15模拟赛 T2题解
    简要题意多重背包但是乘法思路暴力就直接跑背包考虑乘法能否变为加法,可以找到模数的原根,将每个数映射一下,这样乘法就变成了加法,可以直接\(\text{bitset}\)优化,但是暴力这样做还是过不了于是我们考虑二进制分组优化背包,这样复杂度貌似就对了?code#pragmaGCCoptimize("Ofast......
  • CodeForces 1500C Matrix Sorting
    洛谷传送门CF传送门做了好久。怎么会是呢。题目的操作可以看成,求出一些关键字,使得\(B\)矩阵的行是由\(A\)按照这些第\(1\)关键字、第\(2\)关键字一直到第\(k\)关键字,最后还有一个原来所在行下标的关键字,从小到大排序。肯定是从排好序的\(B\)矩阵入手。首先任意找......
  • 闲话1.15
    今天接着摆了。上午打了场模拟赛,接着掉分......
  • 吴师兄学算法day07 双指针 680. 验证回文串 II
    题目:680. 验证回文串II易错点:s[1:3]是左闭右开我的第一次代码:classSolution(object):defvalidPalindrome(self,s):""":types:str:rtype:bool"""isPalindrome=lambdax:x==x[::-1]l......
  • 1.15闲话
    推歌:蜥蜴舞曲/洛天依by伊野奏/Creuzer/Realillusions为啥感觉今天我闲话内容都这么少的样子,可能是因为HS_xh这几天去搞whk了导致闲话水平大幅下降(他去搞whk管我啥事今天上午帮助高一大佬去找羽毛球拍然后没找到,回来用手一抹我去怎么流鼻血了(流汗黄豆)菜菜菜菜菜菜菜菜菜菜......
  • P1558 色板游戏
    原题链接题解1,种30棵树,每棵树代表每种颜色,树的每个节点代表这个颜色在对应区间上是否存在code#include<bits/stdc++.h>usingnamespacestd;intst[32][400005]={0};intlazy[32][400005]={0};voidpushdown(intwho,intnode){st[who][node*2]=lazy[who][node];......