指針與數組

来源:http://www.cnblogs.com/letben/archive/2016/02/24/5215295.html
-Advertisement-
Play Games

前面的東西都比較基礎,後面的這個才是真正關鍵的地方。 示例代碼: #include <iostream> #include <stdlib.h> int main(int argc, char *argv[]) { //argc 指的是參數個數 // argv[0]指的是程式的名字 // argv[


前面的東西都比較基礎,後面的這個才是真正關鍵的地方。

示例代碼:

#include <iostream>
#include <stdlib.h> 


int main(int argc, char *argv[]) {
    //argc 指的是參數個數
    // argv[0]指的是程式的名字
    // argv[1]值的是程式執行的第一個參數
    
    int array[10]={1023,2,3,4,5,6};
    int *p = &array[0];
    int *p1 = array;
    
    printf("%p,%p\n",array,&array[0]);
    //十六位的地址 
    //兩個地址的值,並且兩個地址相同。 
    
    printf("*p = %d\n",*p);
    //1 
    printf("*p1 = %d\n",*p1);
    //1
    printf("sizeof(array) = %d,sizeof(p1) = %d\n",sizeof(array),sizeof(p1));
    //40,8
    printf("%d,%d\n",sizeof(int *),sizeof(char *));
    //8,8
    printf("array =%p,*array =%p,&array = %p\n",array,*array,&array);
    //地址的值,跟上面的結果一樣的,15個0後面1,(如果是32位的操作系統的話,應該是7個0後面一個1),地址的值,跟最上面一樣 
    
    //這個結果是什麼呢? 
    printf("%d\n",*((char *)p1+1));
    //這個地方很奇怪,總是覺得有問題。 
    //但是好像就是 0啊。 
    return 0;
}

運行結果:

這個地方多少有點兒出入,就是為了把那個 結果試出來。所以能看得出來,開始數組裡面第一個數字給的是1.

來看看為什麼最後一行的結果是3.前面的不知道為什麼的同學可以看看這個地址裡面書寫的內容:

http://www.cnblogs.com/letben/p/5213967.html

 

void function2(void){
    //上面的如果看懂了的話,下麵的都比較簡單了 
    char buf[10] = {"abcdef"};
    char *pc = buf;
    printf("%c\n",*(pc+3));
    int i = 0x12345678;
     
    char *cpi = (char *) &i;
    printf("%x,%x,%x,%x\n",*(cpi+0),*(cpi+1),*(cpi+2),*(cpi+3));
    
}

運行結果:

這個表現出操作系統相關性,如果是一般的windows,或者linux都是這種先輸出小端的,如果是伺服器型的unix的話,就會出現12,34,56,78的結果。

 

利用指針進行賦值:

代碼:

/**
    利用指針進行賦值。 
*/
void function3(void){
    int array[10]={0};
    int *p = array;
    for(int i = 0;i<10;i++){
        scanf("%d",p++);
    } 
    for(int i= 0;i<10;i++){
        printf("%d\n",array[i]);
    }    
}

運行結果:

/**
    指針數組 與數組指針 
*/
void function4(void){
    char *s[10];//指針數組 
    char (*s1)[10];//數組指針
    //第一個表達的意思是,有一個數組,裡面有10個元素,每個元素都是一個指向 字元數組 類型 的 指針變數。
    //所以可以有 
    char c1[2]; 
    char c2[3];
    char c3[4];
    s[1] = c1;
    s[2] = c2;
    s[3] = c3;
    //第二個是數組指針,是一個指向有10個字元大小的字元數組的指針變數。
    char cc[2][10];
    //[Error] cannot convert 'char [2][5]' to 'char (*)[10]' in assignment
    s1 = cc;
    s1 = &cc[1];
    //這些東西 明天好好在理解一下 
    int i;
    int * p;
    p = &i;
    //同理:
    char mychars[10];
    s1 = &mychars;
}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在Java中,如果類的一個構造方法想要調用另一個構造方法,需要用this(參數列表)的形式來調用。 public class Student { String name; int age; public Student(int age) { this("Jack",age); } public St
  • Github連接 : 一、題目 題目描述連接: 二、準備過程 1. 把c++遠征計劃中的離港篇和封裝篇上看完了。( 學習計劃並沒有完成T_T ) 2. 發現題目中要求用到queue的知識,就去度娘了有關隊列的使用,大概知道該怎麼用吧。 3. 本來在電腦里下了c++ primer plus看一部分,發
  • 安裝JDK JDK的官網網址如下: http://www.oracle.com/technetwork/java/javase/downloads/index-jsp-138363.html 配置JDK環境變數參數設置 (1)JAVA_HOME: D:\Program Files (x86)\Jav
  • 眾所周知,json_encode通常會把json中的漢字轉義成unicode,但是這並不一定是我們想要的。有時候,我們需要獲得漢字形式的json字元串,比如需要獲得gbk編碼的json字元串(只要把漢字形式的字元串轉碼就可以得到了)。有什麼好辦法麽? php官方聽到了這個需求,並提供了一種可靠的解決
  • 簡介 一個同步輔助類,在完成一組正在其他線程中執行的操作之前,它允許一個或多個線程一直等待。用給定的計數 初始化 CountDownLatch。由於調用了 countDown() 方法,所以在當前計數到達零之前,await 方法會一直受阻塞。之後,會釋放所有等待的線程,await 的所有後續調用都將
  • IOC:即控制反轉,主要意思就是Spring容器來管理對象的初始化,而不需要程式員人工的使用new方式來創建對象,並且當A對象依賴於B對象時,在配置文件中可以指定,同樣不需要程式員在構造函數或是setter中進行對象註入。 AOP:面向切麵編程。其實就是一種新的不同於繼承的代碼重用技術。繼承是將共性
  • 介紹 一個同步輔助類,它允許一組線程互相等待,直到到達某個公共屏障點 (common barrier point)。在涉及一組固定大小的線程的程式中,這些線程必須不時地互相等待,此時 CyclicBarrier 很有用。因為該 barrier 在釋放等待線程後可以重用,所以稱它為迴圈 的 barri
  • package demo1; public class Demo { public static void main(String[] args) { int a=4; for(int i=1;i<=a;i++) { for(int k=1;k<=a-i;k++) { System.out.prin
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...