2016年6月18日星期六

如何配置LAMP环境

手贱搞坏了自己的ubuntu,今天重新装了一遍之后发现对照着之前转载的那篇教程死活都配不好LAMP,在查阅了无数资料之后终于配置成功,想了想只是看别人写的教程果然还是不靠谱,于是果断决定自己写一个以备日后不时之需。


一、下载apache

sudo apt-get install apache2


二、下载mysql

sudo apt-get install mysql-server mysql-client

中途会让你设定root用户的密码,输入并确认之后即可成功安装mysql


三、下载php

这里需要说明的是我的ubuntu版本是16.04,而16.04默认的apt库中是没有php5的,会自动安装php7。

sudo apt-get install php php-curl php-mysql php-gettext php-curl libapache2-mod-php php-mbstring

完成之后,写一个文件来测试下是否成功连接数据库

sudo apt-get install vim

sudo vim /var/www/html/test.php

输入以下内容:

<?php
echo mysqli_connect('localhost', 'root', 'root') ? 'OK' : 'FAIL';
echo phpinfo();
?>

注意:php7全面取消了mysql函数库的支持,应改写为mysqli


四、下载phpmyadmin

sudo apt-get install phpmyadmin

中途会让你输入phpmyadmin的密码(不是连接的mysql的密码),输入即可

现在还不能直接在浏览器中访问phpmyadmin,有两种方法可以实现访问:

①在/var/www/html文件夹下建立一个到phpmyadmin的软连接,用法如下:
sudo ln -s /usr/share/phpmyadmin /var/www/html/phpmyadmin

补充知识:ln命令可以建立软连接和硬链接(在后面加上-s的选项即为建立软连接),两者的区别是软连接只复制文件的路径,不会占用新的磁盘空间,而硬链接会复制文件本身,也就意味着会占用更多的磁盘空间。源文件夹的内容若有改动,两者复制的文件夹内容都会随之改动。若要删除一个连接,键入
sudo rm -rf path

②将phpmyadmin自带的apache配置文件包括进apache中,用法如下:
sudo nano /etc/apache2/apache2.conf
在文件末尾添加如下行:
Include /etc/phpmyadmin/apache.conf

补充知识:nano命令是一个简易的文件编辑器,修改完毕之后键入ctrl+o保存,ctrl+x退出,如果退出时没有保存修改,会提示你是否保存,输入y或n即可,之后会要求你输入保存的文件路径和文件名,一般保持默认。

现在phpmyadmin应该可以直接访问了,需要说明,phpmyadmin对php有两个依赖,分别是php-gettext和php-mbstring,如果到这一步仍然不能访问试试看安装这两个php包。

参考链接:
https://www.unixmen.com/how-to-install-lamp-stack-on-ubuntu-16-04/

https://www.digitalocean.com/community/tutorials/how-to-install-linux-apache-mysql-php-lamp-stack-on-ubuntu-16-04

http://www.ahlinux.com/ubuntu/23193.html

2016年6月9日星期四

在FireFox下selected属性不能正确解析的问题

今天在开发一个HTML页面的时候发现给某个option标签加上selected属性在FF下并不能被默认选中,除非用ctrl+F5强制刷新才能重新渲染。
这可能是FF团队在出于性能方面的考虑将DOM元素缓存,而当刷新的时候会优先读取缓存中的数据。
后来找到了解决办法,在selece标签内部添加autocomplete属性,并将其值设为off。

如下:
<select name="cal" autocomplete="off">

2016年6月3日星期五

C语言中的强制类型转换

可以利用强制类型转换运算符将一个表达式转换成所需类型:
例如:
(double)a       (将a转换成double类型)
(int)(x+y)      (将x+y的值转换成整型)
(float)(5%3)    (将5%3的值转换成float型)

另外,也可以强制转换为指针变量,如:
int *p = (int *)malloc(n * sizeof(int));

Java位运算符相关

~:按位取反
^:按位异或(数值不同才为1)
&:按位与
|:按位或

