• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            syhd142  
            日歷
            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567
            統計
            • 隨筆 - 23
            • 文章 - 122
            • 評論 - 31
            • 引用 - 0

            導航

            常用鏈接

            留言簿(2)

            隨筆檔案(23)

            文章分類(270)

            文章檔案(122)

            我的豆瓣

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

             
            void[1]:
            void是C語言中的空類型,void的用途有二。
            1、對函數返回的限定;
                  如果函數沒有返回值,則默認返回整數類型,而不是void類型。c++有很嚴格的類型,不允許函數不加類型聲明,而編譯器則不這么認為檢查這一點在VC6.0中可以驗證。所以在編寫代碼的時候,每個函數都應該加上返回類型。
            2、對函數參數的限定;
                  在c++中,函數參數為void意味著不接受參數,但是在c語言中可以給無參數的函數傳遞任意類型的參數,這點在turbo c中可以驗證。

            指針的大小和機器的位數有關,在32位機器上任何類型指針的大小都是4字節,在64位機器上為8。所以指針大小和類型無關
            void*就是空類型指針,所謂空類型指針就是通用指針類型。它有以下特點。
            1、按照ASC碼標準void指針不能做算術操作,因為不確定其指向數據類型大小;
            2、c++允許將任何類型的指針賦給void*,但是不允許void指針賦值給其它類型。必須顯示的強制轉換。

            其它類型指針相互之間是否也可以強制裝換?
               強制轉換后編譯能通過,大部分情況下運行也是沒有問題的,但是根據參考文獻[4]的說法是容易出問題的,因為某些CPU對某些數據類型有對其限制,這樣在做指針強制轉換的時候就容易出現問題。
               其實,其它類型指針之間的轉換完全可以通過使用void*類型來避免。

            sizeof[2]:

            前面說在同一臺機器上指針大小是固定的,通過sizeof測試int*,char*,bool*,double*都出結果都是4(32位機器測試)。
            今天在程序中memset一個T*類型的指針,發現沒有初始化成功,原來在memset的第三個參數中填的是sizeof(T*類型的指針)。特此總結了一下sizeof的一些問題。
            1、char* s="0123456789";
                  sizeof(s)=4,s是一個指針。
                  sizeof(*s)=1,*s是第一個元素。
                  strlen(s)=10,s是字符串首地址。
            2、char s[]="0123456789";
                  sizeof(s)=11,s是字符串數組,包括'\0'。
                  sizeof(*s)=1,*s是第一個元素。
                  strlen(s)=10,s是字符串首地址。
            3、char s[20]="0123456789";
                  sizeof(s)=20,s是在內存中靜態分配的大小。
                  sizeof(*s)=1,*s是第一個元素。
                  strlen(s)=10,s是字符串首地址。

            結構體[3]:

            結構體在字節對齊的時候有三個原則,有了這三個原則就很容易的可以計算出任意一個結構體的sizeof大小了。
            1、結構體變量的首地址能夠被其最寬基本類型的成員大小所整除;
            2、結構體每個成員相對于結構體首地址的偏移量(offset)都是成員大小的整數倍,如有需要編譯器會在成員之間加上填充字節(internal adding);
            3、結構體的總大小為結構體最寬基本類型成員大小的整數倍,如有需要編譯器會在最末一個成員之后加上填充字節(trailing padding)。

            參考文獻:
            [1]、http://blog.sina.com.cn/s/blog_625cce080100kip3.html
            [2]、http://shansun123.iteye.com/blog/398601 
            [3]、http://blog.csdn.net/Linux_Gao/article/details/2612885 
            [4]、http://blog.csdn.net/Linux_Gao/article/details/2612885
            posted on 2011-08-24 22:48 Fucker 閱讀(945) 評論(0)  編輯 收藏 引用
             
            Copyright © Fucker Powered by: 博客園 模板提供:滬江博客
            91精品国产高清久久久久久91| 狠狠精品久久久无码中文字幕| 亚洲国产高清精品线久久| 久久久国产精品福利免费| 国内精品久久久久久久coent| 2020最新久久久视精品爱| 久久精品中文字幕一区| 波多野结衣AV无码久久一区| 久久久久人妻一区精品色| 国产一区二区三区久久| 99久久香蕉国产线看观香| 韩国三级大全久久网站| 亚洲精品综合久久| 色综合合久久天天综合绕视看| 久久综合偷偷噜噜噜色| 麻豆精品久久精品色综合| 国产精品成人久久久| 品成人欧美大片久久国产欧美... 品成人欧美大片久久国产欧美 | 无码任你躁久久久久久老妇| 伊人久久大香线蕉av一区| 国产精品综合久久第一页| 人妻少妇久久中文字幕一区二区| 亚洲伊人久久大香线蕉苏妲己| 久久精品国产亚洲αv忘忧草| 激情久久久久久久久久| 国产精品一区二区久久精品| 欧洲精品久久久av无码电影| 2021国产精品午夜久久| 久久91精品综合国产首页| 97久久超碰国产精品旧版| 亚洲AV无码久久精品成人| 日日狠狠久久偷偷色综合0| 狠狠色丁香婷综合久久| av无码久久久久不卡免费网站| 久久久久久国产精品美女| 亚洲а∨天堂久久精品9966| 久久最新免费视频| 亚洲?V乱码久久精品蜜桃| 久久最新免费视频| 99久久综合国产精品免费| 国产亚洲精久久久久久无码77777|