Skip to main content

Posts

SQL dump指令

    在做数据库实验的时候需要备份当前数据库,因此要使用dump指令。上网查了dump的语法之后,在MySQL的命令行界面输入发现没有效果。     然后发现查到的这个用法应该是在操作系统的命令行上使用的,而非MySQL的命令行。要执行这一条指令,就要先进入到MySQL的bin目录下。 cd C:\Program Files\MySQL\MySQL Server 5.7\bin 然后再执行dump指令 mysqldump -u root -p db_spj>E:\db_spj.sql 执行完毕后就成功dump啦。
Recent posts

各种小技巧

    这篇文章的主要目的就是为了自己收集、总结一些编程时的小技巧。示例语言是C++。 /* 判断质数,判断素数  *  * 0、1、负数、偶数,都直接false。  * 剩下只需要判断是否存在奇数因数。最小的非prime奇数是9,所以可以从i=3开始。  * i*i<p 这个条件是为了减少for循环的次数,即根号优化。  * */ bool isPrime(int p) { if (p<2 || !(p%2)) return false; for (int i=3; i*i<=p; i+=2) { if (!(p%i)) return false; } return true; } /* 两个变量交换值,不引入临时变量  *  * 注意,应用在较大的动态数组上有时候会出错,不知道原因。发现会出错的话就用临时变量吧。  * */ void swapWithoutTemp(int& a, int& b) { a += b; b = a-b; a -= b; } /* 快速判断一个整数是否为2的正整数次幂  *  * 计算机用二进制存储所有内容。  * 如果n是2的正整数次幂,假设n用x位来表示。  * 那么n的表示一定是1后面跟(x-1)个0,那么(n-1)的表示一定是0后面跟(x-1)个1。  * 因此对n和(n-1)进行逻辑与运算,一定会得到0。  * */ bool isPowerOf2(int n) { return !(n & (n-1)); }

Vivado崩溃与文件路径和计算机名称

先声明软件版本与操作系统 Vivado 2014.4 Windows 10 家庭版 做数字逻辑实验要用 Vivado ,按照老师给的教程安装了 Vivado 2014.4 。然后就开始按照实验指导去做实验了。 做到需要进行 RTL Analysis 的时候,点击 Schematic , Vivado 就直接崩溃了,没有弹出任何的错误提示。 于是我就去搜索,看有没有人遇到了类似情况,是否有解决办法。搜索到的全都是说文件路径里含有中文或特殊字符,但是我的路径全都是规范的,只包含英文、数字、下划线。我从头开始做了一遍,不行。卸载后重装 Vivado ,重做实验,还是不行。完全不知道该怎么解决。 后来做另一个实验的时候,要用到 Synthesis 功能,在 Run Synthesis 之后,就会 Fail ,在最底下的 Log 里的最后几行能看到 TclStackFree: incorrect freePtr. Call out of sequence? 我又去 Google 了一下,然后就浏览到了这个链接。 https://forums.xilinx.com/t5/Synthesis/TclStackFree-incorrect-freePtr-Call-out-of-sequence-in-2016-4/m-p/742698 看到里面有人说,把计算机的名字改了之后就能正常使用了。我就去看了一下我的计算机名,是 myName’sPC 然后我就尝试着去掉那个单引号改成 myNamesPC 重启计算机之后再去使用 Vivado ,发现已经能够正常使用了!!! 原来我遇到的问题的根源就出在这里!计算机名包含了这个单引号! 所以,以后在命名这些关键内容的时候,无论是设备名还是路径名,都尽量只包含英文、数字、下划线,其他的符号很容易带来问题。

C++中shared_ptr环形引用问题及weak_ptr的作用

     C++中双斜杠//只能注释一行,在这里我没有花时间排版,所以看起来//注释换了行。把代码复制到编辑器或IDE上看可能会好很多。     weak_ptr指向一个shared_ptr管理的对象,最重要的特点就是,weak_ptr不会改变shared_ptr的引用计数。weak_ptr更详细的介绍可以参考《C++ Primer》中文版第五版第420页。此篇文章将给出《C++ Primer》上没有给出的weak_ptr的用法。     在使用shared_ptr的时候,可能会出现环形引用的问题。一旦出现了环形引用(Circular Reference),就会导致两个shared_ptr的引用计数都没办法减到1,也就没办法销毁对象,程序结束的时候就没办法正常地释放内存。下面将演示一下这种情况。 #include<memory>    //shared_ptr定义在memory头文件中。 using namespace std; //我们先定义一个叫Node的类,包含两个数据成员。 struct Node{     shared_ptr<Node> previous;     shared_ptr<Node> next; }; int mian() {     //然后在main函数里定义两个指向Node类对象的shared_ptr并进行值初始化。     shared_ptr<Node> n1 = make_shared<Node>();  //此时n1计数器为1。     shared_ptr<Node> n2 = make_shared<Node>();  //此时n2计数器为1。     //不妨假设n1指向的对象名字为node_1,n2指向的叫node_2。     //接下来让node_1的next成员指向node_2,让node_2的previous成员指向node_1。     (*n1).next=n2;      //拷贝了n2,此时n2的计数器为2     (*n2).previous=n1;  //拷贝了n1,此时n1的计数器为2     //这时n1、n2就产生

