- cuda编程python接口_使用Python写CUDA程序的方法
weixin_39822184
cuda编程python接口
使用Python写CUDA程序有两种方式:*Numba*PyCUDAnumbapro现在已经不推荐使用了,功能被拆分并分别被集成到accelerate和Numba了。例子numbaNumba通过及时编译机制(JIT)优化Python代码,Numba可以针对本机的硬件环境进行优化,同时支持CPU和GPU的优化,并且可以和Numpy集成,使Python代码可以在GPU上运行,只需在函数上方加上相关的指
- pytorch的学习笔记
wyn20001128
算法
一cuda 2006年,NVIDIA公司发布了CUDA(ComputeUnifiedDeviceArchitecture),是一种新的操作GPU计算的硬件和软件架构,是建立在NVIDIA的GPUs上的一个通用并行计算平台和编程模型,它提供了GPU编程的简易接口,基于CUDA编程可以构建基于GPU计算的应用程序。 CPU是用于负责逻辑性比较强的计算,GPU专注于执行高度线程化的并行处理任务。所以
- CIANNA由天体物理学家提供/为天体物理学家提供的卷积交互式人工神经网络
struggle2025
神经网络
一、软件介绍文末提供程序和源码下载CIANNA是一个通用的深度学习框架,主要用于天文数据分析。根据天体物理问题解决的相关性添加功能和优化。CIANNA可用于为各种任务构建和训练大型神经网络模型,并提供高级Python接口(类似于keras、pytorch等)。CIANNA的特点之一是它定制实施了受YOLO启发的对象探测器,用于2D或3D射电天文数据产品中的星系探测。该框架通过低级CUDA编程完全实
- CUDA编程:优化GPU并行处理与内存管理
Omoo
CUDAGPU并行处理线程协作内存管理硬件限制
背景简介CUDA是NVIDIA推出的一种通用并行计算架构,它利用GPU的强大计算能力来解决复杂的计算问题。在本书的第12章中,我们深入探讨了CUDA编程的关键概念,包括线程间的协作、内存分配与管理以及如何应对硬件限制。CUDA中的线程协作与内存管理在GPU上进行编程时,我们需要处理内存分配、数据传输以及内核(kernel)的调用等任务。CUDA提供了一系列的API来帮助开发者管理这些资源。在提供的
- 【CUDA编程】Dim3
量化投资和人工智能
CUDA昇腾CUDA人工智能深度学习c++云计算
dim3是CUDA编程中用于定义线程块(Block)和网格(Grid)维度的三维向量结构体,本质是包含三个无符号整数成员(x、y、z)的轻量级容器。以下是其核心特性与用法详解:一、核心定义与结构structdim3{unsignedintx;//第一维度(宽度)unsignedinty;//第二维度(高度)unsignedintz;//第三维度(深度)};默认值规则:未显式赋值的维度默认为1。示例
- 【CUDA编程】OptionalCUDAGuard详解
量化投资和人工智能
CUDA大模型人工智能机器学习CUDA云计算pythonc++
OptionalCUDAGuard是PyTorch的CUDA工具库(c10/cuda)中用于安全管理GPU设备上下文的RAII(ResourceAcquisitionIsInitialization)类。其核心作用是在特定代码块中临时切换GPU设备,并在退出作用域时自动恢复原设备状态,尤其适用于设备可能为“未指定”(nullopt)的场景。以下从作用、原理、用法和典型场景详细解析:⚙️一、核心作用
- 【CUDA编程】 C10_CUDA_CHECK 宏详细解析
量化投资和人工智能
CUDACUDA人工智能云计算大模型
以下是对C10_CUDA_CHECK宏的详细解析,结合CUDA错误处理机制和PyTorch框架设计进行说明:一、宏定义结构解析#defineC10_CUDA_CHECK(EXPR)\do{\constcudaError_t__err=EXPR;\c10::cuda::c10_cuda_check_implementation(\static_cast(__err),\__FILE__,\__fun
- 第四篇:Python 高级-高性能计算加速秘籍
程序员勇哥
Python全套教程python开发语言
第四篇:Python高级-高性能计算加速秘籍在当今数据量与计算需求日益增长的环境下,提升Python程序的计算性能显得尤为关键。本篇将深入探讨向量化计算的深度优化以及如何借助CUDA编程与GPU加速来显著提升Python计算效率。一、向量化计算的深度优化(一)利用Numba实现复杂算法的高效向量化Numba简介Numba是一个用于Python的即时编译器(JIT),它能够将Python函数转换为机
- Python中使用CUDA/GPU的方式比较
东北豆子哥
CUDAHPC/MPIpythonCUDA
Python中使用CUDA/GPU的方式比较在Python中利用GPU加速计算有多种方式,以下是主要的几种方法及其比较:1.CUDA原生开发方式:使用NVIDIA提供的CUDAC/C++API开发内核通过PyCUDA或Numba等工具在Python中调用特点:最底层,性能最优开发复杂度高需要熟悉CUDA编程模型示例库:PyCUDANumbaCUDA2.通用GPU计算框架2.1CUDA加速库方式:使
- flash attention的CUDA编程流水并行加速-V6
谨慎付费(看不懂试读博客不要订阅)
高性能计算redis数据库缓存
之前关于flashattention的介绍可以继续参考链接添加链接描述矩阵乘法的优化参考添加链接描述,我们发现矩阵乘法的最优配置为:BLOCK_DIM_x=BLOCK_DIM_y=16,同时每个线程处理一个8×8的子矩阵。线程网格设置如下所示:constintRq=8;constintRv
- 被 CUDA 性能问题困扰?从全局内存到共享内存,并行归约优化全解析!
讳疾忌医丶
动手学习CUDA编程c++CUDA开发语言
你是不是也觉得GPU编程听起来很酷,但一上手就头大?别慌,今天我带你玩转CUDA里一个既基础又硬核的东西——并行归约。啥是归约?简单说,就是把一堆数加起来(或者其他累积操作),但在GPU上,这可不是简单的for循环,而是能让性能起飞的优化手法。作为一个写了好几年CUDA的老司机,我有个独家观点:并行归约是CUDA编程的灵魂,搞懂它,你就摸到了GPU优化的门道。这篇文章不整虚的,我会用大白话带你从最
- 《GPU高性能编程CUDA实战》中文版电子书
翁佳忱
《GPU高性能编程CUDA实战》中文版电子书【下载地址】GPU高性能编程CUDA实战中文版电子书探索GPU高性能编程的奥秘,掌握CUDA实战技巧!本资源提供了《GPU高性能编程CUDA实战》中文电子书,深入解析GPU编程基础与CUDA架构,助您从理论到实践全面提升。无论您是编程新手还是资深开发者,本书都能为您提供清晰的指导与丰富的实战案例。立即下载,开启您的CUDA编程之旅,解锁GPU计算的无限潜
- Cuda Instruction Replay
ZhiqianXia
CUDA技术笔记cuda
在CUDA编程中,指令重放(InstructionReplay)是GPU执行指令时因特定原因导致指令需重复发射或重新执行的现象,通常会影响性能。以下是其关键点:指令重放的原因分支分歧(DivergentBranches)当同一线程束(Warp)中的线程执行不同分支(如if-else)时,GPU需串行化处理每个分支路径。同一指令可能被多次发射(重放),导致执行时间增加。内存访问延迟全局内存访问未命中
- CUDA编程高阶优化:如何突破GPU内存带宽瓶颈的6种实战策略
学术猿之吻
GPU高校人工智能边缘计算人工智能transformer深度学习gpu算力aiAI编程
在GPU计算领域,内存带宽瓶颈是制约性能提升的"隐形杀手"。本文面向具备CUDA基础的研究者,从寄存器、共享内存到TensorCore,系统剖析6项突破性优化策略,助你充分释放GPU算力。一、全局内存访问优化:对齐与合并原则1.1合并访问的本质GPU全局内存以线程束(Warp)为单位执行合并事务。当32个线程访问连续且对齐的128字节内存块时,总线利用率可达100%。以下代码演示如何实现合并
- CUDA编程优化:如何实现矩阵计算的100倍加速
学术猿之吻
GPU高校人工智能矩阵人工智能线性代数深度学习量子计算算法gpu算力
一、突破性能瓶颈的核心路径矩阵计算的百倍加速需要打通"内存带宽→计算密度→指令吞吐"三重关卡。根据NVIDIAAmpere架构白皮书,A100GPU的理论计算峰值(FP32)为19.5TFLOPS,但原生CUDA代码往往只能达到5-8%的理论值。通过系统化优化策略,我们成功将1024×1024矩阵乘法从初始的212ms优化至2.1ms,实现101倍加速(测试平台:NVIDIARTX3090)。二、
- C++开发者的逆袭之路:大部份的高薪岗位都在招 CUDA 人才,你还不行动?
讳疾忌医丶
动手学习CUDA编程c++开发语言
为什么你必须学会CUDA编程?想象一下,你手头有个计算任务,普通CPU跑得慢得像乌龟爬,而GPU却能像火箭一样把性能拉满——这就是高性能计算(HPC)的魅力!在这个数据爆炸的时代,无论是AI训练、科学仿真还是金融建模,HPC都成了不可或缺的利器。而NVIDIA的CUDA平台,正是这场革命的核心,把GPU从画图的“小能手”变成了并行计算的“大杀器”。作为一名C++专家,我可以负责任地说:学会CUDA
- CUDA 编程相关的开源库
byxdaz
CUDAcuda
CUDA编程相关的开源库非常丰富,涵盖了高性能计算、深度学习、图像处理、线性代数、优化算法等多个领域。1.通用GPU计算库CUDAToolkit(NVIDIA官方):包含CUDA运行时库、编译器(nvcc)、调试工具(cuda-gdb、Nsight)、数学库(如cuBLAS、cuFFT)等。CUDAToolkit-FreeToolsandTraining|NVIDIADeveloperThrust
- GPU编程实战指南04:CUDA编程示例,使用共享内存优化性能
anda0109
CUDA并行编程gpu算力AI编程ai
在CUDA编程中,共享内存(SharedMemory)比全局内存(GlobalMemory)效率高的原因主要与CUDA的硬件架构和内存访问特性密切相关。以下是详细分析:1.CUDA内存层次结构CUDA设备(GPU)具有多层次的内存架构,主要包括以下几种:寄存器(Registers):每个线程私有的高速存储单元,速度最快但容量有限。共享内存(SharedMemory):由同一个线程块(Block)中
- gather算子的CUDA编程和算子测试
谨慎付费(看不懂试读博客不要订阅)
高性能计算CUDA
知乎介绍参考添加链接描述完整测试框架参考本人仓库添加链接描述gather算子的onnx定义参考添加链接描述,该算子的主要变换参考下图:这里我们不妨以input=[A,dimsize,D],indices=[B,C],axis=1举例子,此时对应的output形状是[A,B,C,D],并且根据gather算子定义,我们知道output[i,j,k,s]=input[i,indices[j,k],s]
- Python调用CUDA
源代码分析
python开发语言
CUDA常用语法和函数CUDA(ComputeUnifiedDeviceArchitecture)是NVIDIA提供的一个并行计算平台和编程模型,允许开发者使用NVIDIAGPU进行高性能计算。以下是一些CUDA编程中的常用语法和函数:核函数(KernelFunctions):使用__global__修饰符定义,这种函数可以从主机(CPU)调用并在设备(GPU)上并行执行。调用格式:kernel>
- NVIDIA GTC 开发者社区Watch Party资料汇总
扫地的小何尚
NVIDIAGPUlinuxAI算法
NVIDIAGTC开发者社区WatchParty资料汇总以下是所有涉及到的工具中文解读汇总,希望可以帮到各位:1.CUDA编程模型开发者指南和最新功能解析专栏2.NVIDIAWarp:高性能GPU模拟与图形计算的Python框架3.NVIDIAcuDF:GPU加速的数据处理库详解4.NVIDIAcuML:GPU加速的机器学习库详解5.NVIDIAcuFFT详解:从入门到高级应用6.NVIDIAcu
- GPU计算的历史与CUDA编程入门
己见明
GPU计算CUDAC数据并行性CUDA程序结构向量加法内核
GPU计算的历史与CUDA编程入门背景简介GPU计算的历史可以追溯到早期的并行计算研究,如今已发展成为计算机科学中的一个重要分支。本文将探讨GPU计算的发展史,重点分析《ComputerGraphics:PrinciplesandPractice》等关键文献,以及CUDAC编程模型的引入及其对现代软件开发的影响。历史回顾回顾历史,GPU计算的发展始于1986年Hillis与Steele在《Comm
- CUDA编程基础
清 澜
算法面试人工智能c++算法nvidiacuda编程
一、快速理解CUDA编程1.1CUDA简介CUDA(ComputeUnifiedDeviceArchitecture)是由NVIDIA推出的并行计算平台和应用程序接口模型。它允许开发者利用NVIDIAGPU的强大计算能力来加速通用计算任务,而不仅仅是图形渲染。通过CUDA,开发者可以编写C、C++或Fortran代码,并将其扩展以在GPU上运行,从而显著提高性能,特别是在处理大规模数据集和复杂算法
- c++高性能多进程 cuda编程: safe_softmax实现 + cub::BlockReduce自定义归约操作
FakeOccupational
深度学习c++开发语言
目录cub::BlockReduce自定义归约操作(`cub::BlockReduce::Reduce`)1.语法safe_softmax实现cub::BlockReducecub::BlockReduce是CUB库(CUDAUnBound)提供的一种用于GPU线程块内数据归约(一般完成所有数据规约需要两次规约)的高效工具。它允许线程块内的多个线程并行地对数据执行归约操作,cub::BlockRe
- 英伟达的ptx是什么?ptx在接近汇编语言的层级运行?
AI-AIGC-7744423
人工智能
PTX(ParallelThreadeXecution)是英伟达CUDA架构中的一种中间表示形式(IR)语言。以下是关于它的介绍以及它与汇编语言层级关系的说明:PTX介绍•性质与作用:PTX是一种类似于汇编语言的指令集架构,但它更像是一种抽象的、面向并行计算的中间语言。它是CUDA编程模型中,主机代码与实际在GPU上执行的机器码之间的桥梁。开发者编写的CUDAC/C++等高级语言代码,在编译过程中
- CUDA编程之OpenCV与CUDA结合使用
byxdaz
CUDAopencv人工智能计算机视觉
OpenCV与CUDA的结合使用可显著提升图像处理性能。一、版本匹配与环境配置CUDA与OpenCV版本兼容性OpenCV各版本对CUDA的支持存在差异,例如OpenCV4.5.4需搭配CUDA10.02,而较新的OpenCV4.8.0需使用更高版本CUDA。需注意部分模块(如级联检测器)可能因CUDA版本更新而不再支持。OpenCV版本CUDA版本4.5.x推荐CUDA11.x及以下
- GPU编程实战指南01:CUDA编程极简手册
anda0109
CUDA并行编程算法
目录1.CUDA基础概念1.1线程层次结构1.2内存层次结构2.CUDA编程核心要素2.1核函数2.2内存管理2.3同步机制3.CUDA优化技巧3.1内存访问优化3.2共享内存使用3.3线程分配优化4.常见问题和解决方案5.实际案例分析1.CUDA基础概念1.1线程层次结构CUDA采用层次化的线程组织结构,从小到大依次为:线程(Thread):最基本的执行单元每个线程执行相同的核函数代码通过thr
- 高性能计算中如何优化内存管理?
gpu
在高性能计算(HPC)中,优化内存管理是提升计算性能的关键环节之一。以下是一些常见的优化策略和方法:内存分配与管理策略内存池技术:通过预分配一定大小的内存池,避免频繁的内存分配和释放操作,减少内存碎片化。例如,在CUDA编程中,可以使用内存池来管理GPU内存,从而提高内存访问效率。异构内存管理:在异构计算环境中(如CPU+GPU),采用统一内存管理(UnifiedMemory)或智能数据迁移策略,
- cuda编程入门——并行归约(五)
我不会打代码啊啊
cuda编程算法c++gpu算力
CUDA编程入门—并行归约(数组求和为例)在并行计算中,归约(Reduction)是一种将多个数据通过特定操作(如求和、求最大值等)合并为单一结果的并行算法。其核心目标是通过并行化加速大规模数据集的聚合计算。关键概念操作类型:可结合且可交换的操作(如加法、乘法、最大值、最小值、逻辑与/或等)适合并行归约。若操作不可结合(如减法或除法),需特殊处理或无法直接并行化。并行实现方式:树形结构归约:将数据
- cuda编程入门——并行性与异构性概念
我不会打代码啊啊
cuda编程gpu算力c++
CUDA编程入门一基于cuda的异构并行计算并行性一、并行性的概念与分类概念并行性旨在通过同时处理多个任务或数据元素来提高计算速度和效率。它可以在不同的层次上实现,包括指令级并行、数据级并行和任务级并行等。分类指令级并行(Instruction-LevelParallelism,ILP):在处理器的指令执行层面,通过硬件技术(如流水线、超标量技术等)让多条指令在不同阶段同时执行,从而提高处理器的指
- 对于规范和实现,你会混淆吗?
yangshangchuan
HotSpot
昨晚和朋友聊天,喝了点咖啡,由于我经常喝茶,很长时间没喝咖啡了,所以失眠了,于是起床读JVM规范,读完后在朋友圈发了一条信息:
JVM Run-Time Data Areas:The Java Virtual Machine defines various run-time data areas that are used during execution of a program. So
- android 网络
百合不是茶
网络
android的网络编程和java的一样没什么好分析的都是一些死的照着写就可以了,所以记录下来 方便查找 , 服务器使用的是TomCat
服务器代码; servlet的使用需要在xml中注册
package servlet;
import java.io.IOException;
import java.util.Arr
- [读书笔记]读法拉第传
comsci
读书笔记
1831年的时候,一年可以赚到1000英镑的人..应该很少的...
要成为一个科学家,没有足够的资金支持,很多实验都无法完成
但是当钱赚够了以后....就不能够一直在商业和市场中徘徊......
- 随机数的产生
沐刃青蛟
随机数
c++中阐述随机数的方法有两种:
一是产生假随机数(不管操作多少次,所产生的数都不会改变)
这类随机数是使用了默认的种子值产生的,所以每次都是一样的。
//默认种子
for (int i = 0; i < 5; i++)
{
cout<<
- PHP检测函数所在的文件名
IT独行者
PHP函数
很简单的功能,用到PHP中的反射机制,具体使用的是ReflectionFunction类,可以获取指定函数所在PHP脚本中的具体位置。 创建引用脚本。
代码:
[php]
view plain
copy
// Filename: functions.php
<?php&nbs
- 银行各系统功能简介
文强chu
金融
银行各系统功能简介 业务系统 核心业务系统 业务功能包括:总账管理、卡系统管理、客户信息管理、额度控管、存款、贷款、资金业务、国际结算、支付结算、对外接口等 清分清算系统 以清算日期为准,将账务类交易、非账务类交易的手续费、代理费、网络服务费等相关费用,按费用类型计算应收、应付金额,经过清算人员确认后上送核心系统完成结算的过程 国际结算系
- Python学习1(pip django 安装以及第一个project)
小桔子
pythondjangopip
最近开始学习python,要安装个pip的工具。听说这个工具很强大,安装了它,在安装第三方工具的话so easy!然后也下载了,按照别人给的教程开始安装,奶奶的怎么也安装不上!
第一步:官方下载pip-1.5.6.tar.gz, https://pypi.python.org/pypi/pip easy!
第二部:解压这个压缩文件,会看到一个setup.p
- php 数组
aichenglong
PHP排序数组循环多维数组
1 php中的创建数组
$product = array('tires','oil','spark');//array()实际上是语言结构而不 是函数
2 如果需要创建一个升序的排列的数字保存在一个数组中,可以使用range()函数来自动创建数组
$numbers=range(1,10)//1 2 3 4 5 6 7 8 9 10
$numbers=range(1,10,
- 安装python2.7
AILIKES
python
安装python2.7
1、下载可从 http://www.python.org/进行下载#wget https://www.python.org/ftp/python/2.7.10/Python-2.7.10.tgz
2、复制解压
#mkdir -p /opt/usr/python
#cp /opt/soft/Python-2
- java异常的处理探讨
百合不是茶
JAVA异常
//java异常
/*
1,了解java 中的异常处理机制,有三种操作
a,声明异常
b,抛出异常
c,捕获异常
2,学会使用try-catch-finally来处理异常
3,学会如何声明异常和抛出异常
4,学会创建自己的异常
*/
//2,学会使用try-catch-finally来处理异常
- getElementsByName实例
bijian1013
element
实例1:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/x
- 探索JUnit4扩展:Runner
bijian1013
java单元测试JUnit
参加敏捷培训时,教练提到Junit4的Runner和Rule,于是特上网查一下,发现很多都讲的太理论,或者是举的例子实在是太牵强。多搜索了几下,搜索到两篇我觉得写的非常好的文章。
文章地址:http://www.blogjava.net/jiangshachina/archive/20
- [MongoDB学习笔记二]MongoDB副本集
bit1129
mongodb
1. 副本集的特性
1)一台主服务器(Primary),多台从服务器(Secondary)
2)Primary挂了之后,从服务器自动完成从它们之中选举一台服务器作为主服务器,继续工作,这就解决了单点故障,因此,在这种情况下,MongoDB集群能够继续工作
3)挂了的主服务器恢复到集群中只能以Secondary服务器的角色加入进来
2
- 【Spark八十一】Hive in the spark assembly
bit1129
assembly
Spark SQL supports most commonly used features of HiveQL. However, different HiveQL statements are executed in different manners:
1. DDL statements (e.g. CREATE TABLE, DROP TABLE, etc.)
- Nginx问题定位之监控进程异常退出
ronin47
nginx在运行过程中是否稳定,是否有异常退出过?这里总结几项平时会用到的小技巧。
1. 在error.log中查看是否有signal项,如果有,看看signal是多少。
比如,这是一个异常退出的情况:
$grep signal error.log
2012/12/24 16:39:56 [alert] 13661#0: worker process 13666 exited on s
- No grammar constraints (DTD or XML schema).....两种解决方法
byalias
xml
方法一:常用方法 关闭XML验证
工具栏:windows => preferences => xml => xml files => validation => Indicate when no grammar is specified:选择Ignore即可。
方法二:(个人推荐)
添加 内容如下
<?xml version=
- Netty源码学习-DefaultChannelPipeline
bylijinnan
netty
package com.ljn.channel;
/**
* ChannelPipeline采用的是Intercepting Filter 模式
* 但由于用到两个双向链表和内部类,这个模式看起来不是那么明显,需要仔细查看调用过程才发现
*
* 下面对ChannelPipeline作一个模拟,只模拟关键代码:
*/
public class Pipeline {
- MYSQL数据库常用备份及恢复语句
chicony
mysql
备份MySQL数据库的命令,可以加选不同的参数选项来实现不同格式的要求。
mysqldump -h主机 -u用户名 -p密码 数据库名 > 文件
备份MySQL数据库为带删除表的格式,能够让该备份覆盖已有数据库而不需要手动删除原有数据库。
mysqldump -–add-drop-table -uusername -ppassword databasename > ba
- 小白谈谈云计算--基于Google三大论文
CrazyMizzz
Google云计算GFS
之前在没有接触到云计算之前,只是对云计算有一点点模糊的概念,觉得这是一个很高大上的东西,似乎离我们大一的还很远。后来有机会上了一节云计算的普及课程吧,并且在之前的一周里拜读了谷歌三大论文。不敢说理解,至少囫囵吞枣啃下了一大堆看不明白的理论。现在就简单聊聊我对于云计算的了解。
我先说说GFS
&n
- hadoop 平衡空间设置方法
daizj
hadoopbalancer
在hdfs-site.xml中增加设置balance的带宽,默认只有1M:
<property>
<name>dfs.balance.bandwidthPerSec</name>
<value>10485760</value>
<description&g
- Eclipse程序员要掌握的常用快捷键
dcj3sjt126com
编程
判断一个人的编程水平,就看他用键盘多,还是鼠标多。用键盘一是为了输入代码(当然了,也包括注释),再有就是熟练使用快捷键。 曾有人在豆瓣评
《卓有成效的程序员》:“人有多大懒,才有多大闲”。之前我整理了一个
程序员图书列表,目的也就是通过读书,让程序员变懒。 程序员作为特殊的群体,有的人可以这么懒,懒到事情都交给机器去做,而有的人又可以那么勤奋,每天都孜孜不倦得
- Android学习之路
dcj3sjt126com
Android学习
转自:http://blog.csdn.net/ryantang03/article/details/6901459
以前有J2EE基础,接触JAVA也有两三年的时间了,上手Android并不困难,思维上稍微转变一下就可以很快适应。以前做的都是WEB项目,现今体验移动终端项目,让我越来越觉得移动互联网应用是未来的主宰。
下面说说我学习Android的感受,我学Android首先是看MARS的视
- java 遍历Map的四种方法
eksliang
javaHashMapjava 遍历Map的四种方法
转载请出自出处:
http://eksliang.iteye.com/blog/2059996
package com.ickes;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Map.Entry;
/**
* 遍历Map的四种方式
- 【精典】数据库相关相关
gengzg
数据库
package C3P0;
import java.sql.Connection;
import java.sql.SQLException;
import java.beans.PropertyVetoException;
import com.mchange.v2.c3p0.ComboPooledDataSource;
public class DBPool{
- 自动补全
huyana_town
自动补全
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml&quo
- jquery在线预览PDF文件,打开PDF文件
天梯梦
jquery
最主要的是使用到了一个jquery的插件jquery.media.js,使用这个插件就很容易实现了。
核心代码
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.
- ViewPager刷新单个页面的方法
lovelease
androidviewpagertag刷新
使用ViewPager做滑动切换图片的效果时,如果图片是从网络下载的,那么再子线程中下载完图片时我们会使用handler通知UI线程,然后UI线程就可以调用mViewPager.getAdapter().notifyDataSetChanged()进行页面的刷新,但是viewpager不同于listview,你会发现单纯的调用notifyDataSetChanged()并不能刷新页面
- 利用按位取反(~)从复合枚举值里清除枚举值
草料场
enum
以 C# 中的 System.Drawing.FontStyle 为例。
如果需要同时有多种效果,
如:“粗体”和“下划线”的效果,可以用按位或(|)
FontStyle style = FontStyle.Bold | FontStyle.Underline;
如果需要去除 style 里的某一种效果,
- Linux系统新手学习的11点建议
刘星宇
编程工作linux脚本
随着Linux应用的扩展许多朋友开始接触Linux,根据学习Windwos的经验往往有一些茫然的感觉:不知从何处开始学起。这里介绍学习Linux的一些建议。
一、从基础开始:常常有些朋友在Linux论坛问一些问题,不过,其中大多数的问题都是很基础的。例如:为什么我使用一个命令的时候,系统告诉我找不到该目录,我要如何限制使用者的权限等问题,这些问题其实都不是很难的,只要了解了 Linu
- hibernate dao层应用之HibernateDaoSupport二次封装
wangzhezichuan
DAOHibernate
/**
* <p>方法描述:sql语句查询 返回List<Class> </p>
* <p>方法备注: Class 只能是自定义类 </p>
* @param calzz
* @param sql
* @return
* <p>创建人:王川</p>
* <p>创建时间:Jul