程序员笔试一些总结

一:面向对象的三个特点

封装:封装是类和对象的特性。是把客观的事物封装成抽象的类。

继承:使用现有的类,在不重新编写现有的类的情况下对其进行功能上的拓展。 多态:分为覆盖和重载

覆盖:子类重新定义父类虚函数的做法。

重载:允许不同函数使用同一个函数名。

二:析构函数和构造函数

构造函数:作用是在创建对象是初始化对象。构造函数名必须和类名相同。可重载,不可继承。无返回值,也不能用void修饰。一个类中可以有多个构造函数。

析构函数:也必须与类名相同,不可继承,不可重载。一个类中只能有一个析构函数。 后构造的先析构。

三 public protected private default

当前类 同一包 子孙类 不同包

Public yes yes yes yes

Protected yes yes yes no

Default yes yes no no

Private yes no no no

四:collection 和 collections 的区别

Collection 是集合类的上级接口,list 和set继承collection接口,collections是集合类的帮助类。

五:重载和重写的区别

重写是指子类中定义了与父类相同的名称和参数的方法。构造器只能被重载,不能被重写。 六:error 好人exception 的区别

Error:该错误回复不是不可能但是难度很大,

Exception :如果程序正确运行不会出现这种情况。

七 hashtable 和hashmap 的区别

Hashtable不允许空键值,hashmap允许,因此hashmap效率较高。

多线程访问hashtable时,不需要自己为它的方法同步,hashmap需要。

1;在一个容量为15的循环队列中,若头指针front=6,尾指针rear=9,则该循环队列中共有 个元素 有四个元素,求元素个数可以用这个公式:(尾指针-头指针)%队列长度+1

2:c语言中的宏定义

简单的宏

带参数的宏 使用宏替代实际的参数有两个优点:

程序可能是稍微快些(一个函数调用在执行时通常会有些额外开销——存储上下文信息、复制参数的值等,而宏的调用则没有这些运行开销)

2. 宏会更“通用”(宏的参数没有类型,因此宏可以接受任何类型的参数) 宏的缺点 1.

编译后的代码通常会变大

宏参数没有类型检查(与函数调用不同,预处理器不会检查宏参数的类型,也不会进行类型转换)

3. 无法用一个指针来指向一个宏(宏不能用于c语言中的指向函数的指针) 4. 宏可能不止一次的计算它的参数(如n=MAX(i++,j);这个例子中第一个参数会产生

副作用,不会编译错误,但是,可能不会产生预想的结果)

1. 2.

Static 的用法

C程序一直由下列部分组成:

1)正文段——CPU执行的机器指令部分;一个程序只有一个副本;只读,防止程序由于意外事故而修改自身指令;

2)初始化数据段(数据段)——在程序中所有赋了初值的全局变量,存放在这里。

3)非初始化数据段(bss段)——在程序中没有初始化的全局变量;内核将此段初始化为0。

4)栈——增长方向:自顶向下增长;自动变量以及每次函数调用时所需要保存的信息(返回地址;环境信息)。

5)堆——动态存储分。

1.全局静态变量

在全局变量之前加上关键字static,全局变量就被定义成为一个全局静态变量。

1)内存中的位置:静态存储区(静态存储区在整个程序运行期间都存在)

2)初始化:未经初始化的全局静态变量会被程序自动初始化为0(自动对象的值是任意的,除非他被显示初始化)

3)作用域:全局静态变量在声明他的文件之外是不可见的。准确地讲从定义之处开始到文件结尾。

好处:

定义全局静态变量的好处:

(1)不会被其他文件所访问,修改

(2)其他文件中可以使用相同名字的变量,不会发生冲突。

.2.局部静态变量

在局部变量之前加上关键字static,局部变量就被定义成为一个局部静态变量。

1)内存中的位置:静态存储区

2)初始化:未经初始化的全局静态变量会被程序自动初始化为0(自动对象的值是任意的,除非他被显示初始化)

3)作用域:作用域仍为局部作用域,当定义它的函数或者语句块结束的时候,作用域随之结束。

注:当static用来修饰局部变量的时候,它就改变了局部变量的存储位置,从原来的栈中存放改为静态存储区。但是局部静态变量在离开作用域之后,并没有被销毁,而是仍然驻留在内存当中,直到程序结束,只不过我们不能再对他进行访问。

当static用来修饰全局变量的时候,它就改变了全局变量的作用域(在声明他的文件之外是不可见的),但是没有改变它的存放位置,还是在静态存储区中。

3. 静态函数

在函数的返回类型前加上关键字static,函数就被定义成为静态函数。 函数的定义和声明默认情况下是extern的,但静态函数只是在声明他的文件当中可见,不能被其他文件所用。

定义静态函数的好处:

(1)其他文件中可以定义相同名字的函数,不会发生冲突

(2)静态函数不能被其他文件所用。 存储说明符auto,register,extern,static,对应两种存储期:自动存储期和静态存储期。 auto和register对应自动存储期。具有自动存储期的变量在进入声明该变量的程序块时被建立,它在该程序块活动时存在,退出该程序块时撤销。

关键字extern和static用来说明具有静态存储期的变量和函数。用static声明的局部变量具有静态存储持续期(static storage duration),或静态范围(static extent)。虽然他的值在函数调用之间保持有效,但是其名字的可视性仍限制在其局部域内。静态局部对象在程序执行到该对象的声明处时被首次初始化。 .4.由于static变量的以上特性,可实现一些特定功能。

1)统计次数功能

