-
浅谈十进制小数和二进制小数之间的转换
所属栏目:[经验] 日期:2020-12-31 热度:50
一、二进制数转换成十进制数 由二进制数转换成十进制数的基本做法是,把二进制数首先写成加权系数展开式,然后按十进制加法规则求和。这种做法称为"按权相加"法。 二、十进制数转换为二进制数 十进制数转换为二进制数时,由于整数和小数的转换方法不同,所以[详细]
-
浅谈带缓冲I/O 和不带缓冲I/O的区别与联系
所属栏目:[经验] 日期:2020-12-31 热度:110
这里搜集从网上看到的一些言论,自认为还是比较靠谱的,有些不靠谱的根据自己的理解进行了修正。 首先要明白不带缓冲的概念: 所谓不带缓冲,并不是指内核不提供缓冲,而是只单纯的系统调用,不是函数库的调用 。系统内核对磁盘的读写都会提供一个块缓冲(在[详细]
-
浅谈哈希表存储效率一般不超过50%的原因
所属栏目:[经验] 日期:2020-12-31 热度:156
本文主要是讲"哈希表的存储效率一般不超过50%"的原因。 Hash Table 常用于频繁进行 key/value 模式的查找中。(查找模式,如匹配查找) 哈希表最大的优点在于查找速度快,但存储时可能发生collision(冲突)。 哈希表大多使用open addressing来解决collision,此[详细]
-
C语言去除相邻重复字符函数的实现方法
所属栏目:[经验] 日期:2020-12-31 热度:51
C语言去除相邻重复字符函数的实现方法 字符去重函数 功能:去重字符串相邻重复的字符,不相邻的不用去重 参数: arg1 -- 输入字符串 arg2 -- 字符串开始位置 arg3 -- 字符串结束位置 要求: 输入参数为arg1时, 对这个字符串去重 输入参数为arg1,arg2时,[详细]
-
C语言实现动态顺序表的实现代码
所属栏目:[经验] 日期:2020-12-31 热度:75
C语言实现动态顺序表的实现代码 顺序表是在计算机内存中以数组的形式保存的线性表,是指用一组地址连续的存储单元依次存储数据元素的线性结构。线性表采用顺序存储的方式存储就称之为顺序表。顺序表是将表中的结点依次存放在计算机内存中一组地址连续的存储[详细]
-
浅谈在函数中返回动态的内存
所属栏目:[经验] 日期:2020-12-31 热度:86
1、有以下题目: #include iostreamusing namespace std;void GetMemeory(char* p){ p=(char*)malloc(sizeof(char)*100);}int main(){ char *str=NULL; GetMemeory(str); strcpy(str,"Thunder"); strcat(str,"Downloader"); printf(str); system("pause"); r[详细]
-
浅谈do {...} while (0) 在宏定义中的作用
所属栏目:[经验] 日期:2020-12-31 热度:123
如果你是一名C程序员,你肯定很熟悉宏,它们非常强大,如果正确使用可以让你的工作事半功倍。然而,如果你在定义宏时很随意没有认真检查,那么它们可能使你发狂,浪费N多时间。在很多的C程序中,你可能会看到许多看起来不是那么直接的较特殊的宏定义。 下面[详细]
-
关于win32 gettimeofday替代方案
所属栏目:[经验] 日期:2020-12-31 热度:119
来自nginx代码: voidngx_gettimeofday(struct timeval *tp){ uint64_t intervals; FILETIME ft; GetSystemTimeAsFileTime( /* * A file time is a 64-bit value that represents the number * of 100-nanosecond intervals that have elapsed since * Janua[详细]
-
实现一个内存池管理的类方法
所属栏目:[经验] 日期:2020-12-31 热度:78
模拟STL中的freelist,有这个思想在内。 union obj{ union obj* next; char p[1]; };class MemoryPool{ public: MemoryPool() { union obj* temp; m_memory.assign(5,(union obj*)NULL); for(int i=0;im_memory.size();i++) { for(int j=0;jm_memory.size();j[详细]
-
C++实现的打字母游戏示例
所属栏目:[经验] 日期:2020-12-31 热度:59
本篇章节讲解C++实现的打字母游戏。供大家参考研究具体如下: // 打字母的游戏// 编译代码请先安装 VC 绘图库(V20091123)#include graphics.h#include conio.h#include time.h// 欢迎界面void welcome(){ // 输出屏幕提示 cleardevice(); setcolor[详细]
-
C++面试题之结构体内存对齐计算问题总结大全
所属栏目:[经验] 日期:2020-12-31 热度:65
前言 本文给大家介绍的是关于C++结构体内存对齐计算的相关内容,内存对齐计算可谓是笔试题的必考题,但是如何按照计算原则算出正确答案一开始也不是很容易的事,所以专门通过例子来复习下关于结构体内存对齐的计算问题。话不多说,来一起看看详细介绍吧。 编[详细]
-
C++中的四个默认成员函数与运算符重载详解
所属栏目:[经验] 日期:2020-12-31 热度:191
本文主要给大家介绍了关于C++默认成员函数与运算符重载的相关内容,分享出来公的敬爱啊参考学习,话不多说,来一起看看详细的介绍: 一:类和对象的基础知识:类的定义,访问限定符,面向对象封装性,对象的大小计算等等。(编译环境为VS2015) 面向对象程序[详细]
-
C++数据精度问题的解决方案(对浮点数保存指定位小数)
所属栏目:[经验] 日期:2020-12-31 热度:199
1、背景 对浮点数保存指定位小数。比如, 1.123456. 要保存1位小数,,调用方法后, 保存的结果为: 1.1。 再比如,1.98765, 保存2位小数的结果为: 2.00. 2、 解决方案 A、添加头文件 #include sstream #include iomanip B、添加命名空间 using namespace s[详细]
-
利用C++如何覆盖或删除指定位置的文件内容
所属栏目:[经验] 日期:2020-12-31 热度:133
前言 最近在工作中遇到一个问题,需要覆盖或者删除指定位置的文件内容,发现网上这方面的资料较少,无奈只能自己解决,下面将自己解决的方法分享给大家,方便大家参考学习,下面话不多说了,来一起看看详细的介绍吧。 一、覆盖指定位置的文件内容 我们经常使[详细]
-
C语言中字符串的存储方法
所属栏目:[经验] 日期:2020-12-31 热度:198
众所周知,C语言中没有数据类型能够存储字符串,char数据类型仅仅能够存储一个字符的数据,那么在C语言中关于存储字符串这一难题我们改何去何从呢? 下面将详述相关的字符串存储方法; 1、使用字符数组存; [root@Qrui ruiy]##includestdio.hint main(int argc,[详细]
-
C语言数据结构 快速排序实例详解
所属栏目:[经验] 日期:2020-12-31 热度:112
C语言数据结构 快速排序实例详解 一、快速排序简介 快速排序采用分治的思想,第一趟先将一串数字分为两部分,第一部分的数值都比第二部分要小,然后按照这种方法,依次对两边的数据进行排序。 二、代码实现 #include stdio.h/* 将两个数据交换 */void swap(i[详细]
-
C/C++中输入多组数据的方法
所属栏目:[经验] 日期:2020-12-31 热度:50
如果在刚开始学习算法,做算法题的时候,题上经常会要求输入多组数据,对于刚开始学习的小白来说,可能不知道怎么算输入多组数据,也不知道该怎么处理,刚好想起来,就把方法记录一下 怎么算输入多组数据? 一般题中要求输入多组数据的意思就是读取数量不定[详细]
-
C语言中strlen() strcpy() strcat() strcmp()函数的实现方法
所属栏目:[经验] 日期:2020-12-31 热度:127
strlen函数原型: unsigned int strlen(const char *); 返回的是字符串中第一个 之前的字符个数。 1.strcat函数原型 char* strcat(char* dest,const char* src); 进行字符串的拼接,将第二个字符串连接到第一个字符串中第一个出现 开始的地方。返回的是拼接[详细]
-
C++实现多源最短路径之Floyd算法示例
所属栏目:[经验] 日期:2020-12-31 热度:51
本篇章节讲解C++实现多源最短路径之Floyd算法。供大家参考研究具体如下: #includecstdio#includecstring#includeiostream#define MAX 999using namespace std;int n,m;int e[MAX][MAX];void Init(){ for(int i=1; i=n; ++i) for(int j=1; j=n; ++[详细]
-
C语言 数据结构链表的实例(十九种操作)
所属栏目:[经验] 日期:2020-12-30 热度:140
C语言 数据结构链表的实例(十九种操作) #include stdio.h#include string.h#include stdlib.h/*************************************************************************************//* 第一版博主 原文地址 http://www.cnblogs.com/renyuan/archive/2[详细]
-
C语言中编写可变参数函数
所属栏目:[经验] 日期:2020-12-30 热度:156
通过stdarg.h头文件为函数提供了定义可变参数列表的能力。声明一个可变参数的函数类似: void f1(int n,...); 其中n表示参数列表个数,而用省略号来表示未知参数列表。stdarg.h中提供了一个va_list类型,用于存放参数。一个大概的使用过程类似: void f1(int[详细]
-
Qt实现FTP的上传和下载的实例代码
所属栏目:[经验] 日期:2020-12-30 热度:87
为了方便网络编程,Qt 提供了 Network 模块。该模块包含了许多类,本文介绍了Qt实现FTP的上传和下载,分享给大家 本来想简单抄抄书,随便手写个Ftp客户端的,结果发现教材上的是基于Qt4的QFtp类库,而在Qt5中取消了这一个类库(同时也取消了QHttp等的类),[详细]
-
C语言实现“幸运数”的实例详解
所属栏目:[经验] 日期:2020-12-30 热度:63
C语言实现“幸运数”的实例详解 1、题目: 标题:幸运数 幸运数是波兰数学家乌拉姆命名的。它采用与生成素数类似的“筛法”生成。 首先从1开始写出自然数1,2,3,4,5,6,…. 1 就是第一个幸运数。 我们从2这个数开始。把所有序号能被2整除的项删除,变为: 1 _[详细]
-
浅谈Qt中使用CEF的几个要点(Windows下)
所属栏目:[经验] 日期:2020-12-30 热度:180
最近项目中要在Qt中使用CEF(Chromium Embedded Framework),在这里总结下其中的几个要点。 下载合适的CEF版本 关于CEF的简介我们这里就不做介绍了,下载CEF可以有2种选择: 1、源码:强烈不建议下载源代码并编译构建(学习代码除外),下载源码需要你FQ、[详细]
-
Linux中出现“No space left on device”错误的排查与解决方法
所属栏目:[经验] 日期:2020-12-26 热度:124
前言 最近这两天登陆服务器,发现用 wget 下载文件的时候提示“No space left on device”,而且连使用 tab 键进行补全时也会提示该错误。 之前遇到过一次这种问题,是由于磁盘空间被占满了,导致无法创建新文件。正常情况下,删除一些文件来释放空间,即可[详细]