C/C++一些库函数的实现
1. 写出String的具体实现
类的定义:
#include <iostream>
#include <cstring>
using namespace std; class String
{
friend ostream & operator<<(ostream &, const String &);
public:
String(const char *str = NULL);
String(const String &);
String & operator=(const String &);
~String();
private:
char *m_data;
};
类成员函数的实现:
String::~String()
{
if (m_data) delete[] m_data;
} String::String(const char *str)
{
if (str == NULL)
{
m_data = new char[1];
m_data[0] = '\0';
}
else
{
m_data = new char[strlen(str)+1];
strcpy(m_data, str);
}
} String::String(const String &other)
{
m_data = new char[strlen(other.m_data)+1];
strcpy(m_data, other.m_data);//String str;str.m_data;
} String & String::operator=(const String &other)
{
if (this == &other) return *this; delete[] m_data;
m_data = new char[strlen(other.m_data)+1];
strcpy(m_data, other.m_data);
return *this;
} ostream & operator<<(ostream &out, const String &s)
{
out << s.m_data;
return out;
} int main()
{
String str;
String str2("hello");
String str3(str2);
String str4 = str2; cout << str << "#" << endl;
cout << str2 << endl;
cout << str3 << endl;
cout << str4 << endl;
}
2. 编写一个标准strcpy函数
总分值为10,下面给出几个不同得分的答案
以下是2分程序片段:
void strcpy(char *dest, char *src)
{
while ((*dest++ = *src++) != '\0');
}
以下是4分程序片段:
//将源字符串加const
void strcpy(char *dest, const char *src)
{
while ((*dest++ = *src++) != '\0');
}
以下是7分程序片段:
//对源地址和目的地址加非NULL断言
void strcpy(char *dest, const char *src)
{
assert((dest != NULL) && (src != NULL));
while ((*dest++ = *src++) != '\0');
}
以下是10分程序片段:
//为了实现链式操作,将目的地址返回
char *strcpy(char *dest, const char *src)
{
assert((dest != NULL) && (src != NULL));
if (dest == src) return dest;
char *addr = dest;
while ((*dest++ = *src++) != '\0');
return addr;
}
可以清楚的看到,小小的strcpy竟然暗藏着这么多玄机,真不是盖的!需要多么扎实的基本功才能写一个完美的strcpy啊!
读者看了不同分值的strcpy版本,应该也可以写出一个10分的strlen函数了:
int strlen(const char *str)
{
assert(str != NULL);
int len = 0;
while (*str++ != '\0') len++;
return len;
}
函数strcmp的实现:
int strcmp(const char *str1, const char *str2)
{
assert((str1 != NULL) && (str2 != NULL));
while (*str1 && *str2 && (*str1 == *str2))
{
str1++;
str2++;
}
return *str1 - *str2;
}
3. 文件中有一组整数,要求从小到大排序后输出到另一个文件中
#include <iostream>
#include <fstream>
#include <vector>
using namespace std;
//simple bubble sort
void sort(vector<int> &data)
{
int temp, n = data.size();
for (int i = 1; i < n; i++)
for (int j = 0; j < n-i; j++)
if (data[j] > data[j+1])
{
temp = data[j];
data[j] = data[j+1];
data[j+1] = temp;
}
} int main()
{
ifstream in(".\\data.txt");
if (!in)
{
cout << "open file error!" << endl;
exit(1);
} int temp;
vector<int> data;
while (!in.eof())
{
in >> temp;
data.push_back(temp);
}
in.close(); sort(data); ofstream out(".\\result.txt");
if (!out)
{
cout << "create file error!" << endl;
exit(1);
}
for (size_t i = 0; i < data.size(); i++)
out << data[i] << " ";
out.close();
}
4. 两个int型数据,不用任何的判断语句如 if、switch、?: 等,找出其中的大值
int max(int x, int y)
{
int buf[2] = {x, y};
unsigned int z = x - y;
z >>= 31;
return buf[z];
}
利用位运算,不过一个很大的正数和一个很小的负数比较可能会溢出。
C/C++一些库函数的实现的更多相关文章
- Entity Framework 6 Recipes 2nd Edition(11-11)译 -> 在LINQ中调用数据库函数
11-11. 在LINQ中调用数据库函数 问题 相要在一个LINQ 查询中调用数据库函数. 解决方案 假设有一个任命(Appointment )实体模型,如Figure 11-11.所示, 我们想要查 ...
- Linux系统调用和库函数调用的区别
Linux下对文件操作有两种方式:系统调用(system call)和库函数调用(Library functions).系统调用实际上就是指最底层的一个调用,在linux程序设计里面就是底层调用的意思 ...
- C标准I/O库函数与Unbuffered I/O函数
一.C标准I/O库函数.Unbuffered I/O函数 1. C标准I/O库函数是如何用系统调用的 fopen(3) 调用open(2)打开制定的文件,返回一个文件描述符(一个int类型的编号),分 ...
- [Django]模型提高部分--聚合(group by)和条件表达式+数据库函数
前言:本文以学习记录的形式发表出来,前段时间苦于照模型聚合中group by 找了很久,官方文章中没有很明确的说出group by,但在文档中有提到!!! 正文(最后编辑于2016-11-12): 聚 ...
- STM32库函数编程、Keli/MDK、stm32f103zet6
catalogue . Cortex-M3地址空间 . 基于标准外设库的软件开发 . 基于固件库实现串口输出(发送)程序 . 红外接收实验 . 深入分析流水灯例程 . GPIO再举例之按键实验 . 串 ...
- LPC1768/1769之CAN控制器概述(附库函数下载地址)
一.背景: 使用LPC1769来做CAN的收发,在此对使用LPC1769的CAN控制器进行收发做个总结和记录,以备下 次开发快速上手使用. 附:LPC1768/1769除了支持最高频率不同以外,其它基 ...
- 如何快速上手使用STM32库函数
一.背景 如前文所述,利用标准库函数的好处在于,可以快速开发,不用去对着数据手册,小心翼翼的一位一位的配置那些繁复的寄存器,因为这些工作意法半导体已经找了一些顶级的工程师帮你做了,杰作既是其库函数.当 ...
- 【XLL 框架库函数】 TempActiveRef/TempActiveRef12
[XLL 框架库函数] TempActiveRef/TempActiveRef12 创建一个包含所有激活工作表引用区域 XLOPER/XLOPER12 LPXLOPER TempActiveRef(B ...
- linux内核分析作业4:使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用
系统调用:库函数封装了系统调用,通过库函数和系统调用打交道 用户态:低级别执行状态,代码的掌控范围会受到限制. 内核态:高执行级别,代码可移植性特权指令,访问任意物理地址 为什么划分级别:如果全部特权 ...
- C语言-两个库函数
两个库函数 --1-- printf函数 1.1 printf 函数的介绍 1.2 格式控制字符串 1.3 %f输出精度的问题 1.4 printf 函数使用注意事项 --2-- scanf函数 2. ...
随机推荐
- Java B
3.继承时候类的执行顺序问题,一般都是选择题,问你将会打印出什么? 答:父类: package test; public class FatherClass { public FatherClass( ...
- Hadoop架构模型
1.hadoop 1.x架构模型:分布式文件存储系统:HDFSNameNode(主节点:管理元数据) secondaryNameNode(作用是合并元数据信息,辅助NameNode管理元数据信息)Da ...
- pytorch笔记:09)Attention机制
刚从图像处理的hole中攀爬出来,刚走一步竟掉到了另一个hole(fire in the hole*▽*) 1.RNN中的attentionpytorch官方教程:https://pytorch.or ...
- https://blog.csdn.net/blmoistawinde/article/details/84329103
背景 很多场景需要考虑数据分布的相似度/距离:比如确定一个正态分布是否能够很好的描述一个群体的身高(正态分布生成的样本分布应当与实际的抽样分布接近),或者一个分类算法是否能够很好地区分样本的特征 ...
- javascript中常见undefined与defined的区别
在JavaScript中相信“undefined”与“defined”对大家来说都肯定不陌生,但是又不是很清楚它们的区别,先看两个demo我们再说, 例1. console.log(parms); / ...
- 笔试算法题(25):复制拥有多个指针的链表 & 判断二元树B是否为A的子树
出题:定义一个复杂链表:在单向链表的基础上,每个节点附加一个指向链表中其他任意节点的指针sibling,实现CNode* Clone(Cnode *head)函数复制这个复杂链表: 分析: 解法1:将 ...
- Vue如何引入icon图标
1.下载icon图标,推荐icomoon网站,里面有大量的矢量图标,也可以自定义,当然你也可以去阿里巴巴矢量图标库下载你所需要的小图标.点击进入icomoon网站点击右上角“IcoM ...
- cookie、localStorage和sessionStorage三者的异同
1.三者都是用来存储浏览器数据的 2.生命周期:cookie可以设置数据失效时间,默认是关闭浏览器后失效:localStorage中的数据是永久保存的,除非手动清除:sessionStorage的数据 ...
- jQuery实现上传进度条效果
效果:(点击上传按钮) See the Pen pjGNJr by moyu (@MoYu1991) on CodePen. html代码: <!DOCTYPE html> <h ...
- BNUOJ 5363 Machine Schedule
Machine Schedule Time Limit: 1000ms Memory Limit: 32768KB This problem will be judged on HDU. Origin ...