规划方面
获取节点的几种方式
通过ID获取(getElementById)
通过name属性(getElementsByName)
通过标签名(getElementsByTagName)
通过类名(getElementsByClassName)
获取html的方法(document.documentElement)
获取body的方法(document.body)
通过选择器获取一个元素(querySelector)
通过选择器获取一组元素(querySelectorAll)
事务的特性
一致性、原子性、隔离性、持久性
Ajax五个状态
0 - (未初始化)还没有调用send()方法
1 - (载入)已调用send()方法,正在发送请求
2 - (载入完成)send()方法执行完成,已经接收到全部响应内容
3 - (交互)正在解析响应内容
4 - (完成)响应内容解析完成,可以在客户端调用了
单例
Class single{
Private static $instance =null;
Private function __construct(){}
Private function __clone(){}
Public function getinstance(){
If(!isset(self::instance)){
Self::$instance=new self();
}
Return $instance;
}
}
优化数据库方式:
选取合适的字段属性、
使用连接代替子查询、事务、使用联合代替手动创建的临时表、锁定表、使用外键、使用索引、优化查询语句
尽可能的使用not null
使用ENUM枚举,而不是varchar(性别,民族,部门等)
如何查下看最后插入的记录:
1、如果有自增字段id查看最大id
2、mysql_insert_id()
3、Mysql_last_insert();
4、Information_schema
Print\print_r\echo\var_dump区别:
Print 是打印字符串
Print_r 则是打印复合类型 如数组 对象
Var_dump
Echo 没有返回值
Include\require区别
Require: |
一个文件存在错误时,执行就会中断。并返回一个致命错误 |
include |
一个文件存在错误,程序不会中断执行。会弹出一个警告 |
Echo 其他进制数值时,自动转换为十进制
页面跳转:header(location:’www.baidu.com’)
查看一个文件下的所有文件
Array Glob(pattern,flag)//glob(‘*.*’)匹配所有文件
1、Foreach(glob(‘*.*’) as $filename){
Echo “filename is ”.$filename;
}
2、if($handle=opendir(‘./’)){
Echo “files:\n”;
While(($file=readdir($handle))!==false){
Echo “$file \n”;
}
Closedir($handle)
}
3、$d=dir(“./”);
Echo ”handle:”.$d->handle.”
”;
Echo “path:”.$d->path.”
”;
While(($file=$d->read())!==false){
Echo “filename:”.$file.”
”;
}
数据库存储,金额存储类型?
decimal
如何通过月份筛选?
datediff(date1,date2)返回日期之间差
Date_format(date,format)
Having group by
SELECT ProductID, Total = SUM(LineTotal)
FROM Sales.SalesOrderDetail
GROUP BY ProductID
HAVING SUM(LineTotal) > $2000000.00 ;
Nginx?
高并发
低内存消耗
高扩展性,跨平台
高可靠
更快,响应更快
热部署
最自由的BSD许可协议
索引类型:
普通索引、唯一索引、主键索引、组合索引、全文索引
Mysql数据类型?
TINYINT、SMALLINT、MEDIUMINT、INT、BIGINT
FLOAT、DOUBLE
DATE、TIME、DATETIME、TIMESTAMP
CHAR、VARCHAR、TINYTEXT、TEXT、MEDIUMTEXT、LONGTEXT、ENUM枚举、SET集合
协程?
进程,如何通讯?
管道(无名管道):速度慢,容量有限,只有父子进程能通讯
FIFO(命名管道):任何进程之间都能通讯,但速度慢
消息队列:容量受到系统限制,且第一次读的时候,要考虑上次没有读完的数据
信号量:不能传递复杂消息,只能用来同步
共享内存:能够很容易控制容量,速度快,但要保持同步,比如一个进程在写的时候,另一个进程要注意读写的问题,相当于线程中的线程安全,当然,共享内存区同样可以用作线程间通讯,不过没这个必要,线程间本来就已经共享了同一进程内的一块内存
进程,线程区别?
进程是资源分配的基本单位,他是程序执行时的一个实例。程序运行时系统就会创建一个进程,并为它分配资源,然后把该进程放入进程就绪队列,进程调度器选中它的时候就会为它分配CPU时间,程序开始真正运行。
线程是程序执行时的最小单位,他是进程的一个执行流,是CPU调度和分派的进本单位,一个进程可以由很多线程组成,线程间共享进程的所有资源,每个线程都有自己的堆栈和局部变量。线程由CPU独立调度执行,在多CPU环境下就允许多个线程同时运行,同时多线程也可以实现并发操作,每个请求分配一个线程来处理。
快排?
是对冒泡排序的一种改进,以第一个值为参考值,通过“一次”排序将比其小的放到左面,打的放到右面,然后不断迭代,直到排序完成。
“一次排序”,两个指针分别指向1,和,n-1,当发生一次事件,交换一下数据,事件在n/2的右面有比参考值小的数,或在左侧有比参考值大的数
堆排?
完全二叉树
事务原理?
Js中的protype?
prototype 属性使您有能力向对象添加属性和方法。
存储引擎,及区别?
MyISAM (misemu发音)是非事务的存储引擎;适合用于频繁查询的应用;表锁,不会出现死锁;适合小数据,小并发
innodb是支持事务的存储引擎;合于插入和更新操作比较多的应用;设计合理的话是行锁(最大区别就在锁的级别上);适合大数据,大并发。
MVVM设计模式?
MVC:模型-视图-控制器model-view-controller
MVP:模型-视图-表现层model-view-presenter
MVVM:模型-视图-视图模型model-view-viewmodel
WPF与Silverlight?
ftp,ssh协议?
ftp文件传输协议
ssh:secure shell安全外壳协议
http协议几种状态?
200请求成功
301永久重定向
403客户端错误,没有权限
404 页面不存在
500服务器内部错误
远程登录?
SecureCRTPortable,软件,使用的是ssh协议,端口号22,主机名,服务器IP
Cookie与session区别?
Cookie客户端
Session服务器端
几个页面之间传值方式?
Cookie
Web worker
localStorage
sessionStorage
php当中魔术方法
__construct() 实例化类时自动调用。
__destruct() 类对象使用结束时自动调用。
__set() 在给未定义的属性赋值的时候调用。
__get() 调用未定义的属性时候调用。
__isset() 使用isset()或empty()函数时候会调用。
__unset() 使用unset()时候会调用。
__sleep() 使用serialize序列化时候调用。
__wakeup() 使用unserialize反序列化的时候调用。
__call() 调用一个不存在的方法的时候调用。
__callStatic()调用一个不存在的静态方法是调用。
__toString() 把对象转换成字符串的时候会调用。比如 echo。
__invoke() 当尝试把对象当方法调用时调用。
__set_state() 当使用var_export()函数时候调用。接受一个数组参数。
__clone() 当使用clone复制一个对象时候调用。、
Sql注入:
SQL注入攻击是黑客对数据库进行攻击的常用手段之一。一部分程序员在编写代码的时候,没有对用户输入数据的合法性进行判断,注入者可以在表单中输入一段数据库查询代码并提交,程序将提交的信息拼凑生成一个完整sql语句,服务器被欺骗而执行该条恶意的SQL命令。注入者根据程序返回的结果,成功获取一些敏感数据,甚至控制整个服务器,这就是SQL注入。
Check 约束
CREATE TABLE Persons
(
Id_P int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),
CHECK (Id_P>0)
)
怎么使得元素大小包含padding和border?
box-sizing: border-box;
Display:hidden与visibility:hidden的区别?
Mysql中表连接的几种方式及区别?
配置nginx的server?
什么场景使用链表,什么场景使用数组?
数组应用场景:数据比较少;经常做的运算是按序号访问数据元素;数组更容易实现,任何高级语言都支持;构建的线性表较稳定。
链表应用场景:对线性表的长度或者规模难以估计;频繁做插入删除操作;构建动态性比较强的线性表。
Php怎么处理XML文件,和json文件?
简述你常用的一些linux指令?
ls
cd
cat
more less tail head wc
mkdir
touch
chmod
cp
rm
ps
grep
find
pwd
mv
df 查看目录使用情况
rmdir 删除空目录
basename 取文件名
whereis file 找出文件file的位置
diff file1 file2 文件不同处
防止sql注入的方法?
开启错误调试使用什么函数?
mysql常用操作?
create databases 数据库名称 ;
show databases ;
show create databases 数据库名称 ;
alter database 数据库名称 default character set 编码方式 collate 编码方式_bin ;
drop database 数据库名称 ;
create table 表名
{
字段名 1,数据类型[完整性约束条件],
字段名 2,数据类型[完整性约束条件],
...
字段名 n,数据类型[完整性约束条件],
}
show create table 表名 ;
describe 表名 ;
简写为
desc 表名 ;
alter table 旧表名 rename [to] 新表名 ;
alter table 表名 modify 字段名 数据类型 ;
alter table grade modify id int(20) ;
alter table 表名 drop 字段名 ;
alter table 表名 modify 字段名1 数据类型 first|after 字段名2
drop table 表名 ;
insert into 表名(字段名1,字段名2, ...) value(值1,值2, ...)
insert into 表名 set 字段名1 = 值1 [,字段名2 = 值2, ...]
update 表名 set 字段名1 = 值1 [,字段名2 = 值2, ...] [where 条件表达式]
delete from 表名 [where 条件表达式]
truncate [table] 表名
查询语句....
smarty遍历数组?
//{literal}{/literal}原样输出
/*
{foreach $stu as $k=>$v}
{$k}:{$v}
{foreachelse}
{/foreach}
{if 条件}
{elseif 条件}
{else}
{/if}
{section name='自定义变量名' loop='被遍历的数组'}
{/section}
{section name=s loop=$stu}
{$stu[s]}
{/section}
{for $i=1 to 10 step=2}
{/for}
{while $i<10}
{/while}
*/
smarty常用函数?
$smarty = new Smarty();
$smarty->assign('key','value');
$smarty->display('a.html');
$smarty->cache_lifetime=5;//缓存的生存时间
$smarty->caching=1;//开启缓存
$smarty->force_cache=TRUE;//强制更新缓存
$_SESSION['a']='1';//{$smarty.session.a}
setcookie('a','1');//{$smarty.cookies.a}
define('a','1');//{$smarty.const.a}
//{$smarty.server.REMOTE_ADDR}
//{$smarty.now}
//{$smarty.version}版本号
//{$smarty.ldelim}左界定符
//{$smarty.rdelim}
python与php相比的优势?
计算能力和大数据处理多线程等有很明显的优势,
有很多扩展库
git常用操作?
Git add filename,将文件添加到仓库实际上是添加到暂存区,没有提示证明添加成功
Git commit -m “提交说明”命令
git status 查看仓库当前状态
git diff filename 查看文件修改了什么内容
Git log 查看所有提交日志
git reset —hard HEAD^
Git reflog 查看命令历史
git checkout — filename 在没有提交到暂存区(未执行add)撤销工作区的修改
git reset HEAD filename ,当执行了add,使用该命令撤销暂存区的修改,重新放回到工作区
git rm filename 删除文件
ssh-keygen -t rsa -C “[email protected]” 命令创建SSH KEY
git remote add origin [email protected]:michaelliao/learngit.git 关联远程库
git push origin master推送最新修改
git clone [email protected]:账户名/远程库名.git 进行克隆
git checkout -b dev 创建并切换到dev分支
Git merge dev命令将dev分支合并到当前分支上
git branch -d dev 删除分支
Git pull 获取最新提交
git branch 命令不仅仅能创建和删除分支,如果不加任何参数,它会给出当前所有分支的清单:
今日头条协议:https
自我介绍?
工作经验?
为什么离开?
python优势?
平时有什么爱好?
有没有阅读习惯?