Status ListInsert_Sq(SqList *L,int i,LElemType_Sq e) {

LElemType_Sq *newbase;

LElemType_Sq *p,*q;

if(i<0 || i>(*L).length+1)

return ERROR; // i值不合法

if((*L).length >= (*L).listsize) { //若存储空间已满,需开辟新空间

newbase = (LElemType_Sq*)realloc((*L).elem,((*L).listsize+LIST_INCREMENT)*sizeof(LElemType_Sq));

if(!newbase)

exit(OVERFLOW);

(*L).elem=newbase;

(*L).listsize+=LIST_INCREMENT;

}

q=&(*L).elem[i]; // q为插入位置

for(p=&(*L).elem[(*L).length-1]; p>=q; --p)

*(p+1)=*p; // 插入位置及之后的元素右移

*q=e; // 插入e

++(*L).length; // 表长增1

return OK;

}

void SequenceList() {

SqList L;

int i;

LElemType_Sq e;

InitList_Sq(&L);

printf("\nSequenceList\n");

//ListInsert_Sq(&L,0,0);

ListInsert_Sq(&L,1,1);

ListInsert_Sq(&L,2,4);

ListInsert_Sq(&L,3,666);

ListTraverse_Sq(L,SequenceList_PrintElem);

i=ListLength_Sq(L);

printf(",ListLength_Sq=%d",i);

}

Status ListTraverse_Sq(SqList L,void(Visit)(LElemType_Sq)) {

int i;

for(i=-2; i<=L.length; i++) {

Visit(L.elem[i]);

printf("--&(L.elem[%d])=%d--",i,&(L.elem[i]));

}

}

SequenceList

e=1650049076,&e=2293104--&(L.elem[-2])=4518744--

e=268582613,&e=2293104--&(L.elem[-1])=4518748--

e=3827376,&e=2293104--&(L.elem[0])=4518752--

e=1,&e=2293104--&(L.elem[1])=4518756--

e=4,&e=2293104--&(L.elem[2])=4518760--

e=666,&e=2293104--&(L.elem[3])=4518764--,ListLength_Sq=3

--------------------------------

Process exited after 0.01549 seconds with return value 0

请按任意键继续. . .

https://github.com/toywei/Data-Structure

字符串常量就是字符数组,字符串的内部标识使用一个空字符'\0'作为串的结尾
存储字符串的物理存储单元数比括在双引号中的字符数多1个
C语言对字符串的长度没有限制,但是程序必须在扫描完整整个字符串后才能确定字符串的长度

C has been designed to make functions efficient and easy to use; C programs generally consist of many small functions rather than a few big ones. A program may reside in one or more source files. Source files may be compiled separately and loaded together, along with previously compiled functions from libraries. We will not go into that process here, however, since the details vary from system to system.

C语言程序一般都由许多小的函数组成,而不是由少量较大的函数组成。一个程序可以保存在一个或多个源文件中。各个文件可以单独编译,并可以与库中已编译

过的函数一起加载。

The standard clarifies the rules on the scope of names; in particular, it requires that there be only one definition of each external object. Initialization is more general: automatic arrays and structures may now be initialized.

C语言可以看成由一些列的外部对象构成,这些外部对象可能是变量或函数。形容词external与internal相对的,internal用于描述定义在函数内部的函数参数及变量。

外部变量定义在函数之外,一次可以再许多函数中使用。

由于C语言不允许在一个函数中定义另外其他函数,因此函数本身是“外部”的。

默认情况下,外部变量与函数具有下列性质:通过同一个名字对象(标准中把这一性质称为外部链接)。

princf("hello, world\n"};

printf接受的是一个指向字符数组第一个字符的指针。

程序可以通过检查空字符找到字符数组的结尾。

字符串常量可以通过指向其第一个元素的指针访问。

