久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

C語言的編程之美之內存函數

這篇文章主要介紹了C語言全部內存操作函數的實現詳細講解,作者用圖文代碼實例講解的很清晰,有感興趣的同學可以研究下

內存函數

memcpy內存拷貝

  • 函數memcpy從source的位置開始向后復制num個字節的數據到destination的內存位置。
  • 這個函數在遇到 ‘\0' 的時候并不會停下來。
  • 如果source和destination有任何的重疊,復制的結果都是未定義的。

原格式

image-20210912150415470

分析

**字面上意思只要是內存里面的東西就都可以進行拷貝,所以就打破了字符串拷貝的魔咒,什么類型都可以進行拷貝,那就不需要想來,肯定回和萬能類型(通用類型指針-無類型指針)void*有關,因為當時做qsort還是印象深刻的


/*num是幾個字節的意思*/
void* my_memcpy(void* dest, const void* src, size_t num)
{
	assert(dest && src);
	void* ret = dest;
	while (num--)
	{
		//和void*連用char*,分成最小然后一個一個傳
		*(char*)dest = *(char*)src;
		((char*)dest)++;//void*無類型不好直接加加,就強轉char*再加加
		((char*)src)++;
	}	
	return ret;
}

內存拷貝的問題

1.內存相關連的話,就會拷貝錯誤

image-20210912174618496

那你怎么解決內存相關連還不會有上面的錯誤,正面賦值交集的內存空間會被操作兩次,就會改變原來的值,那我們怎么做呢,如果從后面來呢,前面操作兩次會把后面的變了,那就先把后面的拿走賦值,不就間接的改變了原來會變的情況了嗎,所以這樣上面的代碼就得修改了,這是朝后面拷貝的情況,如果提目是朝前面拷貝的話,是不是從后面來就有問題了,反而從前面來會比較完美,所以我們得兩種情況都得考慮到

所以為了解決重疊拷貝的問題就有了memmove這個函數

2.內存不夠了還要朝里面拷貝直接程序掛了

image-20210912175703527

memmove內存重疊拷貝

用來處理內存重疊的情況

C語言規定

memcpy 只要處理內存不重疊的拷貝就可以

memmove 處理重疊內存拷貝

我們重寫memcpy的代碼是滿足C語言要求的,在vs這個編譯器中memcpy實際上是超額完成任務了,他的效果已經和memmove效果一樣了

image-20210912201352859

你會發現他們跑出來的效果 是一樣的,所以上面那個測試我就是用我自己的代碼測試的(已經達到C語言的標準了)

我們再精細點就是memmove的內容了

原格式

image-20210912195704561

分析

image-20210912200345318

image-20210912210111460

image-20210912210718304

image-20210912212544483


/*num是幾個字節的意思*/
void* my_memmove(void* dest,const void* src, size_t num)//memmove和memcpy的參數是一樣的
{
	assert(dest && src);
	void* ret = dest;
	if (dest < src)
	{
		while (num--)
		{
			//sre內存從前向后拷貝
			//和void*連用char*,分成最小然后一個一個傳
			*(char*)dest = *(char*)src;
			((char*)dest)++;//void*無類型不好直接加加,就強轉char*再加加
			((char*)src)++;
		}
	}
	else
	{
		while (num--)
		{
			//sre內存從后向前拷貝
			//和void*連用char*,分成最小然后一個一個傳
			*((char*)dest+num) = *((char*)src+num);
			//((char*)dest)++;//void*無類型不好直接加加,就強轉char*再加加
			//((char*)src)++;
		}
	}	
	return ret;
}

image-20210912215713723

memset內存設置

將緩沖區設置為指定的字符。

原格式

image-20210912224129279

memcmp內存比較

和strcmp相似,只不過一個是比較字符串,一個比較內存,由于不知道什么類型,所以后面有字節個數限制,準確的說應該和strncmp相似,因為后面都有一個個數的參數

原格式

image-20210912222610487

分析

基本和字符串比較一樣,就是變成了內存比較罷了

image-20210912233051911

image-20210912233234287


//buf1內存里的內容比buf2內存里的內容大就>0,反之<0
int my_memcmp(const void* buf1, const void* buf2, size_t count)
{
	assert(buf1 && buf2);
	while (--count && *(char*)buf1 == *(char*)buf2)//這個先減減就是細節
	{
		((char*)buf1)++;
		((char*)buf2)++;
	}
	if (*(char*)buf1 - *(char*)buf2 > 0)
		return 1;
	if (*(char*)buf1 - *(char*)buf2 < 0)
		return -1;
	return 0;
}

給你count不要亂超,因為他操作的是內存,沒有字符串補\0的功能

總結

本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關注html5模板網的更多內容!

【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!

相關文檔推薦

這篇文章主要介紹了C語言指針引用數組案例講解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下
這篇文章主要介紹了使用C語言操作文件的基本函數整理,包括創建和打開以及關閉文件的操作方法,需要的朋友可以參考下,希望能夠給你帶來幫助
scanf()函數是通用終端格式化輸入函數,它從標準輸入設備(鍵盤)讀取輸入的信息,接下來通過本文給大家介紹C語言中關于scanf讀取緩存區的問題,需要的朋友一起看看吧
本文主要講解C語言 常量,這里整理了 C語言常量的基礎知識,并附代碼示例和示例詳細講解,希望能幫助開始學習C 語言的同學
本文給大家分享的是一則使用C語言實現動態數組的代碼,完美解決內存溢出以及內存回收問題,有需要的小伙伴可以參考下
這篇文章主要為大家詳細介紹了C語言實現隨機抽獎程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
主站蜘蛛池模板: 国产在线精品一区二区 | 综合久 | 91精品观看| 欧美一二三 | 欧美一区视频 | 91不卡在线 | 国产精品免费一区二区三区四区 | 拍戏被cao翻了h承欢 | 日韩中文字幕第一页 | 久久久成人一区二区免费影院 | 亚洲欧美一区二区三区在线 | 亚洲欧美国产毛片在线 | 国产欧美日韩一区 | 成人中文字幕在线 | 欧美精品二区 | 密色视频 | 亚洲精品一区二区 | 伊人伊成久久人综合网站 | 在线成人一区 | 欧美a级成人淫片免费看 | 亚洲欧洲精品一区 | 国产免费一区 | 免费99视频| 久久福利 | 久久久性色精品国产免费观看 | 老妇激情毛片免费 | 国产精品亚洲一区二区三区在线 | 成人av网站在线观看 | 黄网免费看 | 国产情侣久久 | 91久久精品国产91久久性色tv | 国产视频1区 | 在线免费观看a级片 | 国产1区2区在线观看 | h在线 | 成人精品一区二区三区四区 | 亚洲一区二区三区免费在线观看 | 精品国产不卡一区二区三区 | 亚洲综合天堂网 | 一区二区三区视频在线观看 | 中文字幕免费 |