简单的测试*p++的结果

 

#include "stdio.h"

static void PrintLine(void)
{
    int loop_a = 30;
   
    printf("/n");
    while (loop_a--)
    {
        printf("-"); 
    }
}

static void PrintStrAndLine(char *str, int type)
{
    if (type == 1)
    {
        while (*str)
        {
            printf("/n/t*p++ = %c", *str++); 
        }
    }
    else if (type == 2)
    {
        while (*str)
        {
            printf("/n/t*(p++) = %c", *(str++)); 
        }
    }
    else if (type == 3)
    {
        while (*str)
        {
            printf("/n/t(*p)++ = %s", (*str)++); 
        }
    }
    else
    {
        printf("/n/tno data");
    }
    PrintLine();
}

int main(void)
{
    char *p = "hello";
    char *q = p;
    int i;
    
    printf("/n/t*p = %s/n", p);
    for (i = 1; i <= 5; i++)
    {
        PrintStrAndLine(p, i);
        p = q;
    }
}

此code在mingw2.05上输出,最后一项输出为错误值

 

        *p = hello

        *p++ = h
        *p++ = e
        *p++ = l
        *p++ = l
        *p++ = o
------------------------------
        *(p++) = h
        *(p++) = e
        *(p++) = l
        *(p++) = l
        *(p++) = o
------------------------------

Terminated with return code -1073741819
Press any key to continue ...

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
用C++,创建MFC,用prewitt算子锐化,仿照下面代码void CMyImageView::OnSobelsuanzi() { // TODO: 在此添加命令处理程序代码 CMyImageDoc* pDoc = GetDocument();//获取文档指针 ASSERT_VALID(pDoc); Prewittsuanzi dlginputyuzhi;//定义阈值对话框类对象 dlginputyuzhi.DoModal();//弹出对话框 UpdateData(TRUE); if (pDoc->m_pDib == NULL) { AfxMessageBox("Error!"); return; } int mcols = pDoc->m_pDib->m_nCols; int mrows = pDoc->m_pDib->m_nRows; unsigned char* m_pData = NULL; m_pData = pDoc->m_pDib->pImgData; unsigned char* m_pDataOldPos = m_pData; unsigned char* a; int* b = NULL; int irows, jcols; int max = 0; int min = 255; vector<int>v; for (irows = 0; irows < mrows; irows++) { for (jcols = 0; jcols < mcols; jcols++) { int j = 0; int p = 0, q = 0; m_pData += irows * mcols + jcols; j += irows * mcols + jcols; if (j > mcols && (j + 1) % mcols != 0 && j < (mrows * (mcols - 1))) { p = (m_pData + mcols+1) + 2( * (m_pData + mcols )) + (m_pData + mcols - 1) - 2( * (m_pData - mcols)) - (m_pData - mcols - 1) - (m_pData - mcols + 1); q = 2( * (m_pData + 1)) + (m_pData + mcols + 1) + (m_pData - mcols + 1) - 2( * (m_pData - 1)) - (m_pData + mcols - 1) - (m_pData - mcols - 1); p = abs(p); q = abs(q); if (p > dlginputyuzhi.xyuzhi && q > dlginputyuzhi.yyuzhi) { v.push_back(0); } else { v.push_back(255); } } m_pData = m_pDataOldPos; } } int aq = 0; for (irows = 0; irows < mrows; irows++) { for (jcols = 0; jcols < mcols; jcols++) { int j = 0; int p = 0, q = 0; m_pData += irows * mcols + jcols; j += irows * mcols + jcols; if (j > mcols && (j + 1) % mcols != 0 && j < (mrows * (mcols - 1))) { m_pData = v[aq]; aq++; } m_pData = m_pDataOldPos; } } pDoc->UpdateAllViews(NULL); },生成梯度图像
最新发布
05-30

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值