华为c和c++笔试题.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
______________________________________________________________________________________________________________ (一) 1)什么是预编译,何时需要预编译? 答: a、总是使用不经常改动的大型代码体。 b、程序由多个模块组成,所有模块都使用一组标准的包含文件 和相同的编译选项。 在这种情况下, 可以将所有包含文件预编译为一个预编译头。 (2)char * const p char const * p const char *p 上述三个有什么区别? 答: char * const p: 常量指针, p 的值不可以修改 char const * p: 指向常量的指针,指向的常量值不可以改 const char *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; 请写出程序运行结果。 答:结果是: 0011 。 str1,str2,str3,str4 是数组变量,它们有各自的内存空间;而 str5,str6,str7,str8 是指针,它们指向相同的常量区域。 (4)以下代码中的两个 sizeof 用法有问题吗? 精品资料 ______________________________________________________________________________________________________________ void UpperCase( char str[] ) // 将 str 中的小写字母转换成大写 字母 {for( size_t i=0; i sizeof(str)/sizeof(str[0]); ++i ) if( a =str str =z ) str -= (a-A ); } char str[] = aBcDe; cout str 字符长度为 : sizeof(str)/sizeof(str[0]) endl; UpperCase( str ); cout str endl; 答案:函数内的 sizeof 有问题。根据语法, sizeof 如用于数组, 只能测出静态数组的大小,无法检测动态分配的或外部数组大 小。函数外的 str 是一个静态定义的数组,因此其大小为 6,因 为还有 \0 ,函数内的 str 实际只是一个指向字符串的指针,没有 任何额外的与数组相关的信息, 因此 sizeof 只将其当指针看, 一 个指针为 4 个字节,因此返回 4。 (5)一个 32 位的机器 ,该机器的指针是多少位? 答案: 指针是多少位只要看地址总线的位数就行了。 80386 以 后的机子都是 32 的数据总线。所以指针的位数就是 4 个字节了。 6)int main() {inta[5]={1,2,3,4,5};int*ptr=(int*)(a+1); printf(%d,%d,*(a+1),*(ptr-1)); } 写出该程序的运行结果。 精品资料 ______________________________________________________________________________________________________________ 答案: 2,5。 *(a+1 )就是 a[1] ,*(ptr-1) 就是 a[4], 执行结果是 2,5。 a+1 不是首地址 +1 ,系统会认为加一个 a 数组的偏移,是偏移了一 个数组的大小(本例是 5 个 int )。 int *ptr=(int *)(a+1); 则 ptr 实际是 (a[5]), 也就是 a+5 原因如下: a 是数组指针,其类型 为 int (*)[5]; 而指针加 1 要根据指针类型加上一定的值,不同类 型的指针 +1 之后增加的大小不同, a 是长度为 5 的 int 数组指 针,所以要加 5*sizeof(int) 所以 ptr 实际是 a[5]

文档评论(0)

lm027601 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档