声明函数的一个局部变量,并设为static类型,作为一个计数器,这样函数每次被调用的时候就可以进行计数。这是统计函数被调用次数的最好的办法,因为这个变量是和函数息息相关的,而函数可能在多个不同的地方被调用,所以从调用者的角度来统计比较困难。

5.不同类型变量的区别

与auto类型(普通)局部变量相比, static局部变量有三点不同

1) 存储空间分配不同

auto类型分配在栈上, 属于动态存储类别, 占动态存储区空间, 函数调用结束后自动释放, 而static分配在静态存储区, 在程序整个运行期间都不释放. 两者之间的作用域相同, 但生存期不同.

2)static局部变量在所处模块在初次运行时进行初始化工作, 且只操作一次

3)对于局部静态变量, 如果不赋初值, 编译期会自动赋初值0或空字符, 而auto类型的初值是不确定的. (对于C++中的class对象例外, class的对象实例如果不初始化, 则会自动调用默认构造函数, 不管是否是static类型)

特点: static局部变量的”记忆性”与生存期的”全局性”

所谓”记忆性”是指在两次函数调用时, 在第二次调用进入时, 能保持第一次调用退出时的值.

.6.外部静态变量/函数

在C中 static有了第二种含义:用来表示不能被其它文件访问的全局变量和函数。但为了限制全局变量/函数的作用域, 函数或变量前加static使得函数成为静态函数。但此处“static”的含义不是指存储方式,而是指对函数的作用域仅局限于本文件(所以又称内部函数)。注意此时, 对于外部(全局)变量, 不论是否有static限制, 它的存储区域都是在静态存储区, 生存期都是全局的. 此时的static只是起作用域限制作用, 限定作用域在本模块(文件)内部.

使用内部函数的好处是:不同的人编写不同的函数时,不用担心自己定义的函数,是否会与其它文件中的函数同名

~13=-14,~15=-16

#include<stdio.h>

#include<stdlib.h>

#include<string.h>

int main()

{char a[][3]={'a','b','c','d'};

char (*ptr)[3]=a;

ptr++;

printf("%d",sizeof(a)); //此时输出6

printf("%c",*(ptr[0]));//指向d

char *s="asdfghj";

printf("%d",sizeof(s));//输出4,指针所占字节数

printf("%d",strlen(s));//7

int c[7];

printf("%d",sizeof(c));//728

char f[]={'a','d'};

printf("%d",sizeof(f));//2

return 0;

}

A[i][j]; *(a[i]+j) *(&a[i][j]) *(*(a+i)+j)4 0

常见的内存错误

1:指针没有指向一块合法的内存。

2:为指针分配的内存太小。

3:内存分配成功,但未初始化。

4:内存越界

5:内存泄漏。

6:内存已经释放,但还是通过指针来使用

 

第二篇:程序员面试总结

广州金博信息技术有限公司

总结:

广州市乐天科技有限公司

总结

面试题 委托的关键字:delegate

数据库设计模式:单例,抽象工厂模式,工厂

数据库中having: 一个条件

面向对象:封装,继承,多态

Continue break的区别 break跳出 环,执行下一语句

Continue 跳出当前,执行下一语句

String 地址不可变 stringBuilder 地址可变

Int a=10,int b=15,

答: a=b-a;

b=b-a;

a=b+a;

面试:分页代码

Select * from (select * row_number() over (order by id) row from A) where row between 21 and 30

查出自动增长列断点中的最小值

Select min(id) * from A where id not in(select * row_number()over(order by id)row from A) 天展网络科技有限公司

面试题:

继承:子类对父类的子承父业

接口:是一组包含了函数型方法的数据结构。通过这组数据结构,客户代码可以调用组件对象的功能。

反射:动态调用程序集创建对象

用户登入查询:

Sqlconnection conn=new sqlconnection(connString);

String name=this.textName.text;

String pwd=this.password.text;

String sql=”select * from table where username=”+name+” and password=”+pwd+”;

Sqlcommand cmd=new sqlcommand(sql,conn);

Conn.open();

Datareader reader=cmd.exec;

While(reader.next()){

String ip=reader.getstring[3];

Datetime time=reader.getstring[4];

Session[“ip”]=ip;

Session[“time”]=time;

Response.redirect(“default.aspx”);

}

用递归删除文件目录下的文件

先得到所有的目录查询出文件,不是文件就继续递归获取是的话就删除文件

}

Jquery: $(“#username”).blur(function(){

If($(“#username”).val()==””){

Alert(‘不为空’);

}else{

$(“#username”).focus();

} 用JS和JQuery分别写出判断用户名和密码框是否为空 Js: Function validateForm(){ var name= document.getElementById(‘文本框的值’).value; Var pwd=Document.getElementById(“密码框的值”).value; If(name!=’’||pwd!=’’){}

});

两个数组合并成一个数组,进行全排列

Int a=new int[1,2,3];

Int b=new int[4,5,6];

Int total=new int[a.length+b.length];

For(int i=0,i<=a.length;i++){

Total[i]=a[i];

}

For(int j=0;j<b.length;j++){

Total[i+j]=b[j];

}

面试:等待时间长久心烦。对面试题的看法,因为一直是在电脑上操作,所以手写的时候不是那么顺畅。。

乐天科技有限公司复试

机试:用三层架构实现添删查改

广州众通电子科技有限公司

面试:问了第三个项目,那个是OA系统,我都不懂。Dataset和datareader的区别,dataset是数据集,datareader是一个指针,每次只读取一行信息。还设计了一个表。

相关推荐