linux內(nèi)核中的typeof
今天分析內(nèi)核時(shí)又看到了typeof,只知道它大概是返回變量的類型,后來(lái)上網(wǎng)查了下發(fā)現(xiàn)這個(gè)關(guān)鍵字在linux中用的非常多。如果你對(duì)sizeof很熟悉的話,那么大可進(jìn)行類推,sizeof(exp)返回的是exp的數(shù)據(jù)類型大小,那么typeof(exp.)返回的就是exp的數(shù)據(jù)類型。下面是linux內(nèi)核中typeof的一些例子。
本文引用地址:http://m.butianyuan.cn/article/201611/319991.htminclude/linux/kernel.h- /*
- *min()/max()macrosthatalsodo
- *stricttype-checking..Seethe
- *"unnecessary"pointercomparison.
- */
- #definemin(x,y)({
- typeof(x)_x=(x);//_x的數(shù)據(jù)類型和x一樣
- typeof(y)_y=(y);
- (void)(&_x==&_y);
- _x<_y?_x:_y;})
- #definemax(x,y)({
- typeof(x)_x=(x);
- typeof(y)_y=(y);
- (void)(&_x==&_y);
- #defineget_user(x,p)
- ({
- constregistertypeof(*(p))__user*__pasm("r0")=(p);//__p的數(shù)據(jù)類型和*(p)的指針數(shù)據(jù)類型是一樣的,__p=p
- registertypeof(*(p))__r2asm("r2");//__r2的數(shù)據(jù)類型和*(p)的數(shù)據(jù)類型是一樣的
- registerint__easm("r0");
- switch(sizeof(*(__p))){
- case1:
- __get_user_x(__r2,__p,__e,1,"lr");
- break;
- case2:
- __get_user_x(__r2,__p,__e,2,"r3","lr");
- break;
- case4:
- __get_user_x(__r2,__p,__e,4,"lr");
- break;
- case8:
- __get_user_x(__r2,__p,__e,8,"lr");
- break;
- default:__e=__get_user_bad();break;
- }
- x=__r2;
- __e;
- })
- #include
- typedefstruct
- {
- intx;
- chary;
- }astruct,*pastrcut;
- intmain()
- {
- intsizem,sizew;
- intx=3;
- typeof(&x)m=&x;
- sizem=sizeof(m);
- *m=5;
- typeof(((astruct*)5)->y)w;
- sizew=sizeof(w);
- w="a";
- return1;
- }
首先看main函數(shù)里的m變量,這個(gè)變量的類型就是typeof(&x), 由于x是int型的(這里與x是否被賦值一點(diǎn)關(guān)系都沒(méi)有),所以&x應(yīng)該是int *類型,那么typeof(&x)返回的類型就是int*,所以m自然也就是個(gè)int*類型的。
然后我們看w變量,其類型是 typeof(((astruct *)5)->y), 其中astruct是一個(gè)被定義的結(jié)構(gòu)類型,其中的y元素是char類型,那么((astruct *)5)->y是啥意思呢?在這里5并不是真正的變量,可以把它理解為一個(gè)替代使用的符號(hào),當(dāng)然這個(gè)符號(hào)最好是一個(gè)數(shù),其意思更可以理解為一個(gè)被賦值了的變量,這個(gè)數(shù)可以是0,3,也可以是8也可以隨便什么都可以。那么((astruct *)5)->y僅僅就是表示了y這個(gè)變量,所以typeof的結(jié)果就是y元素的類型,也就是char。
評(píng)論