C++文件流打开文件路径时的反斜杠用法

     系统:Windows 10     IDE:Code::Blocks 16.01      C++中双斜杠//只能注释一行,在这里我没有花时间排版,所以看起来//注释换了行。      预备知识:转义序列      在C++语言中有特殊含义的字符(单引号、双引号、问号、反斜线)是不能直接打印出来的,必须用到转义序列,转义序列以反斜线作为开始。      \n代表换行符,\?代表问号,\'代表单引号,\"代表双引号,\\代表反斜线。想查看更多转义序列请自己去Google。      在用《C++ Primer》学习C++的文件输入输出的部分的时候,会遇到一个疑问:到底怎么打开一个具体的文件?书上只给出了格式,而没给出具体实例,这就导致了自己真正操作的手会遇到问题。            fstream fstrm;     //创建一个未绑定的文件流。fstream是头文件fstream中定义的一个类型,fstrm是此类型的一个流对象。      fstream fstrm(s);     //创建一个绑定了文件名为s的文件流,s可以是:                       //[方法1:一个string类型],或者,[方法2:指向C风格字符串的指针]。      示范一: ofstream os;    //创建了未绑定的os。 string filename_1;   //定义一个存储文件路径string类型的对象。 cout<<"请输入文件路径:"<<endl; getline(cin,filename_1);    //读取输入的文件名或路径,存入filename_1。                             //用getline而不用cin的好处是,有些文件名可能会带有空格,                             //getline读入整行包括空格,而cin遇到空格停止。 cout<<filename_1<<endl; os.open(filename_1);    //这里对应了方法1,即一个string类型。

shadowsocks服务器开启net-speeder在高延迟不稳定链路上优化单线程下载速度

在网上各种文章比较多,我在搭建的时候就走了不少弯路,所以搭建成功之后就想自己重新整理一遍方法,放到自己的 Blog 里,以后也方便一些。参考了网上其他文章,教程末尾有References。 此篇教程用 Debian 7 操作,已成功。之前用过 CentOS 6 ,也成功了。其他系统不一定。 注1:开启了net-speeder的服务器上对外ping时看到的是4倍,实际网络上是2倍流量。另外两倍是内部dup出来的,不占用带宽。 另外,内部dup包并非是偷懒未判断。。。是为了更快触发快速重传的。 注2:net-speeder不依赖ttl的大小,ttl的大小跟流量无比例关系。不存在windows的ttl大,发包就多的情况。 安装步骤: 1:下载源码并解压 wget https://github.com/snooda/net-speeder/archive/master.zip unzip master.zip 若遇到 unzip command not found,可以执行以下命令来安装unzip: apt-get install zip unzip 2:准备编译环境 debian/ubuntu: #安装libnet-dev: apt-get install libnet1-dev #安装libpcap-dev: apt-get install libpcap0.8-dev centos: #下载epel:https://fedoraproject.org/wiki/EPEL/zh-cn 例:CentOS6 64位: wget http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm #(如果是centos5,则在epel/5/下) #安装epel: rpm -ivh epel-release-6-8.noarch.rpm #然后即可使用yum安装: yum install libnet libpcap libnet-devel libpcap-devel 编译: 可能要先进入到net-speeder的目录下:

Debian 7 搭建shadowsocks服务器并开启ss-bash脚本管理与BBR

自己搭建 ss-bash 脚本管理的 shadowsocks 服务器并开启 BBR。 在网上各种文章比较多,我在搭建的时候就走了不少弯路,所以搭建成功之后就想自己重新整理一遍方法,放到自己的 Blog 里,以后也方便一些。 参考了很多网上的方法,因此文章的末尾会有 References 。 此篇用的是 Debian 7 搭建的,已成功。其他系统不一定。 (2018-07-09更新:Debian 9 所有安装都没问题,但是ss-bash/ssadmin.sh start就会显示ssserver启动失败,查了很多方法都没有办法解决。换回Debian7才能正常使用。) 购买与初步部署 VPS 就不写了。 部署完 VPS 之后,下载 PuTTy 或者 Xshell ,连接上 VPS 1. 依次复制以下命令,一行执行一次,每一行单独复制粘贴到 PuTTy / Xshell ,每行按一次回车 ) apt-get update apt-get install python-pip apt-get install wget apt-get install bc apt-get install gawk apt-get install git pip install shadowsocks git clone https://github.com/hellofwy/ss-bash Debian 一般默认没有 sudo ,要安装 sudo 的话执行以下命令: apt-get install sudo 注:下面的很多命令, GitHub 上原作者给出的例子会在前面加上 “sudo” ,但是自己实际运行的时候可能会遇上 sudo command not found ,如果遇上了,就把前面的 sudo 去掉就好,或者是按照前面说的把sudo安装好。我这一篇的例子是没有 sudo 的。 2. 首次运行时,先新建用户 例如新用户端口为 8381 ,密码为 abcdefg ,流量限制为 100GB 。 执行以下命令: ss-bash/ssadmin.sh add 8381 abcdefg 100GB 要添加更多用户就自己继续按照格式来执行命令