对内存分配的理解 自动变量 局部变量 临时变量 外部变量 字符串长度 C语言可以看成由一些列的外部对象构成的更多相关文章

  1. 深入理解Java虚拟机二:垃圾收集与内存分配

    垃圾收集:垃圾收集要完成三件事,包括哪些内存需要回收,什么时候回收及如何回收. 1.需要回收的内存判定:没有引用指向原先分配给某个对象的内存时,则该内存是需要回收的垃圾 Java垃圾收集器在对内存进行 ...

  2. C语言中的内存分配与释放

    C语言中的内存分配与释放 对C语言一直都是抱着学习的态度,很多都不懂,今天突然被问道C语言的内存分配问题,说了一些自己知道的,但感觉回答的并不完善,所以才有这篇笔记,总结一下C语言中内存分配的主要内容 ...

  3. 【java虚拟机序列】java中的垃圾回收与内存分配策略

    在[java虚拟机系列]java虚拟机系列之JVM总述中我们已经详细讲解过java中的内存模型,了解了关于JVM中内存管理的基本知识,接下来本博客将带领大家了解java中的垃圾回收与内存分配策略. 垃 ...

  4. Netty源码分析第5章(ByteBuf)---->第7节: page级别的内存分配

    Netty源码分析第五章: ByteBuf 第六节: page级别的内存分配 前面小节我们剖析过命中缓存的内存分配逻辑, 前提是如果缓存中有数据, 那么缓存中没有数据, netty是如何开辟一块内存进 ...

  5. 浅谈JVM内存分配与垃圾回收

    大家好,我是微尘,最近又去翻了周志明老师的<深入理解Java虚拟机>这本书.已经看了很多遍了,每次都感觉似乎看懂了,但没过多久就忘了.这次翻了第三章的垃圾收集器与内存分配策略,感觉有了新的 ...

  6. SQLite剖析之动态内存分配

    SQLite通过动态内存分配来获取各种对象(例如数据库连接和SQL预处理语句)所需内存.建立数据库文件的内存Cache.保存查询结果. 1.特性    SQLite内核和它的内存分配子系统提供以下特性 ...

  7. Java深入 - Java 内存分配和回收机制

    Java的GC机制是自动进行的,和c语言有些区别需要程序员自己保证内存的使用和回收. Java的内存分配和回收也主要在Java的堆上进行的,Java的堆中存储了大量的对象实例,所以Java的堆也叫GC ...

  8. Java 对象内存分配与回收

    JVM内存区域模型: * 程序计数器,内存区域极小,是当前线程的字节码执行行号指示器: * 虚拟机栈.本地方法栈,即平时所说的“栈”,是虚拟机用来执行方法(包括Java.非Java方法)时,使用的临时 ...

  9. Java深入 - Java 内存分配和回收机制-转

    Java的GC机制是自动进行的,和c语言有些区别需要程序员自己保证内存的使用和回收. Java的内存分配和回收也主要在Java的堆上进行的,Java的堆中存储了大量的对象实例,所以Java的堆也叫GC ...

随机推荐

  1. Bash 中的特殊字符大全【转】

    Linux下无论如何都是要用到shell命令的,在Shell的实际使用中,有编程经验的很容易上手,但稍微有难度的是shell里面的那些个符号,各种特殊的符号在我们编写Shell脚本的时候如果能够用的好 ...

  2. [svc]tomcat配置文件详解-最简单的基于mvn的war包

    tomcat安全管理规范 java&tomcat配置参考(多看看这位大牛的博客,写的很好) Tomcat系列之Java技术详解 http://blog.51cto.com/freeloda/1 ...

  3. Socket网络编程--简单Web服务器(4)

    上一小节已经实现了对图片的传输,接下来就是判断文件是否为js,css,png等格式.我们增加一个函数用于判断格式 int WebServer::get_filetype(char *type,char ...

  4. Fluent动网格【1】:概述

    最近总有小伙伴向我询问Fluent中的动网格问题,因此决定做一期关于Fluent动网格技术的内容. 动网格技术在流体仿真中很特殊,应用也很广.生活中能够碰到形形色色的包含有部件运动的问题,比如说我现在 ...

  5. 【Python】socket模块应用

    [Socket] 本文记录了一些socket模块的简单应用,对于具体原理还没来得及深究. ■ 利用socket模块进行端口连接验证和扫描 在linux中常用nc命令来进行远端端口是否开放的验证.但是这 ...

  6. Java知多少(14)数组

    如果希望保存一组有相同类型的数据,可以使用数组. 数组的定义和内存分配 Java 中定义数组的语法有两种: type arrayName[]; type[] arrayName; type 为Java ...

  7. Java知多少(22)方法重载

    在Java中,同一个类中的多个方法可以有相同的名字,只要它们的参数列表不同就可以,这被称为方法重载(method overloading). 参数列表又叫参数签名,包括参数的类型.参数的个数和参数的顺 ...

  8. WPF Input Validation Using MVVM

    Data validation is a key part in WPF.Validation is used to alert the user that the data he entered i ...

  9. 牛客网_Go语言相关练习_选择题(3)

    题目来源于牛客网 一.选择题 Go语言自带垃圾回收机制. 如果是值传递的话子函数对map修改不会影响父函数中的map,如果是地址传递则会影响. go语言编译器会自动在以标识符.数字字面量.字母字面量. ...

  10. 对于Python中@property的理解和使用

    @property 这个我们在很多代码中都会用到,简单讲即为一个只读属性的调用 如果需要有修改权限,需要再加一个@属性名.setter 例: #!/usr/bin/env python # -*- c ...