1.>>和>>>的区别
>>和>>>分别为算术右位移和逻辑右位移,位移的结果是运算符左边的操作数被2的幂来除,指数为运算符右边的操作数。
如:
128>>1 gives 128/2^1 = 64
256>>4 gives 256/2^4 = 16
-256>>4 gives -256/2^4 = -16

算数位移和逻辑位移的主要区别是算数位移保留符号位,由于溢出而不足的高位部分由符号位的复制来补充。而逻辑位移则不保留符号位,高位补0.

2.<<运算符
<<为算数左位移,位移的结果是左边的操作数乘以2的幂,指数为右边的操作数

2016年6月2日星期四

为什么计算机用补码存储数据。

在计算机内部,所有信息都是用二进制数串的形式表示的。整数通常都有正负之分,计算机中的整数分为无符号的和带符号的。无符号的整数用来表示0和正整数,带符号的证书可以表示所有的整数。由于计算机中符号和数字一样,都必须用二进制数串来表示,因此,正负号也必须用01来表示。通常我们用最高的有效位来表示数的符号(当用8位来表示一个整数时,第8位即为最高有效位,当用16位来表示一个整数时,第16位即为最高有效位。)0表示正号、1表示负号,这种正负号数字化的机内表示形式就称为“机器数”,而相应的机器外部用正负号表示的数称为“真值”。将一个真值表示成二进制字串的机器数的过程就称为编码。

无符号数没有原码、反码和补码一说。只有带符号数才存在不同的编码方式。

带符号整数有原码、反码、补码等几种编码方式。原码即直接将真值转换为其相应的二进制形式,而反码和补码是对原码进行某种转换编码方式。正整数的原码、反码和补码都一样,负数的反码是对原码的除符号位外的其他位进行取反后的结果(取反即如果该位为0则变为1,而该位为1则变为0的操作)。而补码是先求原码的反码,然后在反码的末尾位加后得到的结果,即补码是反码+1IBM-PC中带符号整数都采用补码形式表示。(注意,只是带符号的整数采用补码存储表示的,浮点数另有其存储方式。)

采用补码的原因或好处如下,采用补码运算具有如下两个特征:

1)因为使用补码可以将符号位和其他位统一处理,同时,减法也可以按加法来处理,即如果是补码表示的数,不管是加减法都直接用加法运算即可实现。
2)两个用补码表示的数相加时,如果最高位(符号位)有进位,则进位被舍弃。
这样的运算有两个好处:
1)使符号位能与有效值部分一起参加运算,从而简化运算规则。从而可以简化运算器的结构,提高运算速度;(减法运算可以用加法运算表示出来。)
2)加法运算比减法运算更易于实现。使减法运算转换为加法运算,进一步简化计算机中运算器的线路设计。


下面深入分析上面所陈述的采用补码的原因(目的)。
用带符号位的原码进行乘除运算时结果正确,而在加减运算的时候就出现了问题,如下: 假设字长为8bits
( 1 ) 10- ( 1 )10 = ( 1 )10 + ( -1 )10 = ( 0 )10
(00000001) + (10000001) = (10000010) = ( -2 ) 显然不正确.

因为在两个整数的加法运算中是没有问题的,于是就发现问题出现在带符号位的负数身上,对除符号位外的其余各位逐位取反就产生了反码。反码的取值空间和原码相同且一一对应。下面是反码的减法运算:

 ( 1 )10 - ( 1 ) 10= ( 1 ) 10+ ( -1 ) 10= ( 0 )10
 (00000001) + (11111110) = (11111111) = ( -0 ) 有问题。
 ( 1 )10 - ( 2)10 = ( 1 )10 + ( -2 )10 = ( -1 )10
 (00000001) + (11111101) = (11111110) = ( -1 ) 正确

问题出现在(+0)(-0)上,在人们的计算概念中零是没有正负之分的。

