
这是网络用语,对话时的缩写,程序员三个字的拼音首字母缩写。
程拼音chéng,声母ch,韵母eng,声调二声。
序拼音xù,声母x,韵母u,声调四声。
员拼音yuán,声母y,介母u,韵母an,声调二声。
程序员分为程序设计人员和程序编码人员,但两者的界限并不非常清楚。软件从业人员分为初级程序员、中级程序员、高级程序员(现为软件设计师)、系统分析员,系统架构师,测试工程师六大类。
扩展资料字体输入作为网络聊天最基本的形式,需要通过键盘或触屏将字符输送到对方显示屏上,打字速度肯定难与思维同步,也远非直接对话那样方便,故以简约高效的字母替代汉字就成为网民聊天首选,它的内涵的丰富程度已经超过正规文字表达模式。
如:GG(哥哥)、JS(奸商)、PFPF(佩服佩服)、ZT(转贴)等,这类语言通常是提取中文词组的首个字母,比较容易理解和识别,所以能够被广泛采用传播。
与它相似的还有以英语词组缩写或变化而来的网络用语,如GF(girl friend,女朋友)、PK(来源于网游中的“playerkill”一词,挑战、杀死、末位淘汰之意),这类用语有很多也不符合英语语法规范,甚至是错误的,如CU(see you,再见)、good good study,day day up(好好学习,天天向上),但因其形式简单、输入便捷、表达内涵确切,所以在网络上有相当高的使用频率。
输入法中使用了两个重要数据结构,分别是PY_NODE和PY_SUBNODE。每个PY_NODE对应一个数字键组合,PY_SUBNODE则对应一组拼音组合。由于一个数字组合可对应多个拼音组合(如“226”对应“ban”、“bao”、“can ”、“cao”),因此这两个结构实现的是一个两级的对应表。PY_NODE按树组织,而PY_SUBNODE按双向链表组织。二者的基本关系如图1所示。
以下是两个结构的定义:
typedef struct py_node{
unsigned int son[8] //对应下次2~9按键输入时应转到的PY_NODE的ID号
unsigned int father//父节点ID号
struct py_subnode *ptrpy //指向下属第一个PY_SUBNODE的指针
}PY_NODE
typedef rom struct py_subnode{
unsigned char py[7] //本节点的拼音字符串
struct py_subnode *prev //指向前一PY_SUBNODE的指针
struct py_subnode *next //指向下一PY_SUBNODE的指针
unsigned char *ptrUnicode //指向本节点对应Unicode码表的指针
}PY_SUBNODE
设计中我们所参照的汉语拼音表中共有412种组合,这样系统中必须有412个PY_SUBNODE与其一一对应;系统中共建立了250个PY_NODE。建立此部分数据的工作比较繁琐,分以下5个步骤进行:
1、 汉字按拼音进行分组,按常用程度排序,并将汉字转化为Unicode码或国标码,码型视系统要求而定;
2、 将有效拼音转换为数字键盘值组合,如拼音“cui”转为数字值“284”,这些值对应了部分PY_NODE;
3、 增加中间PY_NODE,用于表示本身无效但后续输入有效的拼音,如“b”、“c”、“don”、“dua”等节点;
4、 将数字键组合相同的PY_SUBNODE编成链表,由某一PY_NODE中的ptrpy指针指向表头;
5、 按数字键组合的关系,将PY_NODE组成树。
图1中所示组织关系并不复杂,但其工作量不小,一般情况下可编写转换程序自动建立。图2为拼音输入法数据结构的一个片断。
在改变当前PY_NODE时,一般应伴有一些显示 *** 作,因应用不同各有差异,此处不做过多说明。
在当前节点下,可以用某一指定控制键(如“#”键)来选择此PY_NODE下属的PY_SUBNODE以缩小汉字的选取范围。
例子在下面
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)