C++ 进阶笔记:一些库函数……还有一些奇技淫巧

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/sinat_27382047/article/details/81951153

一、奇技淫巧

1.取带小数的余数

(1)“整除”取余法

#include<iostream>
using namespace std;

void main()
{
	float a = 362.75;
	int b = 360;
	float aMod= a - ((int)a / b)*b;
	cout << aMod << endl;
}

(2)循环减法

#include<iostream>
using namespace std;

void main()
{
	float a = 362.75;
	int b = 360;
	while (a > b) { a = a - b; }
	float aMod= a ;
	cout << aMod << endl;
}

2.取静态数组长度

#include<iostream>
using namespace std;

void main()
{
	char d[50];	
	cout << (sizeof(d) / sizeof(char)) << endl;
}

3.把结构体变成字符串【网络编程发送数据包时有用】

#include<iostream>
using namespace std;

struct A
{
	int a; char b;
};
void main()
{
	char d[50];
	struct A a;//创建A类型对象a
	//对象a的赋值
	a.a = 1; a.b = 'o';
	//把结构体“变成字符串”
	memcpy(d, &a, sizeof(a));
	//现在把a改掉
	a.a = 2; a.b = 'B';
	//把“字符串”变回a【删掉下句则不会变回“1 o”】
	memcpy(&a, d, sizeof(a));
	//输出的a还是“1 o”,而不是“2 B”
	cout << a.a << ' ' << a.b << endl;
}

注意sizeof会产生“内存补齐”!!!

二、一些库函数

1.内存、字符串处理

(1)memcpy

memcpy指的是c和c++使用的内存拷贝函数,memcpy函数的功能是从源src所指的内存地址的起始位置开始拷贝n个字节到目标dest所指的内存地址的起始位置中。

函数原型

void *memcpy(void *dest, const void *src, size_t n);

功能

从源src所指的内存地址的起始位置开始拷贝n个字节到目标dest所指的内存地址的起始位置中

所需头文件

C语言:#include<string.h>

C++:#include<cstring>

返回值

函数返回指向dest的指针。

例子

#include<string.h>
#include<stdio.h>
void main()
	{
	char* s = "GoldenGlobalView";
	char d[20];
	memcpy(d,s + 12,4);//从第13个字符(V)开始复制,连续复制4个字符(View)
	//memcpy(d,s+12*sizeof(char),4*sizeof(char));//也可
	d[4] = '\0';
	printf("%s",d);
	getchar();
	}

(2)memset

(3)strcpy

2.排序、交换、比较

(1)Sort函数

参考:https://www.cnblogs.com/jjzzx/p/5122381.html

Sort函数有三个参数:

(1)第一个是要排序的数组的起始地址

(2)第二个是结束的地址(最后一位+1的要排序的地址)

(3)第三个参数是排序的方法,可以是从大到小也可是从小到大,还可以不写第三个参数,此时默认的排序方法是从小到大排序。

Sort函数使用模板: Sort(start,end,排序方法)  【第三个参数(排序方法)没有则默认升序(可自定义比较函数)】

#include <iostream>//sort只在c++里能用
#include <algorithm>
int main()
{
	int A[10] = {2,1,2,3,5,4,6,3,1,4};
	//std::sort(A[0], A[9]);//参数是地址,而不是int型的值!
	std::sort(A, A + 10);//第二个参数是结束的地址(最后一位要排序的地址的下一地址)【第三个参数没有则默认升序(可自定义比较函数)】

	for (int i = 0; i < 10; i++)
		printf("%d ", A[i]);
	return 0;
}

(2)swap函数

#include<iostream>
#include<string>
using namespace std;
int main()
{
    string a ="666",b = "999";
    swap(a,b);
    cout<<a<<"->"<<b<<endl;
    return 0;
}

(3)max、min函数

三、vector

四、socket相关

猜你喜欢

转载自blog.csdn.net/sinat_27382047/article/details/81951153