复旦大学软件学院计算机系统课件 Array.pptVIP

复旦大学软件学院计算机系统课件 Array.ppt

  1. 1、本文档共34页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
* * * * * * Command-line Arguments $ echo hello, world $ hello, world #include stdio.h /* echo command-line arguments */ main(int argc, char *argv[]) { int i ; for ( i = 1; i argc ; i++) printf(“%s%s”, argv[i], (i argc-1) ? “ ” : “”); printf(“\n”) ; return 0; } 0 echo\0 Hello,\0 World\0 argv: Command-line Arguments #include stdio.h /* echo command-line arguments ; 2nd version*/ main(int argc, char *argv[]) { while ( --argc 0 ) printf(“%s%s”, ++argv, (argc 1) ? “ ” : “”); printf(“\n”) ; return 0; } printf((argc 1) ? “%s ” : “%s”); Pointer to Function #include stdlib.h /* numcmp: compare s1 and s2 numerically */ int numcmp(char *s1, char *s2) { double v1, v2; v1 = atof(s1); v2 = atof(s2); if (v1 v2) return -1; else if ( v1 v2 ) return 1; else return 0; } Pointer to Function #include stdio.h #include string.h { …… int numeric = 0, (*cmp)(void *, void *); char *s1, *s2; …… if (…) numeric = 1 ; …… cmp = ( int (*)(void *, void *)) (numeric ? numcmp : strcmp); (*cmp)(s1, s2); …… } * * * * * * * * * * * * * * * * * * * * * * * * * * * * Compilers Autumn 2002 Compilers Autumn 2002 * Array * Outline Aggregate scalar data into larger data Pointers vs. Array Array subscript and pointer arithmetic Memory layout for array Static vs. dynamic Compiler optimization for array operations Suggested reading 3.8 * Array declaration T A[N] ; Allocate a contiguous region in memory The size of the region is sizeof(T) * N bytes * Starting Address of an Array The starting address of an array A is denoted as XA Identifier A can be used as A pointer to the beginning of the array Its value is XA * Accessing Array Array elements can be accessed Using an integer index ranging between 0 and N-1 Array element i is stored at address XA + sizeof(T) * i * Array 0 1 2 3 4 5 6 7 8 9 10 11 0 4 8 12 16 char a[12] ; xa xa+4 xa+8 char *b[5] ; xb xb+4 xb+8 xb+12 xb+16 * Array 0 4 8 12 16 double c[2] ; xc xc+8 double *d[5] ; xd xd+4 xd+8 xd+12 xd+16 * Pointe

您可能关注的文档

文档评论(0)

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

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

1亿VIP精品文档

相关文档