[問題]char 指標問題

作者: amamoimi (佛仔)   2023-10-15 14:49:24
不好意思我程式新手又來擾民了@@
https://onlinegdb.com/Vm941gQ0_
這是我在書上看到的程式碼
功能是把變數byte by byte的交換
但是我看不太懂那個swap函數...
為什麼可以隨便把參數冠上一個(char* )啊?
譬如a跟b明明就是int
把&a跟&b 前面加一個(char *)是什麼意思啊?又為什麼特別指定char呢?
chatgpt 的解釋是說(char*)x是在告訴compiler要把x跟y當作a sequence of bytes.
為啥!?
在本版獲益良多,希望各位這次也能不吝指教
謝謝大家!
作者: ssdoz2sk (眷戀著提拉米蘇的風采~)   2023-10-15 15:01:00
因為以基礎的資料型態來說,只有 char, int, float, double 與 signed, unsigned, 的各式組合,而其中 char 為1 byte。(char *) 是把整個資料當作一個長度為 n 的 byte array 來看。
作者: Lhmstu (lhmstu)   2023-10-15 15:06:00
char = 1 byte 一般來說是 8 bits,這邊轉成char*一次對1byte 進行互換(原本丟進函數後為已轉為 void*),也就是說“接下來我一次要操作一個byte”這樣的意思,所以後面++操作都是把pointer移動一個byte,移動幾次則是根據你丟進去的size決定
作者: ssdoz2sk (眷戀著提拉米蘇的風采~)   2023-10-15 15:08:00
補充一下,我習慣會重新定義 typedef unsigned charUINT8; 。會比較直觀易懂,資料就是一個個 byte ,不會跟字串搞混。
作者: amamoimi (佛仔)   2023-10-15 15:14:00
謝謝z大的詳細解釋!我懂為什麼要用char了,但我還是不太懂為什麼(char*)a是合法的寫法...a明明就是一個整數變數,為什麼可以創造一個char指標指向一個存著整數的記憶體位置啊@@
作者: Lhmstu (lhmstu)   2023-10-15 15:19:00
int 是4 bytes,你可以想像一個byte是一個箱子。而int*是指向排好的箱子的頭,可以一次移動改寫操作這四個箱子,如果你只想一次改動一個箱子( 1 byte),就可以轉成char*,一次只對一個byte做處理,這就是強制性別轉換。也是系統大了之後容易有bug的地方(x
作者: saxontai (黑暗,點綴孤零零的星)   2023-10-15 15:38:00
有stdint.h了,可以不用再自己typedef
作者: wulouise (在線上!=在電腦前)   2023-10-15 15:39:00
use case不合理,什麼情況要swap不同type的資料?你要不要貼一下書名給大家看,有可能你的書太舊或寫得不好最早c只有char代表8bits type,後來才有uint8_t
作者: amamoimi (佛仔)   2023-10-15 15:56:00
書名是「第一次學C++就上手」我好像稍微懂了...所以其實可以assign一個地址(不管那個地址存放什麼變數)給任何指標(指向任何型態)囉?(混亂...其實不管什麼資料型態都是0101嘛)想再問一下 void*型態的參數是只要是地址都可以接收嗎?
作者: Lhmstu (lhmstu)   2023-10-15 16:53:00
是的,void *是萬用。如果要處理任何資料,都需要先把void*轉成對應想要處理的型別的指標你可以嘗試 unsigned int x = 258 然後強制轉型成(unsigned char) 然後看結果,因為一個byte最多存256個值(258會進位用到下一個byte)
作者: amamoimi (佛仔)   2023-10-15 17:12:00
了解了 謝謝大大!
作者: johnjohnlin (嗯?)   2023-10-15 19:47:00
建議還是使用std::swap
作者: wulouise (在線上!=在電腦前)   2023-10-15 20:44:00
byte by byte copy不一定比較快,沒必要自己寫swap
作者: Dracarys (MayShowGunMore)   2023-10-16 01:42:00
作者: leolarrel (真.粽子無雙)   2023-10-16 12:55:00
你可能要先回去複習計概,重新理解什麼是記憶體不然版友回答得再多妳還是有聽卻自以為懂
作者: amamoimi (佛仔)   2023-10-16 14:10:00
謝謝 不過我我們同時修程式跟計概,所以我現在還在學習計概中@@
作者: descent (「雄辯是銀,沉默是金」)   2023-10-16 14:45:00
推薦 C语言程序设计现代方法第2版, 很好的入門書
作者: amamoimi (佛仔)   2023-10-16 14:48:00
另外想問一下https://onlinegdb.com/JH-pAJEJjb這時剛剛用來測試的程式我不小心把cout<<*b寫成cout<<b 結果為什麼output是一樣的勒xd
作者: yvb   2023-10-16 15:27:00
計概教到 little endian 了嗎?
作者: Dracarys (MayShowGunMore)   2023-10-16 15:29:00
因為你呼叫到吃const char*的operator<<了,就像你寫std::cout << “M”;
作者: leolarrel (真.粽子無雙)   2023-10-17 12:38:00
哪一家爛補習班不先教計概就教C語言阿? c/cpp語言又不像python 是高階語言,中低階語言很吃系統底層知識還有你上次問的遞迴,因為你沒有根本上理解遞迴的核心義意,所以才會問出那樣的問題.
作者: yvb   2023-10-17 15:41:00
可能是學校排課程的問題吧.
作者: closer76 (克樓瑟)   2023-10-17 17:12:00
我二十多年前在大學就是在計概課學C的啊!XDD
作者: Richun (解放左手的OO之力)   2023-10-17 17:12:00
如果從140那個IP來看,大一課程同時排計概跟程式設計常見不過先教C++這個做法真的頗神奇,怎麼不是先教C或python?
作者: closer76 (克樓瑟)   2023-10-17 17:13:00
嚴格來說當年我們系上根本沒有單獨的C語言課,教授只有安排助教在晚上開C的補習課,真的需要的人就問助教。
作者: Richun (解放左手的OO之力)   2023-10-17 17:16:00
在學校的話TA時間就過去問爆,C++複雜度很高,陷阱很多。
作者: closer76 (克樓瑟)   2023-10-17 17:19:00
同意,C++真的複雜太多。學得越多越怕踩到陷阱 XD@amamoimi: 你要不要試著把 a=77 改成 a=21325 試試?這樣 cout<<b 和 cout<<*b 結果就會不一樣喔!然後你可以自己思考一下為什麼會這樣。
作者: amamoimi (佛仔)   2023-10-17 17:35:00
有喔 我昨天花了一些時間測試了各種東西~感覺又複習了不少東西感謝各位大前輩願意建議與指點本菜鳥!!
作者: DerLuna (陽月)   2023-10-18 21:03:00
這真的好難懂
作者: CoNsTaR ((const *))   2023-10-19 03:45:00
有 std::byte 可以用

Links booklink

Contact Us: admin [ a t ] ucptt.com