网站大量收购闲置独家精品文档,联系QQ:2885784924

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

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

  1. 1、本文档共34页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
* * * * * * 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精品文档

相关文档