【进阶C语言】排序函数(qsort)与模拟实现(回调函数的实例)
本章大致内容目录:
1.认识回调函数
2.排序函数qsort
3.模拟实现qsort
回调函数为C语言重要知识点,以函数指针为主要知识;下面介绍回调函数的定义、回调函数的库函数举例即库函数模拟实现。
一、回调函数
1.回调函数定义
回调函数就是一个通过函数指针调用的函数。如果你把函数的指针(地址)作为参数传递给另一个函数,当这个指针被用来调用其所指向的函数时,我们就说这是回调函数。
回调函数不是由该函数的实现方直接调用,而是在特定的事件或条件发生时由另外的一方调用的,用于对该事件或条件进行响应。
总结:被函数指针调用的函数
2.回调函数机制实例
在进阶指针1的函数指针数组中,完成了计数器的实现,现在我们再用回调函数的方法改进,先看 原代码:
#include<stdio.h>
void menu()
{printf("****************************\n");printf("*** 1. add 2. sub ***\n");printf("*** 3. mul 4. div ***\n");printf("*** 0. exit ***\n");printf("****************************\n");
}
//加法
int Add(int x, int y)
{return x + y;
}
//减法
int Sub(int x, int y)
{return x - y;
}
//乘法
int Mul(int x, int y)
{return x * y;
}
//除法
int Div(int x, int y)
{return x / y;
}
int main()
{int input = 0;int x = 0;int y = 0;int ret = 0;do{menu();printf("请选择:>");scanf("%d", &input);switch (input){case 1:printf("请输入2个操作数:");scanf("%d %d", &x, &y);ret = Add(x, y);printf("ret = %d\n", ret);break;case 2:printf("请输入2个操作数:");scanf("%d %d", &x, &y);ret = Sub(x, y);printf("ret = %d\n", ret);break;case 3:printf("请输入2个操作数:");scanf("%d %d", &x, &y);ret = Mul(x, y);printf("ret = %d\n", ret);break;case 4:printf("请输入2个操作数:");scanf("%d %d", &x, &y);ret = Div(x, y);printf("ret = %d\n", ret);break;case 0:printf("退出计算器\n");break;default:printf("选择错误, 重新选择\n");break;}} while (input);return 0;
}
改进方向:
可以发现,在case部分,很多代码都是重复的,显得冗余;上文使用函数指针数组将这些重复的包含了起来,实现了简洁的操作。
接下来,我们使用函数指针的机制再次修改,使其更加简便。
改进思路:
第一步:
第二步:初步改进后的代码
case 1:calc(Add);break;
case 2:calc(Sub);break;
case 3:calc(Mul);break;
case 4:calc(Div);break;
case 0:printf("退出计算器\n");break;
default:printf("选择错误, 重新选择\n");break;
将每个功能函数的地址传给一个通用的函数。
第三步:通用函数的实现(利用回调机制)
void calc(int (*pf)(int,int))//用函数指针接收函数地址
{int x = 0;int y = 0;int ret = 0;printf("请输入两个数>:");scanf("%d%d",&x,&y);ret = pf(x,y);//通过函数指针调用printf("%d\n",ret);
}
执行点:函数指针可以接收函数的地址,并且可以通过函数指针变量可以直接调用函数,被调用的函数称为回调函数。
第四步:程序运行图解
完整代码展示:
#include<stdio.h>
void menu()
{printf("****************************\n");printf("*** 1. add 2. sub ***\n");printf("*** 3. mul 4. div ***\n");printf("*** 0. exit ***\n");printf("****************************\n");
}
//加法
int Add(int x, int y)
{return x + y;
}
//减法
int Sub(int x, int y)
{return x - y;
}
//乘法
int Mul(int x, int y)
{return x * y;
}
//除法
int Div(int x, int y)
{return x / y;
}
void calc(int (*pf)(int,int))//用函数指针接收函数地址
{int x = 0;int y = 0;int ret = 0;printf("请输入两个数>:");scanf("%d%d",&x,&y);ret = pf(x,y);//通过函数指针调用printf("%d\n",ret);
}
int main()
{int input = 0;do{menu();printf("请选择:>");scanf("%d", &input);switch (input){case 1:calc(Add);break;case 2:calc(Sub);break;case 3:calc(Mul);break;case 4:calc(Div);break;case 0:printf("退出计算器\n");break;default:printf("选择错误, 重新选择\n");break;}} while (input);return 0;
}
上述就是回调函数的介绍和一个简单的实例,下面库函数的实现也是利用了回调函数的机制。
二、排序函数qsort
为了对比出qsort,我们先来重温一遍冒泡排序。
1.冒泡排序
将一个数组逆序:
#include<stdio.h>
my_bubble(int arr[],int sz)
{int i = 0;for (i=0;i<sz-1;i++){int j = 0;for (j=0;j<sz-1-i;j++){if (arr[j]>arr[j+1]){int tmp = arr[j];arr[j] = arr[j + 1];arr[j + 1] = tmp;}}}
}
print_bubble(int arr[],int sz)
{int i = 0;for (i=0;i<sz;i++){printf("%d ",arr[i]);}printf("\n");
}
int main()
{int arr[] = {10,9,8,7,6,5,4,3,2,1};int sz = sizeof(arr) / sizeof(arr[0]);print_bubble(arr,sz);my_bubble(arr,sz);//将数组升序print_bubble(arr,sz);return 0;
}
上述就是冒泡排序的代码
由此可知,冒泡排序的局限性,所以我们下面介绍万能排序函数--qsort
2.qsort的介绍
函数基础原型:
需要包含头文件#include<stdlib.h>
qsort功能介绍:
该函数是一个库函数,可以排序任意数据类型的数据(数组);底层逻辑采用的是快速排序
参数介绍:
前三个参数:
void* base:待排序数据的第一个元素的地址
size_t num:待排序数据元素的个数
size_t size:待排序数组中一个元素的大小,单位是字节
第四个参数:
(1)int (*compar)(const void*,const void*):这是一个函数指针参数,变量为:compar
(2)compar是一个比较函数,作用是比较两个数据的大小
compar函数的要求:
(1)compar函数是需要用户(需要排序的程序员)自己完成的函数
(2)要求:对两个数进行比较
第一个参数指向的值>第二个,返回>0的数字
第一个参数指向的值=第二个,返回=0的数字
第一个参数指向的值<第二个,返回<0的数字
(3)函数的返回值类型必须是:int
(4)两个参数类型必须是:void*;
目的:可以接收任意类型数据的地址
3.qsort函数的使用
将上述的数字逆序
主函数传参部分:
int my_compar(const void* e1, const void* e2)
{//需要自己完成的比较函数
}
int main()
{int arr[] = { 10,9,8,7,6,5,4,3,2,1 };int sz = sizeof(arr) / sizeof(arr[0]);print_bubble(arr, sz);//可以直接调用库函数进行排序qsort(arr,sz,sizeof(arr[0]),my_compar);print_bubble(arr, sz);return 0;
}
完成函数部分:
int my_compar(const void* e1, const void* e2)
{//需要自己完成的比较函数return *((int*)e1) - *((int*)e2);
}
(1)void*可以兼容任意类型的地址;但是不能进行解引用和+\-操作
(2)根据自己的需要排序的数据类型完成该部分函数,该函数便是回调函数
整体实现:
#include<stdio.h>
#include<stdlib.h>
print_bubble(int arr[], int sz)
{int i = 0;for (i = 0; i < sz; i++){printf("%d ", arr[i]);}printf("\n");
}
//排序整形数据
int my_compar(const void* e1, const void* e2)
{return *((int*)e1) - *((int*)e2);
}
int main()
{int arr[] = { 10,9,8,7,6,5,4,3,2,1 };int sz = sizeof(arr) / sizeof(arr[0]);print_bubble(arr, sz);qsort(arr,sz,sizeof(arr[0]),my_compar);print_bubble(arr, sz);return 0;
}
结果展示:
排序结构体数据类型
结构体中的整形数据(年龄):
#include<stdio.h>
#include<stdlib.h>
struct Stu
{char name[20];int age;int s;
};
print_bubble(struct Stu* arr, int sz)
{int i = 0;for (i = 0; i < sz; i++){printf("%s,%d ", (arr[i]).name,(arr[i]).age);}printf("\n");
}
//排序结构中的年龄(整形)
int compar_Stu_age(const void* e1,const void* e2)
{return ((struct Stu*)e1)->age - ((struct Stu*)e2)->age;
}
int main()
{struct Stu arr[] = { {"张三",19},{"李四",22},{"王五",20}};int sz = sizeof(arr) / sizeof(arr[0]);printf("年龄从小到大排序:\n");print_bubble(arr, sz);qsort(arr, sz, sizeof(arr[0]), compar_Stu_age);print_bubble(arr, sz);return 0;
}
结果展示:
结构体中字符的排序(名字):
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
struct Stu
{char name[20];int age;int s;
};
print_bubble(struct Stu* arr, int sz)
{int i = 0;for (i = 0; i < sz; i++){printf("%s,%d ", (arr[i]).name, (arr[i]).age);}printf("\n");
}
int compar_Stu_name(const void* e1, const void* e2)
{//字符串比较需要用该函数return strcmp(((struct Stu*)e1)->name ,((struct Stu*)e2)->name);
}
int main()
{struct Stu arr[] = { {"张三",19},{"李四",22},{"王五",20} };int sz = sizeof(arr) / sizeof(arr[0]);printf("名字按字典排序:\n");print_bubble(arr, sz);qsort(arr, sz, sizeof(arr[0]), compar_Stu_name);print_bubble(arr, sz);return 0;
}
结果展示:
以上就是qsort函数使用的一些例子
库函数qsort使用步骤:
三、模拟实现qsort
模拟思路:底层使用【冒泡排序】的算法模拟实现qsort,使得可以排序任意类型的数据。所以我们在冒泡排序的基础上进行改造。
1.改造方向
对比方向:
2.分部改造
(1)改造参数
//改造前的
void bubble_sort(int arr[], int sz)
//改造后的参数写法
void bubble_qsort(void* base,size_t num,size_t size,int (*cmp)(const void* e1,const void* e2))
第四个参数:是一个函数指针,用来接收函数的地址。该函数是一个比较函数,由使用者撰写,用来比较两个数据的大小,并传参。
改造后:
比较函数(cmp_int):
//用来比较整形数据
int cmp_int(const void* e1,const void* e2)
{return *((int*)e1) - *((int*)e2);
}
(1)e1是一个指针,存放了一个要比较的元素的地址
e2是一个指针,存放了一个要比较的元素的地址
(2)e1指向的元素>e2指向的元素,返回>0的数字
e1指向的元素==e2指向的元素,返回0
e1指向的元素<e2指向的元素,返回<0的数字
参数意义:
(1)void* base:待排序数据的首元素地址
(2)size_t num:无符号整形,num为待排序数据的个数
(3)size_t size:无符号整形,待排序数据的一个元素的大小。单位:字节
(4)cmp:函数指针
(2)改造“两个数据的比较”
我们有自己撰写的“比较函数”,所以肯定是直接调用该函数即可。
if(cmp()>0)
//根据返回的结果判断是否需要交换
问题:比较的是两个相邻的元素,那怎么找到两个相邻元素的地址呢?
1.void*的指针不可以进行解引用操作和+1或者-1操作
2.需要将void*强转之后才能进行操作;因为不知道是比较什么数据类型,所以我们可以强转成char*
处理办法:
base的地址就是元素的起始地址
比较方法:
交换两个数据:
当两个数据完成比较之后,满足条件就要交换
bubble_qsort函数:
void bubble_qsort(void* base,size_t num,size_t size,int (*cmp)(const void* e1,const void* e2))
{int i = 0;for (i=0;i<num-1;i++){int j = 0;for (j=0;j<num-1-i;j++){//冒泡排序的比较//if(arr[j]>arr[j+1])if( cmp((char*)base+j*size,(char*)base+(j+1)*size) >0){//交换swap((char*)base + j * size, (char*)base + (j + 1) * size,size);}}}
}
交换部分:
依旧是将相邻两个数据的起始地址作为交换;并且多了一个参数:size
交换函数:
void swap(char* buf1,char* buf2,size_t size)
{int i = 0;for (i=0;i<size;i++){char* tmp = *buf1;*buf1 = *buf2;*buf2 = tmp;buf1++;buf2++;}
}
分部思路完成
3.整体思路步骤
(1)整体代码(交换整形数据)
#include<stdio.h>
//模拟内部交换的代码
void swap(char* buf1, char* buf2, size_t size)
{int i = 0;for (i = 0; i < size; i++){char tmp = *buf1;*buf1 = *buf2;*buf2 = tmp;buf1++;buf2++;}
}
//模拟内部排序的代码
void bubble_qsort(void* base,size_t num,size_t size,int (*cmp)(const void* e1,const void* e2))
{int i = 0;for (i=0;i<num-1;i++){int j = 0;for (j=0;j<num-1-i;j++){if( cmp((char*)base+j*size,(char*)base+(j+1)*size) >0){//交换swap((char*)base + j * size, (char*)base + (j + 1) * size,size);}}}
}
//打印函数
void print_bubble(int arr[],int sz)
{int i = 0;for (i=0;i<sz;i++){printf("%d ",arr[i]);}printf("\n");
}
//用来比较整形数据(个人撰写)
int cmp_int(const void* e1,const void* e2)
{return *((int*)e1) - *((int*)e2);
}
int main()
{int arr[] = { 10,9,8,7,6,5,4,3,2,1 };int sz = sizeof(arr) / sizeof(arr[0]);print_bubble(arr,sz);bubble_qsort(arr,sz,sizeof(arr[0]),cmp_int);print_bubble(arr,sz);return 0;
}
(2)整体思路剖析
(3)整体步骤
待排序内容、传参:
int main()
{int arr[] = { 10,9,8,7,6,5,4,3,2,1 };int sz = sizeof(arr) / sizeof(arr[0]);print_bubble(arr,sz);bubble_qsort(arr,sz,sizeof(arr[0]),cmp_int);print_bubble(arr,sz);return 0;
}
比较函数:
//用来比较整形数据(个人撰写)
int cmp_int(const void* e1,const void* e2)
{return *((int*)e1) - *((int*)e2);
}
排序函数:
//模拟内部排序的代码
void bubble_qsort(void* base,size_t num,size_t size,int (*cmp)(const void* e1,const void* e2))
{int i = 0;for (i=0;i<num-1;i++){int j = 0;for (j=0;j<num-1-i;j++){if( cmp((char*)base+j*size,(char*)base+(j+1)*size) >0){//交换swap((char*)base + j * size, (char*)base + (j + 1) * size,size);}}}
}
交换函数:
//模拟内部交换的代码
void swap(char* buf1, char* buf2, size_t size)
{int i = 0;for (i = 0; i < size; i++){char tmp = *buf1;*buf1 = *buf2;*buf2 = tmp;buf1++;buf2++;}
}
以上qsort函数的模拟已完成。如果需要排序其他的数据类型,只需要修改待排序数据、传参和比较函数即可
相关文章:
【进阶C语言】排序函数(qsort)与模拟实现(回调函数的实例)
本章大致内容目录: 1.认识回调函数 2.排序函数qsort 3.模拟实现qsort 回调函数为C语言重要知识点,以函数指针为主要知识;下面介绍回调函数的定义、回调函数的库函数举例即库函数模拟实现。 一、回调函数 1.回调函数定义 回调函数就是一…...
CentOS 7 上编译和安装 SQLite 3.9.0
文章目录 可能报错分析详细安装过程 可能报错分析 报错如下: django.core.exceptions.ImproperlyConfigured: SQLite 3.9.0 or later is required (found 3.7.17). 原因:版本为3.7.太低了,需要升级到3.9.0至少 详细安装过程 1.安装所需的…...
[GXYCTF2019]禁止套娃 无回显 RCE 过滤__FILE__ dirname等
扫除git 通过githack 获取index.php <?php include "flag.php"; echo "flag在哪里呢?<br>"; if(isset($_GET[exp])){if (!preg_match(/data:\/\/|filter:\/\/|php:\/\/|phar:\/\//i, $_GET[exp])) {if(; preg_replace(/[a-z,_]\(…...
Springboot使用Aop保存接口请求日志到mysql
1、添加aop依赖 <!-- aop日志 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-aop</artifactId></dependency> 2、新建接口保存数据库的实体类RequestLog.java package com.example…...
网络安全面试题汇总(附答案)
作为从业多年的网络安全工程师,我深知在面试过程中面试官所关注的重点及考察的技能点。网络安全作为当前信息技术领域中非常重要的一部分,对于每一个从事网络安全工作的人员来说,不仅需要掌握一定的技术能力,更需要具备全面的综合…...
Centos7安装kvm,配置虚拟机网络
1.安装软件包,禁用防火墙(非必须) yum -y install qemu-kvm libvirt virt-install 1)禁用防火墙(非必须) systemctl stop firewalld systemctl disable firewalld 2)禁用NetworkManager syst…...
Javascript文件上传
什么是文件上传 文件上传包含两部分, 一部分是选择文件,包含所有相关的界面交互。一部分是网络传输,通过一个网络请求,将文件的数据携带过去,传递到服务器中,剩下的,在服务器中如何存储…...
golang gin——文件上传(单文件,多文件)
文件上传 单文件上传 从form-data获取文件 package uploadimport ("github.com/gin-gonic/gin""net/http" ) // 单文件上传,多文件上传 func Upload(c *gin.Context) {file, _ : c.FormFile("file") // file为字段名dst : "…...
面试题:Redis和MySQL的事务区别是什么?
大家好,我是小米!今天我要和大家聊聊一个在技术面试中经常被问到的问题:“Redis和MySQL的事务区别是什么?”这个问题看似简单,但实际上涉及到了数据库和缓存两个不同领域的知识,让我们一起来深入了解一下吧…...
Canvas绘图
Canvas绘图 Canvas的意义 随着前端的不断发展,页面特效越来越炫酷,W3C组织也不断退出新的CSS特性:例如各种渐变,瀑布流布局,各种阴影,但是随着需求越来越花哨,W3C表示:我去你妈的&…...
逻辑回归评分卡
文章目录 一、基础知识点(1)逻辑回归表达式(2)sigmoid函数的导数损失函数(Cross-entropy, 交叉熵损失函数)交叉熵求导准确率计算评估指标 二、导入库和数据集导入库读取数据 三、分析与训练四、模型评价ROC曲线KS值再做特征筛选生成报告 五、行为评分卡模型表现总结 一、基础知…...
DPDK系列之三十三DPDK并行机制的底层支持
一、背景介绍 在前面介绍了DPDK中的上层对并行的支持,特别是对多核的支持。但是,大家都知道,再怎么好的设计和架构,再优秀的编码,最终都要落到硬件和固件对整个上层应用的支持。单纯的硬件好处理,一个核不…...
LVGL_基础控件滚轮roller
LVGL_基础控件滚轮roller 1、创建滚轮roller控件 /* 创建一个 lv_roller 部件(对象) */ lv_obj_t * roller lv_roller_create(lv_scr_act()); // 创建一个 lv_roller 部件(对象),他的父对象是活动屏幕对象// 将部件(对象)添加到组,如果设置了默认组,…...
王道考研操作系统——文件管理
磁盘的基础知识 .txt用记事本这个应用程序打开,文件最重要的属性就是文件名了 保护信息:操作系统对系统当中的各个用户进行了分组,不同分组的用户对文件的操作权限是不一样的 文件的逻辑结构就是文件内部的数据/记录应该被怎么组织起来&…...
商业智能系统的主要功能包括数据仓库、数据ETL、数据统计输出、分析功能
ETL服务内容包含: 数据迁移数据合并数据同步数据交换数据联邦数据仓库...
基于帝国主义竞争优化的BP神经网络(分类应用) - 附代码
基于帝国主义竞争优化的BP神经网络(分类应用) - 附代码 文章目录 基于帝国主义竞争优化的BP神经网络(分类应用) - 附代码1.鸢尾花iris数据介绍2.数据集整理3.帝国主义竞争优化BP神经网络3.1 BP神经网络参数设置3.2 帝国主义竞争算…...
将python项目部署在一台服务器上
将python项目部署在一台服务器上 1.服务器2.部署方法2.1 手动部署2.2 容器化技术部署2.3 服务器less技术部署 1.服务器 服务器一般为:物理服务器和云服务器。 我的是物理服务器:这是将服务器硬件直接放置在您自己的数据中心或机房的传统方法。这种方法需…...
【C语言】善于利用指针(二)
💗个人主页💗 ⭐个人专栏——C语言初步学习⭐ 💫点击关注🤩一起学习C语言💯💫 目录 导读:1. 字符指针1.1 字符串的引用方式1.2 有趣的面试题 2. 数组指针2.1 一维数组指针的定义2.2 一维数组…...
Python调用C++
https://www.cnblogs.com/renfanzi/p/10276997.html Linux使用Python调用C/C接口(一) - 代码先锋网 linux系统上使用Python调用C生成的.so动态链接库opencv_linux 下python 编译为so ,给c使用_比赛学习者的博客-CSDN博客 https://www.cnblogs.com/shuimuqingyang/p/13618105…...
自己实现扫描全盘文件的函数。
1.自己实现扫描全盘的函数 def scan_disk(dir): global count,dir_count if os.path.isdir(dir): files os.listdir(dir) for file in files: print(file) dir_count 1 if os.path.isdir(dir os.sep file): …...
JSON文件读写
1、依赖文件 #include <QFile> #include <QJsonDocument> #include <QJsonObject> #include <QDebug> #include <QStringList>2、头文件 bool ReadJsonFile(const QString& filePath""); bool WriteJsonFile(const QString&…...
VisualStudio2022环境下Release模式编译dll无法使用TLS函数问题
Debug x86环境下正常使用TLS回调函数 切换到Release发现程序没有使用tls 到C/C > 优化中将全程序优化关闭即可...
ChatGPT基础使用总结
文章目录 一、ChatGPT基础概念大型语言模型LLMs---一种能够以类似人类语言的方式“说话”的软件ChatGPT定义---OpenAI 研发的一款聊天机器人程序(2022年GPT-3.5,属于大型语言模型)ChatGPT4.0---OpenAI推出了GPT系列的最新模型ChatGPT典型使用…...
解决报错: require is not defined in ES module scope
用node启动mjs文件报错:require is not defined in ES module scope 现象如下: 原因: 文件后缀是mjs, 被识别为es模块,但是node默认是commonjs格式,不支持也不能识别es模块。 解决办法:把文件后缀从.mjs改…...
STM32 10个工程篇:1.IAP远程升级(六)
在IAP远程升级的最后一篇博客里,笔者想概括性地梳理总结IAP程序设计中值得注意的问题,诚然市面上或者工作后存在不同版本的IAP下位机和上位机软件,也存在不同定义的报文格式,甚至对于相似的知识点不同教程又有着完全不同的解读&am…...
【智能家居项目】裸机版本——字体子系统 | 显示子系统
🐱作者:一只大喵咪1201 🐱专栏:《智能家居项目》 🔥格言:你只管努力,剩下的交给时间! 今天实现上图整个项目系统中的字体子系统和显示子系统。 目录 🀄设计思路…...
PDF中跳转到参考文献后,如何回到原文
在PDF中,点击了参考文献的超链接可以直接跳至参考文献的位置。 如果想从当前参考文献在回到正文中对应位置时,可以通过 Alt \red{\text{Alt}} Alt ← \red{\leftarrow} ← 实现。...
了解基于Elasticsearch 的站内搜索,及其替代方案
对于一家公司而言,数据量越来越多,如果快速去查找这些信息是一个很难的问题,在计算机领域有一个专门的领域IR(Information Retrival)研究如何获取信息,做信息检索。在国内的如百度这样的搜索引擎也属于这个…...
【多模态融合】TransFusion学习笔记(2)
接上篇【多模态融合】TransFusion学习笔记(1)。 从TransFusion-L到TransFusion ok,终于可以给出论文中那个完整的框架图了,我第一眼看到这个图有几个疑问: Q:Image Guidance这条虚线引出的Query Initialization是什么意思? Q:图像分支中的…...
Pyhon-每日一练(1)
🌈write in front🌈 🧸大家好,我是Aileen🧸.希望你看完之后,能对你有所帮助,不足请指正!共同学习交流. 🆔本文由Aileen_0v0🧸 原创 CSDN首发🐒 如…...
合肥 做网站的公司/聊城疫情最新消息
题目描述:从扑克牌中随机抽5 张牌,判断是不是一个顺子,即这5 张牌是不是 连续的。2~10 为数字本身,A 为1,J 为11,Q 为12,K 为13,大小王可以看成 任意数字。 思路:用数组…...
软件下载网站开发/我赢网提供的高水平网页设计师
问题: 今天有用户在不知道做了什么操作,在输入密码后就一直停在那无法登陆GUI界面了。 本以为是root密码不对,尝试了恢复root密码操作无效。然后网上搜了一堆处理方法 切换tty命令界面 因为图形界面卡死了所以只能切换到tty命令模式看看能否…...
服装网站模块方案/百度优化seo
在glassfish中部署使用Inbound JCA 1.5 (by quqi99) 作者:张华 发表于:2009-10-19 版权声明:可以任意转载,转载时请务必以超链接形式标明文章原始出处和作者信息及本版权声明。 http://blog.csdn.net/quqi99 1 MDB ejb-jar.x…...
网站开发员招聘/武汉百度推广多少钱
IT行业的技术更新特别快,我们不能一直停留在老技术上而不去接收新的知识,其实作为一个程序员,学习知识的能力比起掌握的知识更重要。Python也是一个目前很火的语言,作为java后端的我,也必须在工作之余学习新知识&#…...
短链接生成接口/品牌搜索引擎服务优化
由于项目总是要不断的集成各种设备,每次集成一个完全不一样的设备的时候,都会相当麻烦,要侵入很多已经写好的代码,比如说控制类的设备,需要写控制日志,比如这次添加的新风机,控制风速需要写日志…...
做网站前怎么写文档/西安百度网站排名优化
如今内部人员给公司的安全造成的威胁非同小可。近来的一些报告指出,内部人员对公司的损害在所有的危害事件中已从80%上升为86%,而且超过半数发生在雇员的终端。无疑,拥有访问公司系统权限的内部雇员极有可能被误导到那些欺诈性的或危险的链接上。而在所有…...