`
djking
  • 浏览: 8924 次
  • 性别: Icon_minigender_1
  • 来自: 广州
最近访客 更多访客>>
社区版块
存档分类
最新评论

c# 指向交叉数组的指针

阅读更多
C#的指针只能指向一个一维数组,有时候我们需要指向一个二维数组,这篇BLOG就是讲解这个问题的。

上代码:
public static void Main(string[] args)
        {
            Stopwatch ss = new Stopwatch();
            ss.Start();
            //定义一个指针数组
            double*[] p = new double*[8];
            IntPtr[] c = new IntPtr[8];

            //定义一个指向p指针数组的指针
            fixed (double** pg = p)
            {
                //这里等同于我们用交叉数组的:
                //Int[][] a = New Int[8][10];
                for (int i = 0; i < p.Length; i++)
                {
                    //分配内存空间,并使用p指针数组里面的每个指针指向每一个分配的内存空间。
                    c[i] = Marshal.AllocHGlobal(sizeof(double) * 10);
                    *(pg + i) = (double*)c[i];
                }

                //指针赋值
                //这里等同于我们用交叉数组的赋值
                //Int[][] a = New Int[8][10];
                //a[i][j]=i*j;
                for (int i = 1; i <= p.Length; i++)
                    for (int j = 1; j <= 10; j++)
                        *((*(pg + (i - 1))) + (j - 1)) = i * j;

                //输出指针
                //这里等同于输出交叉数组
                //Console.Write(a[i][j])
                for (int i = 0; i < p.Length; i++)
                {
                    for (int j = 0; j < 10; j++)
                    {
                        Console.Write(*((*(pg + i)) + j) + " ");
                        if (j == 10 - 1)
                            Console.WriteLine();
                    }
                }

                //回收分配的内存空间
                for (int i = 0; i < p.Length; i++)
                    Marshal.FreeHGlobal(c[i]);
            }

            ss.Stop();
            Console.WriteLine(ss.Elapsed.TotalMilliseconds);


这样,一个指向交叉数组的指针就完成了。
主要是分3步:
1、创建一个指针数组
2、指针数组的每一个指针指向一个一维的数组
3、创建一个指向该指针数组的指针
这就完成了。

不明白的可以看下列代码:
private static double[][] a2 = new double[][]
        {
            new double[]{ 0,1 },
            new double[]{ 2,3 },
            new double[]{ 4,5 },
            new double[]{ 6,7 },
            new double[]{ 8,9 },
            new double[]{ 10,11 },
            new double[]{ 12,13 },
            new double[]{ 14,15 }
        };

public static void Main(string[] args)
        {
            double*[] p = new double*[8];
            fixed (double** pg = p)
            {
                for (int i = 0; i < a2.Length; i++)
                {
                    fixed (double* ap1 = a2[i])
                        *(pg+i) = ap1;
                }

                Console.WriteLine(*((*(pg+1)) + 1));
            }
        }


再不明白的可以加Q:87648714
分享到:
评论

相关推荐

    [免费]经典排序算法实例 C#源码

    在C#中实现交叉排序,需要两个指针分别指向数组的开头和结尾,同时还有一个中间指针用于分隔小于、等于和大于目标值的元素。 这些排序算法各有优缺点:冒泡排序简单直观,但效率较低;选择排序的时间复杂度较优,但...

    C#微软培训资料

    第一部分 C#语言概述.4 第一章 第一章第一章 第一章 .NET 编 编 编程语言 程语言编程语言 程语言 C#.4 1.1 Microsoft.NET——一场新的革命.4 1.2 .NET 与 C#.6 1.3 C#语言的特点.8 1.4 小 结 .11...

    SearchRotatedArray:C#.net核心示例如何使用修改后的二进制搜索算法在旋转数组中搜索数字

    2. **找到旋转点**:使用两个指针,一个从数组开头向后移动,另一个从数组结尾向前移动,直到两个指针相遇或交叉。相遇点可能是旋转点,也可能是原数组的一部分。 3. **分情况讨论**:根据旋转点,将数组分为两部分...

    二进制搜索:C#中的二进制搜索

    初始化两个指针,一个指向数组的起始位置,另一个指向数组的末尾。 2. 计算中间索引,并与目标值进行比较。 3. 如果中间值等于目标值,搜索结束,返回中间索引。 4. 如果中间值小于目标值,舍弃左半部分,更新左...

    有关的几个小算法程序

    这个过程通过两个指针I和J实现,I指向数组开始,J指向数组末尾。 3. **前后搜索**:从J开始向前搜索,找到第一个小于关键数据的元素,然后从I开始向后搜索,找到第一个大于关键数据的元素。将这两个元素交换位置。 4...

    算法大全-面试题-数据结构

    单链表是一种线性数据结构,每个节点包含数据和指向下一个节点的引用(指针)。在C#中,可以定义一个简单的单链表节点类`Link`,如文件中所示: ```csharp public class Link { public Link Next; public string ...

    2021-2022计算机二级等级考试试题及答案No.9456.docx

    21. **指针数组声明**:`int (*p)[3]`声明了一个指针变量p,它指向一个有三个整数元素的一维数组,答案C正确。 22. **数组数据类型**:数组的所有元素必须具有相同的类型,答案A正确。 23. **日期条件**:在SQL...

    2021-2022计算机二级等级考试试题及答案No.11933.docx

    - 当使用replace命令时,如果范围短语为ALL或REST,则执行该命令后记录指针将指向末记录的后面。 - 正确答案为**C**:`末记录的后面`。 ### 12. VBA程序流程控制 - VBA支持三种基本的流程控制结构:顺序控制、分支...

Global site tag (gtag.js) - Google Analytics