于是就引入了补码概念。负数的补码就是对反码加一,而正数不变,正数的原码反码补码是一样的。在补码中用(-128)代替了(-0),所以补码的表示范围为:
(-128~0~127)256个。
注意:(-128)没有相对应的原码和反码, (-128) = (10000000) 补码的加减运算如下:
( 1 ) 10- ( 1 ) 10= ( 1 )10 + ( -1 )10 = ( 0 )10
(00000001) + (11111111) = (00000000) = ( 0 ) 正确
 ( 1 ) 10- ( 2) 10= ( 1 )10 + ( -2 )10 = ( -1 )10
(00000001) + (11111110) = (11111111) = ( -1 ) 正确

采用补码表示还有另外一个原因,那就是为了防止0的机器数有两个编码。原码和反码表示的0有两种形式+0-0,而我们知道,+0-0是相同的。这样,8位的原码和反码表示的整数的范围就是-127~+12711111111~01111111),而采用补码表示的时候,00000000+0,即010000000不再是-0,而是-128,这样,补码表示的数的范围就是-128~+127了,不但增加了一个数得表示范围,而且还保证了0编码的唯一性。

整数和0的原码、反码和补码都相同,下面介绍手工快速求负数补码的方法。这个方法在教材的第8页已经提到了,这里再写出来以便能引起大家的注意。其方法如下:
先写出该负数的相反数(正数),再将该正数的二进制形式写出来,然后对这个二进制位串按位取反,即若是1则改为0,若是0则改为1,最后在末位加1



接下来的问题是,如何能将减法运算转换成加法运算呢?

我们已经知道,原码表示简单直观,与真值转换容易。但如果用原码表示,其符号位不能参加运算。在计算机中用原码实现算术运算时,要取绝对值参加运算,符号位单独处理,这对乘除运算是很容易实现的,但对加减运算是非常不方便的,如两个异号数相加,实际是要做减法,而两个异号数相减,实际是要做加法。在做减法时,还要判断操作数绝对值的大小,这些都会使运算器的设计变得很复杂。而补码这种编码方式实际上正是针对上述问题的。通过用补码进行表示,就可以把减法运算化为加法运算。

在日常生活中,有许多化减为加的例子。例如,时钟是逢12进位,12点也可看作0点。当将时针从10点调整到5点时有以下两种方法:
一种方法是时针逆时针方向拨5格,相当于做减法:
    1055
另一种方法是时针顺时针方向拨7格,相当于做加法:
    1071255    (MOD 12)
这是由于时钟以12 为模,在这个前提下,当和超过12时,可将12舍去。于是,减5相当于加7。同理,减4可表示成加8,减3可表示成加9,…。
在数学中,用“同余”概念描述上述关系,即两整数AB用同一个正整数M (M称为模)去除而余数相等,则称ABM同余,记作:
    AB     (MOD  M)
具有同余关系的两个数为互补关系,其中一个称为另一个的补码。当M12时,-5和+7,-4和+8,-3和+9就是同余的,它们互为补码。
从同余的概念和上述时钟的例子,不难得出结论:对于某一确定的模,用某数减去小于模的另一个数,总可以用加上“模减去该数绝对值的差”来代替。因此,在有模运算中,减法就可以化作加法来做。

可以看出,补码的加法运算所依据的基本关系为:
[x]+ [y]= [x+y]
补码减法所依据的基本关系式:
[x-y] =[x+(-y)]= [x]+ [-y]
至于加法运算为什么比减法运算易于实现以及CPU如何实现各种算术运算等问题,则需要通过对数字电路的学习来理解CPU的运算器的硬件实现问题的相关内容了。

总的来说,使用补码来存储数据有三个好处:
1.将减法运算化为加法运算,使计算机线路设计更为简易。
2.符号位可以参与运算,如有进位则溢出舍弃。
3.扩充了负数可表示的范围(10000000)表示-128,同时保证了0的唯一性。


转自CSDN:GLGoober

使PHP页面自动跳转的方法

有时我们需要给一个简单的PHP页面设置一个自动刷新时间,让它跳转至另一个特定页面。
可以使用一句简单的语言给这个PHP页面设置HTTP响应头。
如下:
echo '<meta http-equiv="refresh" content="3,url=index.php" >';