-
关于Qt中使用中文编码的一些问题
Qt库作为一个开源库,并且支持多语言。在开发时需要考虑字符编码问题。
我现在的使用Qt开发环境为VS2012+Qt5.1.1,所以一下所讨论的也是基于这个版本而言的。目前Qt5已经将tr()
删掉了。在windows下使用Qt库进行开发
有两种主流开发环境:- 使用Qt Creator作为开发环境
- 使用Visual Studio + Visual Assist + Qt Visual Studio Addon作为开发环境
目前我使用的就是第二种开发环境,鉴于在Windows平台下没有哪个开发环境能与Visual Studio相媲美。
使用VS开发Qt程序时需要注意源文件的编码格式
Qt5官方推荐的源文件编码格式为UTF-8,QString内部的编码格式就是UTF-8,使用QtCreator创建的源文件的编码格式也是UTF-8 without BOM。
但是VS在中文操作系统上,如果不进行特殊的设置,默认创建的含有中文的源文件编码格式为gb3212。这样的原始字符串就是gb2312格式的,在使用时需要进行特殊转换,这样显示在界面上才不会乱码。
推荐使用一下两种方法解决gb2312编码问题:-
QString::fromLocale8Bit()
会将gb2312编码的字符串转换为UTF-8格式以便存放在QString中。
-
QStringLiteral()
是一个宏定义,会在编译期将字符串实例化,对静态字符串使用这个字符串也是一个提高效率的方法(因为减少了运行时的内存申请开销)。
在VS中使用utf-8 with BOM的源文件格式
如果使用了utf-8 with BOM的源文件格式,VS会将其中的字符串转换为gb2312编码的中文,这样是为了兼容旧版本的编译器。
可以使用编译选项让VS编译器不进行这项转换,这样就可以直接使用字符串char*
初始化QString了。- 微软在VS2010中提供了
#pragma execution_character_set("utf-8")
这样的编译选项,能够防止编译器进行文件编码转换,保证字符串保留utf-8格式。
- VS2012 并不支持以上编译选项,VS2012将这个特性取消了
- VS2015 可以使用
/utf-8
让编译器能够识别 utf-8 without BOM格式的文件,并保留utf-8的字符串编码。
C++11的编码格式支持
对于支持C++11标准的编译器,可以采用如下的写法产生utf-8格式的字符串。const char* szMsg = u8"字符串";
- 使用Qt Creator作为开发环境
-
为git设置socks5代理
在某些时候,为了绕过网络封锁,在使用git时需要借助代理完成相关网络操作。
一个可用的VPN代理是先决条件
关于VPN的架设就不在此讨论了。
将repo的链接由ssh改为为https
已经使用https的repo跳过此步骤。
本教程需要通过https(http)的方式使用代理,所以如果现有的repo是使用ssh方式clone到本地的,需要修改其为https方式。
需要修改repo_name/.git/config
中的url配置,将其中的git格式改为https格式。使用文本编辑工具将其打开进行修改,以github为例,需要将[email protected]:user_name/repo_name.git
改为https://github.com/user_name/repo_name.git
。
可以使用sed指令完成替换。sed -i 's/[email protected]:/git:\/\/github.com\//' ./.git/config
设置git使用代理
将git配置为使用socks5代理,以socks5的ip和端口是
127.0.0.1:1080
为例。git config --global http.proxy 'socks5://127.0.0.1:1080' git config --global https.proxy 'socks5://127.0.0.1:1080'
将登录信息缓存下来
使用https时,在向远程仓库进行推送(git push)时会要求验证用户名和密码,由于每次都输入验证信息是十分繁琐的,考虑将验证信息缓存下来。
git config --global credential.helper cache
git默认会将密码缓存15分钟,在这期间进行的操作是不需要再次进行密码验证的,可以使用下面命令修改缓存的时长。
git config --global credential.helper "cache --timeout=3600"
将登陆信息保存下来
也可以考虑将用户名和密码永久保存下来,这样就不需要再次进行密码验证了。
注意: 使用这种配置会将明文的账户和密码保存在~/.git-cretidentials
文件中,所以仅推荐在个人电脑中使用这个配置。git config --global credential.helper store
参考资料
(全文完)
-
windows平台下的C++开发框架
在开发windows应用程序时,经常会遇到win32、mfc、atl的函数。下面就对三种API(或者说是开发框架)进行了总结。
Win32开发框架
win32开发框架是最基础的函数接口,更接近操作系统底层。
使用Win32接口的优点是程序的依赖最小,生成的可执行文件的体积也最小。MFC开发框架
MFC是Microsoft Foundation Class的缩写,将win32的相关接口按照OOP的思想封装了起来,目的是提供一个快速开发原生应用的框架。
使用MFC开发的程序体型略显臃肿,而且MFC也比较陈旧了,并不推荐使用MFC进行开发。ATL开发框架
ATL是Active Template Library的缩写,是针对COM组件的开发实现的一套开发框架。ATL简化了ActiveX COM组件的开发。
-
使用emacs在目录中递归搜索字符串
对文件中的字符串搜索是开发中经常遇到的情景,下面就对常见的搜索字符串的方式进行了总结。
对当前buffer进行搜索(单个文件)
C-s
向后搜索C-r
向后搜索M-s o
使用occur对当前buffer中的指定关键字进行统计
在安装了helm以后可以使用helm-occur
完成当前buffer的搜索对目录中的指定文件进行搜索(一个目录下的多个文件)
C-x d
进入dired模式,在dired模式中使用M-x <dired-do-find-regexp>
(快捷键A
)对标记的文件进行搜索。对目录中的所有文件进行递归搜索(一个目录下的所有文件和所有子目录中的文件)
M-x <rgrep>
能够对一个目录下所有的文件进行正则表达式匹配注意事项
在windows平台上使用grep和find指令时,需要借助仿linux环境中的程序完成,如cygwin中的程序。
需要将程序的路径添加到系统环境变量path中,并且为了覆盖windows系统自带的find命令,需要将该路径放在系统find路径之前。
tips: 对于安装了git bash
的同学,直接将其中的mingw64\bin
的绝对路径加入系统path中即可。 -
ss服务器的配置指南
租一个服务器自己搭建梯子是科学上网方便稳定快捷的好方法。
本文主要是自己部署vpn服务端的笔记,作为备忘留存下来。安装ss服务程序
安装环境为CentOS7, 需要使用python的包管理工具pip完成对ss-server的安装。
sudo yum install m2crypto python-setuptools sudo easy_install pip sudo pip install shadowsocks
配置ss服务器
配置文件示例 :
这份配置中使用了多个端口作供ss-server使用{ "server":"your-server-ip", "local_address":"127.0.0.1", "local_port":1080, "port_password": { "32366":"shadowsocks", "32367":"shadowsocks", "32368":"shadowsocks", "32369":"shadowsocks", "52369":"shadowsocks" }, "timeout":300, "method":"aes-256-cfb", "fast_open": false }
启动脚本示例 :
直接在命令行直接输入指令也能够完成ss服务的启动和停止,使用脚本只是为了方便一些。#!/bin/bash ss_start() { ssserver -c /root/shadowsocks/shadowsocks.json -d start } ss_stop() { ssserver -c /root/shadowsocks/shadowsocks.json -d stop } # shell script main if [ "$#" -eq "0" ]; then ss_start else case "$1" in start) ss_start exit;; stop) ss_stop exit;; esac fi
增加系统启动项
可以将启动脚本加入系统启动项,这样就能够保证在每次reboot后,服务都能自动开启。 -
常用git操作备忘
对常用指令进行总结,方便以后遇到相同情况时查阅。