(1)什么是預編譯,何時需要預編譯:
答案:
1、總是使用不經常改動的大型代碼體。
2、程序由多個模塊組成,所有模塊都使用一組標準的包含文件和相同的編譯選項。在這種情況下,可以將所有包含文件預編譯為一個預編譯頭。
(2)char * const p char const * p const char *p 上述三個有什么區別?
答案:
char * const p; //常量指針,p的值不可以修改
char const * p;//指向常量的指針,指向的常量值不可以改 const char *p; //和char const *p
(3)char str1[] ="abc"; char str2[] = "abc"; const char str3[] ="abc"; const char str4[] = "abc"; const char *str5 ="abc"; const char *str6 = "abc"; char *str7 ="abc"; char *str8 = "abc"; cout < < ( str1 == str2 )< < endl; cout < < ( str3 == str4 ) < < endl; cout < <( str5 == str6 ) < < endl; cout < < ( str7 == str8 ) < <endl;
結果是:0 0 1 1 str1,str2,str3,str4是數組變量,它們有各自的內存空間;而str5,str6,str7,str8是指針,它們指向相同的常量區域。
(4)以下代碼中的兩個sizeof用法有問題嗎?
[C易] void UpperCase( charstr[] ) // 將 str 中的小寫字母轉換成大寫字母 { for( size_t i=0; i<sizeof(str)/sizeof(str[0]); ++i ) if( 'a' <=str[i] && str[i] <='z' ) str[i] -= ('a'-'A' ); } char str[]= "aBcDe"; cout < < "str字符長度為: " < <sizeof(str)/sizeof(str[0]) < < endl; UpperCase( str ); cout < < str< < endl; 答案:函數內的sizeof有問題。根據語法,sizeof如用于數組,只能測出靜態數組的大小,無法檢測動態分配的或外部數組大小。函數外的str是一個靜態定義的數組,因此其大小為6,因為還有' 主站蜘蛛池模板: 99久久久国产精品免费调教网站 | 亚洲国产精品va在线看黑人动漫 | 蜜桃视频一区二区三区在线观看 | 久久久噜噜噜久久中文字幕色伊伊 | 成人免费大片黄在线播放 | 精品在线一区二区 | 亚洲激情综合 | 国产激情视频 | av片在线观看网站 | 国产精品久久久久久久久久久久冷 | 欧美3级| www.久久.com| 午夜精品久久久久久99热软件 | 国产精品久久二区 | 国产小视频在线观看 | 国产综合视频在线观看 | 一级电影a | 日韩精品在线观看视频 | 国产成人免费网站 | 亚洲视频二 | 精品久久久久久久久久久下田 | 99热精品在线播放 | 91福利国产在线观看菠萝蜜 | 激情视频网址 | 99一区二区 | 天天天综合网 | 国产精品成人3p一区二区三区 | 免费午夜av | 中文字幕免费av | 国产精品一区在线 | 成人日韩精品 | 亚洲精品电影网在线观看 | 国产日韩欧美在线 | 久久久久亚洲 | 91精品国产日韩91久久久久久 | 欧美日韩视频一区二区 | 久久er99热精品一区二区 | 欧美高清视频在线观看 | 国产伦精品一区二区免费 | 国产精品久久久久久久久 | 欧美日韩精品一区二区三区 |